add Hide Dashboard Content

This commit is contained in:
Ibnu Maksum 2024-02-07 12:02:39 +07:00
parent 671154d146
commit f62f07d102
No known key found for this signature in database
GPG Key ID: 7FC82848810579E5
6 changed files with 345 additions and 284 deletions

View File

@ -188,6 +188,8 @@ CREATE TABLE `tb_languages` (
`id` int(11) NOT NULL `id` int(11) NOT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci; ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;
ALTER TABLE `tbl_voucher` ADD `generated_by` INT NOT NULL DEFAULT '0' COMMENT 'id admin' AFTER `status`;
ALTER TABLE `tbl_users` ADD `root` INT NOT NULL DEFAULT '0' COMMENT 'for sub account' AFTER `id`;
ALTER TABLE `tbl_appconfig` ALTER TABLE `tbl_appconfig`
ADD PRIMARY KEY (`id`); ADD PRIMARY KEY (`id`);

View File

@ -51,26 +51,28 @@ if (empty($c_all)) {
} }
$ui->assign('c_all', $c_all); $ui->assign('c_all', $c_all);
//user expire if($config['hide_uet'] != 'yes'){
$paginator = Paginator::build(ORM::for_table('tbl_user_recharges')); //user expire
$expire = ORM::for_table('tbl_user_recharges') $paginator = Paginator::build(ORM::for_table('tbl_user_recharges'));
->where_lte('expiration', $mdate) $expire = ORM::for_table('tbl_user_recharges')
->offset($paginator['startpoint']) ->where_lte('expiration', $mdate)
->limit($paginator['limit']) ->offset($paginator['startpoint'])
->order_by_desc('expiration') ->limit($paginator['limit'])
->find_many(); ->order_by_desc('expiration')
->find_many();
// Get the total count of expired records for pagination // Get the total count of expired records for pagination
$totalCount = ORM::for_table('tbl_user_recharges') $totalCount = ORM::for_table('tbl_user_recharges')
->where_lte('expiration', $mdate) ->where_lte('expiration', $mdate)
->count(); ->count();
// Pass the total count and current page to the paginator // Pass the total count and current page to the paginator
$paginator['total_count'] = $totalCount; $paginator['total_count'] = $totalCount;
// Assign the pagination HTML to the template variable // Assign the pagination HTML to the template variable
$ui->assign('paginator', $paginator); $ui->assign('paginator', $paginator);
$ui->assign('expire', $expire); $ui->assign('expire', $expire);
}
//activity log //activity log
$dlog = ORM::for_table('tbl_logs')->limit(5)->order_by_desc('id')->find_many(); $dlog = ORM::for_table('tbl_logs')->limit(5)->order_by_desc('id')->find_many();
@ -79,36 +81,38 @@ $log = ORM::for_table('tbl_logs')->count();
$ui->assign('log', $log); $ui->assign('log', $log);
$cacheStocksfile = File::pathFixer('system/cache/VoucherStocks.temp'); if($config['hide_vs'] != 'yes'){
$cachePlanfile = File::pathFixer('system/cache/VoucherPlans.temp'); $cacheStocksfile = File::pathFixer('system/cache/VoucherStocks.temp');
//Cache for 5 minutes $cachePlanfile = File::pathFixer('system/cache/VoucherPlans.temp');
if(file_exists($cacheStocksfile) && time()- filemtime($cacheStocksfile) < 600){ //Cache for 5 minutes
$stocks = json_decode(file_get_contents($cacheStocksfile), true); if(file_exists($cacheStocksfile) && time()- filemtime($cacheStocksfile) < 600){
$plans = json_decode(file_get_contents($cachePlanfile), true); $stocks = json_decode(file_get_contents($cacheStocksfile), true);
}else{ $plans = json_decode(file_get_contents($cachePlanfile), true);
// Count stock }else{
$tmp = $v = ORM::for_table('tbl_plans')->select('id')->select('name_plan')->find_many(); // Count stock
$plans = array(); $tmp = $v = ORM::for_table('tbl_plans')->select('id')->select('name_plan')->find_many();
$stocks = array("used" => 0, "unused" => 0); $plans = array();
$n = 0; $stocks = array("used" => 0, "unused" => 0);
foreach ($tmp as $plan) { $n = 0;
$unused = ORM::for_table('tbl_voucher') foreach ($tmp as $plan) {
->where('id_plan', $plan['id']) $unused = ORM::for_table('tbl_voucher')
->where('status', 0)->count(); ->where('id_plan', $plan['id'])
$used = ORM::for_table('tbl_voucher') ->where('status', 0)->count();
->where('id_plan', $plan['id']) $used = ORM::for_table('tbl_voucher')
->where('status', 1)->count(); ->where('id_plan', $plan['id'])
if ($unused > 0 || $used > 0) { ->where('status', 1)->count();
$plans[$n]['name_plan'] = $plan['name_plan']; if ($unused > 0 || $used > 0) {
$plans[$n]['unused'] = $unused; $plans[$n]['name_plan'] = $plan['name_plan'];
$plans[$n]['used'] = $used; $plans[$n]['unused'] = $unused;
$stocks["unused"] += $unused; $plans[$n]['used'] = $used;
$stocks["used"] += $used; $stocks["unused"] += $unused;
$n++; $stocks["used"] += $used;
$n++;
}
} }
file_put_contents($cacheStocksfile, json_encode($stocks));
file_put_contents($cachePlanfile, json_encode($plans));
} }
file_put_contents($cacheStocksfile, json_encode($stocks));
file_put_contents($cachePlanfile, json_encode($plans));
} }
$cacheMRfile = File::pathFixer('system/cache/monthlyRegistered.temp'); $cacheMRfile = File::pathFixer('system/cache/monthlyRegistered.temp');
@ -181,7 +185,6 @@ if(file_exists($cacheMSfile) && time()- filemtime($cacheMSfile) < 43200){
// Assign the monthly sales data to Smarty // Assign the monthly sales data to Smarty
$ui->assign('monthlySales', $monthlySales); $ui->assign('monthlySales', $monthlySales);
$ui->assign('xheader', '<script src="https://cdn.jsdelivr.net/npm/apexcharts@3.28.0/dist/apexcharts.min.js"></script>');
$ui->assign('xfooter', ''); $ui->assign('xfooter', '');
$ui->assign('monthlyRegistered', $monthlyRegistered); $ui->assign('monthlyRegistered', $monthlyRegistered);
$ui->assign('stocks', $stocks); $ui->assign('stocks', $stocks);

View File

@ -299,6 +299,23 @@ switch ($action) {
} }
} }
//checkbox
$checks = ['hide_mrc','hide_tms','hide_aui','hide_al','hide_uet','hide_vs','hide_pg'];
foreach ($checks as $check) {
if(!isset($_POST[$check])){
$d = ORM::for_table('tbl_appconfig')->where('setting', $check)->find_one();
if ($d) {
$d->value = 'no';
$d->save();
} else {
$d = ORM::for_table('tbl_appconfig')->create();
$d->setting = $check;
$d->value = 'no';
$d->save();
}
}
}
_log('[' . $admin['username'] . ']: ' . $_L['Settings_Saved_Successfully'], 'Admin', $admin['id']); _log('[' . $admin['username'] . ']: ' . $_L['Settings_Saved_Successfully'], 'Admin', $admin['id']);
r2(U . 'settings/app', 's', $_L['Settings_Saved_Successfully']); r2(U . 'settings/app', 's', $_L['Settings_Saved_Successfully']);

View File

@ -86,6 +86,24 @@
<p class="help-block col-md-4">edit at config.php</p> <p class="help-block col-md-4">edit at config.php</p>
</div> </div>
</div> </div>
<div class="panel-heading">
<div class="btn-group pull-right">
<button class="btn btn-primary btn-xs" title="save" type="submit"><span
class="glyphicon glyphicon-floppy-disk" aria-hidden="true"></span></button>
</div>
Hide Dashboard Content
</div>
<div class="panel-body">
<div class="form-group">
<label class="col-md-3 control-label"><input type="checkbox" name="hide_mrc" value="yes" {if $_c['hide_mrc'] eq 'yes'}checked{/if}> {Lang::T('Monthly Registered Customers')}</label>
<label class="col-md-2 control-label"><input type="checkbox" name="hide_tms" value="yes" {if $_c['hide_tms'] eq 'yes'}checked{/if}> {Lang::T('Total Monthly Sales')}</label>
<label class="col-md-2 control-label"><input type="checkbox" name="hide_aui" value="yes" {if $_c['hide_aui'] eq 'yes'}checked{/if}> {Lang::T('All Users Insights')}</label>
<label class="col-md-2 control-label"><input type="checkbox" name="hide_al" value="yes" {if $_c['hide_al'] eq 'yes'}checked{/if}> {$_L['Activity_Log']}</label>
<label class="col-md-2 control-label"><input type="checkbox" name="hide_uet" value="yes" {if $_c['hide_uet'] eq 'yes'}checked{/if}> {$_L['User_Expired_Today']}</label>
<label class="col-md-2 control-label"><input type="checkbox" name="hide_vs" value="yes" {if $_c['hide_vs'] eq 'yes'}checked{/if}> Vouchers Stock</label>
<label class="col-md-2 control-label"><input type="checkbox" name="hide_pg" value="yes" {if $_c['hide_pg'] eq 'yes'}checked{/if}> Payment Gateway</label>
</div>
</div>
<div class="panel-heading"> <div class="panel-heading">
<div class="btn-group pull-right"> <div class="btn-group pull-right">
<button class="btn btn-primary btn-xs" title="save" type="submit"><span <button class="btn btn-primary btn-xs" title="save" type="submit"><span
@ -417,7 +435,7 @@
</div> </div>
</div> </div>
</div> </div>
<div class="panel-heading" id="envato"> {* <div class="panel-heading" id="envato">
<div class="btn-group pull-right"> <div class="btn-group pull-right">
<button class="btn btn-primary btn-xs" title="save" type="submit"><span <button class="btn btn-primary btn-xs" title="save" type="submit"><span
class="glyphicon glyphicon-floppy-disk" aria-hidden="true"></span></button> class="glyphicon glyphicon-floppy-disk" aria-hidden="true"></span></button>
@ -444,7 +462,7 @@
class="btn btn-xs btn-primary">View MarketPlace</a> class="btn btn-xs btn-primary">View MarketPlace</a>
</label> </label>
</div> </div>
</div> </div> *}
</div> </div>
<div class="panel-body"> <div class="panel-body">

View File

@ -61,129 +61,144 @@
</div> </div>
</div> </div>
<!-- solid sales graph --> <!-- solid sales graph -->
<div class="box box-solid "> {if $_c['hide_mrc'] != 'yes'}
<div class="box-header"> <div class="box box-solid ">
<i class="fa fa-th"></i> <div class="box-header">
<i class="fa fa-th"></i>
<h3 class="box-title">{Lang::T('Monthly Registered Customers')}</h3> <h3 class="box-title">{Lang::T('Monthly Registered Customers')}</h3>
<div class="box-tools pull-right"> <div class="box-tools pull-right">
<button type="button" class="btn bg-teal btn-sm" data-widget="collapse"><i class="fa fa-minus"></i> <button type="button" class="btn bg-teal btn-sm" data-widget="collapse"><i class="fa fa-minus"></i>
</button> </button>
<button type="button" class="btn bg-teal btn-sm" data-widget="remove"><i class="fa fa-times"></i> <button type="button" class="btn bg-teal btn-sm" data-widget="remove"><i class="fa fa-times"></i>
</button> </button>
</div>
</div>
<div class="box-body border-radius-none">
<canvas class="chart" id="chart" style="height: 250px;"></canvas>
</div> </div>
</div> </div>
<div class="box-body border-radius-none"> {/if}
<canvas class="chart" id="chart" style="height: 250px;"></canvas>
</div>
</div>
<!-- solid sales graph --> <!-- solid sales graph -->
<div class="box box-solid "> {if $_c['hide_tms'] != 'yes'}
<div class="box-header"> <div class="box box-solid ">
<i class="fa fa-inbox"></i> <div class="box-header">
<i class="fa fa-inbox"></i>
<h3 class="box-title">{Lang::T('Total Monthly Sales')}</h3> <h3 class="box-title">{Lang::T('Total Monthly Sales')}</h3>
<div class="box-tools pull-right"> <div class="box-tools pull-right">
<button type="button" class="btn bg-teal btn-sm" data-widget="collapse"><i class="fa fa-minus"></i> <button type="button" class="btn bg-teal btn-sm" data-widget="collapse"><i class="fa fa-minus"></i>
</button> </button>
<button type="button" class="btn bg-teal btn-sm" data-widget="remove"><i class="fa fa-times"></i> <button type="button" class="btn bg-teal btn-sm" data-widget="remove"><i class="fa fa-times"></i>
</button> </button>
</div>
</div>
<div class="box-body border-radius-none">
<canvas class="chart" id="salesChart" style="height: 250px;"></canvas>
</div> </div>
</div> </div>
<div class="box-body border-radius-none"> {/if}
<canvas class="chart" id="salesChart" style="height: 250px;"></canvas>
</div>
</div>
<div class="row"> <div class="row">
<div class="col-md-7"> <div class="col-md-7">
{if $_c['disable_voucher'] != 'yes' && $stocks['unused']>0 || $stocks['used']>0} {if $_c['disable_voucher'] != 'yes' && $stocks['unused']>0 || $stocks['used']>0}
<div class="panel panel-primary mb20 panel-hovered project-stats table-responsive"> {if $_c['hide_vs'] != 'yes'}
<div class="panel-heading">Vouchers Stock</div> <div class="panel panel-primary mb20 panel-hovered project-stats table-responsive">
<div class="panel-heading">Vouchers Stock</div>
<div class="table-responsive">
<table class="table">
<thead>
<tr>
<th>{$_L['Plan_Name']}</th>
<th>unused</th>
<th>used</th>
</tr>
</thead>
<tbody>
{foreach $plans as $stok}
<tr>
<td>{$stok['name_plan']}</td>
<td>{$stok['unused']}</td>
<td>{$stok['used']}</td>
</tr>
</tbody>
{/foreach}
<tr>
<td>Total</td>
<td>{$stocks['unused']}</td>
<td>{$stocks['used']}</td>
</tr>
</table>
</div>
</div>
{/if}
{/if}
{if $_c['hide_uet'] != 'yes'}
<div class="panel panel-warning mb20 panel-hovered project-stats table-responsive">
<div class="panel-heading">{$_L['User_Expired_Today']}</div>
<div class="table-responsive"> <div class="table-responsive">
<table class="table"> <table class="table">
<thead> <thead>
<tr> <tr>
<th>{$_L['Plan_Name']}</th> <th>Id</th>
<th>unused</th> <th>{$_L['Username']}</th>
<th>used</th> <th>{$_L['Created_On']}</th>
<th>{$_L['Expires_On']}</th>
</tr> </tr>
</thead> </thead>
<tbody> <tbody>
{foreach $plans as $stok} {$no = 1}
{foreach $expire as $expired}
<tr> <tr>
<td>{$stok['name_plan']}</td> <td>{$no++}</td>
<td>{$stok['unused']}</td> <td><a href="{$_url}customers/viewu/{$expired['username']}">{$expired['username']}</a></td>
<td>{$stok['used']}</td> <td>{Lang::dateAndTimeFormat($expired['recharged_on'],$expired['recharged_time'])}
</td>
<td>{Lang::dateAndTimeFormat($expired['expiration'],$expired['time'])}
</td>
</tr> </tr>
</tbody> </tbody>
{/foreach} {/foreach}
<tr>
<td>Total</td>
<td>{$stocks['unused']}</td>
<td>{$stocks['used']}</td>
</tr>
</table> </table>
</div> </div>
&nbsp; {$paginator['contents']}
</div> </div>
{/if} {/if}
<div class="panel panel-warning mb20 panel-hovered project-stats table-responsive">
<div class="panel-heading">{$_L['User_Expired_Today']}</div>
<div class="table-responsive">
<table class="table">
<thead>
<tr>
<th>Id</th>
<th>{$_L['Username']}</th>
<th>{$_L['Created_On']}</th>
<th>{$_L['Expires_On']}</th>
</tr>
</thead>
<tbody>
{$no = 1}
{foreach $expire as $expired}
<tr>
<td>{$no++}</td>
<td><a href="{$_url}customers/viewu/{$expired['username']}">{$expired['username']}</a></td>
<td>{Lang::dateAndTimeFormat($expired['recharged_on'],$expired['recharged_time'])}
</td>
<td>{Lang::dateAndTimeFormat($expired['expiration'],$expired['time'])}
</td>
</tr>
</tbody>
{/foreach}
</table>
</div>
&nbsp; {$paginator['contents']}
</div>
</div> </div>
<div class="col-md-5"> <div class="col-md-5">
<div class="panel panel-success panel-hovered mb20 activities"> {if $_c['hide_pg'] != 'yes'}
<div class="panel-heading">{Lang::T('Payment Gateway')}: {$_c['payment_gateway']}</div> <div class="panel panel-success panel-hovered mb20 activities">
</div> <div class="panel-heading">{Lang::T('Payment Gateway')}: {$_c['payment_gateway']}</div>
<div class="panel panel-info panel-hovered mb20 activities">
<div class="panel-heading">{Lang::T('All Users Insights')}</div>
<div class="panel-body">
<canvas id="userRechargesChart"></canvas>
</div> </div>
</div> {/if}
<div class="panel panel-info panel-hovered mb20 activities"> {if $_c['hide_aui'] != 'yes'}
<div class="panel-heading"><a href="{$_url}logs">{$_L['Activity_Log']}</a></div> <div class="panel panel-info panel-hovered mb20 activities">
<div class="panel-body"> <div class="panel-heading">{Lang::T('All Users Insights')}</div>
<ul class="list-unstyled"> <div class="panel-body">
{foreach $dlog as $dlogs} <canvas id="userRechargesChart"></canvas>
<li class="primary"> </div>
<span class="point"></span>
<span class="time small text-muted">{time_elapsed_string($dlogs['date'],true)}</span>
<p>{$dlogs['description']}</p>
</li>
{/foreach}
</ul>
</div> </div>
</div> {/if}
{if $_c['hide_al'] != 'yes'}
<div class="panel panel-info panel-hovered mb20 activities">
<div class="panel-heading"><a href="{$_url}logs">{$_L['Activity_Log']}</a></div>
<div class="panel-body">
<ul class="list-unstyled">
{foreach $dlog as $dlogs}
<li class="primary">
<span class="point"></span>
<span class="time small text-muted">{time_elapsed_string($dlogs['date'],true)}</span>
<p>{$dlogs['description']}</p>
</li>
{/foreach}
</ul>
</div>
</div>
{/if}
</div> </div>
@ -191,162 +206,168 @@
<script src="https://cdn.jsdelivr.net/npm/chart.js@3.5.1/dist/chart.min.js"></script> <script src="https://cdn.jsdelivr.net/npm/chart.js@3.5.1/dist/chart.min.js"></script>
{literal}
<script type="text/javascript">
document.addEventListener("DOMContentLoaded", function() {
var counts = JSON.parse('{/literal}{$monthlyRegistered|json_encode}{literal}');
var monthNames = [ <script type="text/javascript">
'Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', {if $_c['hide_mrc'] != 'yes'}
'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec' {literal}
]; document.addEventListener("DOMContentLoaded", function() {
var counts = JSON.parse('{/literal}{$monthlyRegistered|json_encode}{literal}');
var labels = []; var monthNames = [
var data = []; 'Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun',
'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'
];
for (var i = 1; i <= 12; i++) { var labels = [];
var month = counts.find(count => count.date === i); var data = [];
labels.push(month ? monthNames[i - 1] : monthNames[i - 1].substring(0, 3));
data.push(month ? month.count : 0); for (var i = 1; i <= 12; i++) {
var month = counts.find(count => count.date === i);
labels.push(month ? monthNames[i - 1] : monthNames[i - 1].substring(0, 3));
data.push(month ? month.count : 0);
}
var ctx = document.getElementById('chart').getContext('2d');
var chart = new Chart(ctx, {
type: 'bar',
data: {
labels: labels,
datasets: [{
label: 'Registered Members',
data: data,
backgroundColor: 'rgba(0, 0, 255, 0.5)',
borderColor: 'rgba(0, 0, 255, 0.7)',
borderWidth: 1
}]
},
options: {
responsive: true,
scales: {
x: {
grid: {
display: false
}
},
y: {
beginAtZero: true,
grid: {
color: 'rgba(0, 0, 0, 0.1)'
}
}
}
}
});
});
{/literal}
{/if}
{if $_c['hide_tmc'] != 'yes'}
{literal}
document.addEventListener("DOMContentLoaded", function() {
var monthlySales = JSON.parse('{/literal}{$monthlySales|json_encode}{literal}');
var monthNames = [
'Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun',
'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'
];
var labels = [];
var data = [];
for (var i = 1; i <= 12; i++) {
var month = findMonthData(monthlySales, i);
labels.push(month ? monthNames[i - 1] : monthNames[i - 1].substring(0, 3));
data.push(month ? month.totalSales : 0);
}
var ctx = document.getElementById('salesChart').getContext('2d');
var chart = new Chart(ctx, {
type: 'bar',
data: {
labels: labels,
datasets: [{
label: 'Monthly Sales',
data: data,
backgroundColor: 'rgba(2, 10, 242)', // Customize the background color
borderColor: 'rgba(255, 99, 132, 1)', // Customize the border color
borderWidth: 1
}]
},
options: {
responsive: true,
scales: {
x: {
grid: {
display: false
}
},
y: {
beginAtZero: true,
grid: {
color: 'rgba(0, 0, 0, 0.1)'
}
}
}
}
});
});
function findMonthData(monthlySales, month) {
for (var i = 0; i < monthlySales.length; i++) {
if (monthlySales[i].month === month) {
return monthlySales[i];
}
}
return null;
} }
{/literal}
var ctx = document.getElementById('chart').getContext('2d'); {/if}
var chart = new Chart(ctx, { {if $_c['hide_aui'] != 'yes'}
type: 'bar', {literal}
data: { document.addEventListener("DOMContentLoaded", function() {
labels: labels, // Get the data from PHP and assign it to JavaScript variables
var u_act = '{/literal}{$u_act}{literal}';
var c_all = '{/literal}{$c_all}{literal}';
var u_all = '{/literal}{$u_all}{literal}';
//lets calculate the inactive users as reported
var expired = u_all - u_act;
var inactive = c_all - u_all;
// Create the chart data
var data = {
labels: ['Active Users', 'Expired Users', 'Inactive Users'],
datasets: [{ datasets: [{
label: 'Registered Members', label: 'User Recharges',
data: data, data: [parseInt(u_act), parseInt(expired), parseInt(inactive)],
backgroundColor: 'rgba(0, 0, 255, 0.5)', backgroundColor: ['rgba(4, 191, 13)', 'rgba(191, 35, 4)', 'rgba(0, 0, 255, 0.5'],
borderColor: 'rgba(0, 0, 255, 0.7)', borderColor: ['rgba(0, 255, 0, 1)', 'rgba(255, 99, 132, 1)', 'rgba(0, 0, 255, 0.7'],
borderWidth: 1 borderWidth: 1
}] }]
}, };
options: {
// Create chart options
var options = {
responsive: true, responsive: true,
scales: { aspectRatio: 1,
x: { plugins: {
grid: { legend: {
display: false position: 'bottom',
} labels: {
}, boxWidth: 15
y: {
beginAtZero: true,
grid: {
color: 'rgba(0, 0, 0, 0.1)'
} }
} }
} }
} };
// Get the canvas element and create the chart
var ctx = document.getElementById('userRechargesChart').getContext('2d');
var chart = new Chart(ctx, {
type: 'pie',
data: data,
options: options
});
}); });
}); {/literal}
</script> {/if}
</script>
<script type="text/javascript">
document.addEventListener("DOMContentLoaded", function() {
var monthlySales = JSON.parse('{/literal}{$monthlySales|json_encode}{literal}');
var monthNames = [
'Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun',
'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'
];
var labels = [];
var data = [];
for (var i = 1; i <= 12; i++) {
var month = findMonthData(monthlySales, i);
labels.push(month ? monthNames[i - 1] : monthNames[i - 1].substring(0, 3));
data.push(month ? month.totalSales : 0);
}
var ctx = document.getElementById('salesChart').getContext('2d');
var chart = new Chart(ctx, {
type: 'bar',
data: {
labels: labels,
datasets: [{
label: 'Monthly Sales',
data: data,
backgroundColor: 'rgba(2, 10, 242)', // Customize the background color
borderColor: 'rgba(255, 99, 132, 1)', // Customize the border color
borderWidth: 1
}]
},
options: {
responsive: true,
scales: {
x: {
grid: {
display: false
}
},
y: {
beginAtZero: true,
grid: {
color: 'rgba(0, 0, 0, 0.1)'
}
}
}
}
});
});
function findMonthData(monthlySales, month) {
for (var i = 0; i < monthlySales.length; i++) {
if (monthlySales[i].month === month) {
return monthlySales[i];
}
}
return null;
}
document.addEventListener("DOMContentLoaded", function() {
// Get the data from PHP and assign it to JavaScript variables
var u_act = '{/literal}{$u_act}{literal}';
var c_all = '{/literal}{$c_all}{literal}';
var u_all = '{/literal}{$u_all}{literal}';
//lets calculate the inactive users as reported
var expired = u_all - u_act;
var inactive = c_all - u_all;
// Create the chart data
var data = {
labels: ['Active Users', 'Expired Users', 'Inactive Users'],
datasets: [{
label: 'User Recharges',
data: [parseInt(u_act), parseInt(expired), parseInt(inactive)],
backgroundColor: ['rgba(4, 191, 13)', 'rgba(191, 35, 4)', 'rgba(0, 0, 255, 0.5'],
borderColor: ['rgba(0, 255, 0, 1)', 'rgba(255, 99, 132, 1)', 'rgba(0, 0, 255, 0.7'],
borderWidth: 1
}]
};
// Create chart options
var options = {
responsive: true,
aspectRatio: 1,
plugins: {
legend: {
position: 'bottom',
labels: {
boxWidth: 15
}
}
}
};
// Get the canvas element and create the chart
var ctx = document.getElementById('userRechargesChart').getContext('2d');
var chart = new Chart(ctx, {
type: 'pie',
data: data,
options: options
});
});
</script>
{/literal}
<script> <script>
window.addEventListener('DOMContentLoaded', function() { window.addEventListener('DOMContentLoaded', function() {
$.getJSON("./version.json?" + Math.random(), function(data) { $.getJSON("./version.json?" + Math.random(), function(data) {

View File

@ -279,10 +279,10 @@
<a href="{$_url}pluginmanager"><i class="glyphicon glyphicon-tasks"></i> <a href="{$_url}pluginmanager"><i class="glyphicon glyphicon-tasks"></i>
{Lang::T('Plugin Manager')} <small class="label pull-right">Free</small></a> {Lang::T('Plugin Manager')} <small class="label pull-right">Free</small></a>
</li> </li>
<li {if $_routes[0] eq 'codecanyon'}class="active" {/if}> {* <li {if $_routes[0] eq 'codecanyon'}class="active" {/if}>
<a href="{$_url}codecanyon"><i class="glyphicon glyphicon-shopping-cart"></i> <a href="{$_url}codecanyon"><i class="glyphicon glyphicon-shopping-cart"></i>
Codecanyon.net <small class="label pull-right">Paid</small></a> Codecanyon.net <small class="label pull-right">Paid</small></a>
</li> </li> *}
</ul> </ul>
</li> </li>
{$_MENU_AFTER_SETTINGS} {$_MENU_AFTER_SETTINGS}