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.
 
 

368 lines
14 KiB

@extends('layouts.admin.app')
@section('title',\App\Models\BusinessSetting::where(['key'=>'business_name'])->first()->value??'Dashboard')
@section('content')
<style>
.bg-dddd{
background-color: #44f279 !important;
}
</style>
<div class="content container-fluid">
@if(auth('admin')->user()->role_id == 1)
<!-- Page Header -->
<div class="page-header">
<div class="d-flex flex-wrap justify-content-between align-items-center">
<div class="page--header-title">
<h1 class="page-header-title">{{translate('messages.welcome')}}, {{auth('admin')->user()->f_name}}.</h1>
<p class="page-header-text">{{translate('messages.welcome_message')}}</p>
</div>
<div class="page--header-select">
<select name="zone_id" class="form-control js-select2-custom"
onchange="fetch_data_zone_wise(this.value)">
<option value="all">{{translate('all_zones')}}</option>
@foreach(\App\Models\Zone::orderBy('name')->get() as $zone)
<option
value="{{$zone['id']}}" {{$params['zone_id'] == $zone['id']?'selected':''}}>
{{$zone['name']}}
</option>
@endforeach
</select>
</div>
</div>
</div>
<!-- End Page Header -->
<!-- Stats -->
<div class="card mb-3">
<div class="card-body pt-0">
<div id="order_stats_top">
@include('admin-views.partials._order-statics',['data'=>$data])
</div>
<div class="row g-2 mt-2" id="order_stats">
@include('admin-views.partials._dashboard-order-stats',['data'=>$data])
</div>
</div>
</div>
<!-- End Stats -->
<div class="row">
<div class="col-lg-12">
<!-- Card -->
<div class="card h-100" id="monthly-earning-graph">
<!-- Body -->
@include('admin-views.partials._monthly-earning-graph',['total_sell'=>$total_sell,'total_subs' =>$total_subs,'commission'=>$commission])
<!-- End Body -->
</div>
<!-- End Card -->
</div>
</div>
<!-- End Row -->
<div class="row g-2 mt-2">
<div class="col-lg-6">
<!-- Card -->
<div class="card h-100">
<!-- Header -->
<div class="card-header align-items-center">
<h5 class="card-title">
<img src="{{asset('/public/assets/admin/img/dashboard/statistics.png')}}" alt="dashboard" class="card-header-icon">
<span>{{translate('user_statistics')}}</span>
</h5>
<div id="stat_zone">
@include('admin-views.partials._zone-change',['data'=>$data])
</div>
</div>
<!-- End Header -->
<!-- Body -->
<div class="card-body">
<div class="row justify-content-end">
<div class="col-sm-6 col-md-4">
<div class="ml-auto mb-2 pb-xl-5">
<select class="custom-select" name="user_overview"
onchange="user_overview_stats_update(this.value)">
<option
value="this_month" {{$params['user_overview'] == 'this_month'?'selected':''}}>
{{translate('This month')}}
</option>
<option
value="overall" {{$params['user_overview'] == 'overall'?'selected':''}}>
{{translate('messages.Overall')}}
</option>
</select>
</div>
</div>
</div>
<div class="position-relative" >
<div id="user-overview-board">
{{-- @include('admin-views.partials._user-overview-chart') --}}
@php($params = session('dash_params'))
@if ($params['zone_id'] != 'all')
@php($zone_name = \App\Models\Zone::where('id', $params['zone_id'])->first()->name)
@else
@php($zone_name=translate('All'))
@endif
<div class="chartjs-custom mx-auto">
<canvas id="user-overview" class="mt-2"></canvas>
</div>
<div class="total--users">
<span>{{translate('messages.total_users')}}</span>
<h3>{{ $data['customer'] + $data['restaurants'] + $data['delivery_man'] }}</h3>
</div>
</div>
</div>
<div class="d-flex flex-wrap justify-content-center mt-4 pt-xl-5">
<div class="chart--label">
<span class="indicator bg-FFC960"></span>
<span class="info">
{{translate('messages.customer')}}
</span>
</div>
<div class="chart--label">
<span class="indicator bg-0661CB"></span>
<span class="info">
{{translate('messages.restaurant')}}
</span>
</div>
<div class="chart--label">
<span class="indicator bg-7ECAFF"></span>
<span class="info">
{{ translate('messages.delivery_man')}}
</span>
</div>
</div>
<!-- End Chart -->
</div>
<!-- End Body -->
</div>
</div>
<div class="col-lg-6">
<!-- Card -->
<div class="card h-100" id="popular-restaurants-view">
@include('admin-views.partials._popular-restaurants',['popular'=>$data['popular']])
</div>
<!-- End Card -->
</div>
<div class="col-lg-6">
<!-- Card -->
<div class="card h-100" id="top-deliveryman-view">
@include('admin-views.partials._top-deliveryman',['top_deliveryman'=>$data['top_deliveryman']])
</div>
<!-- End Card -->
</div>
<div class="col-lg-6">
<!-- Card -->
<div class="card h-100" id="top-restaurants-view">
@include('admin-views.partials._top-restaurants',['top_restaurants'=>$data['top_restaurants']])
</div>
<!-- End Card -->
</div>
<div class="col-lg-6">
<!-- Card -->
<div class="card h-100" id="top-rated-foods-view">
@include('admin-views.partials._top-rated-foods',['top_rated_foods'=>$data['top_rated_foods']])
</div>
<!-- End Card -->
</div>
<div class="col-lg-6">
<!-- Card -->
<div class="card h-100" id="top-selling-foods-view">
@include('admin-views.partials._top-selling-foods',['top_sell'=>$data['top_sell']])
</div>
<!-- End Card -->
</div>
</div>
@else
<!-- Page Header -->
<div class="page-header">
<div class="row align-items-center">
<div class="col-sm mb-2 mb-sm-0">
<h1 class="page-header-title">{{translate('messages.welcome')}}, {{auth('admin')->user()->f_name}}.</h1>
<p class="page-header-text">{{translate('messages.employee_welcome_message')}}</p>
</div>
</div>
</div>
<!-- End Page Header -->
@endif
</div>
@endsection
@push('script')
<script src="{{asset('public/assets/admin')}}/vendor/chart.js/dist/Chart.min.js"></script>
<script src="{{asset('public/assets/admin')}}/vendor/chart.js.extensions/chartjs-extensions.js"></script>
<script src="{{asset('public/assets/admin')}}/vendor/chartjs-plugin-datalabels/dist/chartjs-plugin-datalabels.min.js"></script>
@endpush
@push('script_2')
<script>
// INITIALIZATION OF CHARTJS
// =======================================================
Chart.plugins.unregister(ChartDataLabels);
$('.js-chart').each(function () {
$.HSCore.components.HSChartJS.init($(this));
});
var updatingChart = $.HSCore.components.HSChartJS.init($('#updatingData'));
</script>
<script>
var ctx = document.getElementById('user-overview');
var myChart = new Chart(ctx, {
type: 'doughnut',
data: {
datasets: [{
label: 'User',
data: ['{{$data['customer']}}', '{{$data['restaurants']}}', '{{$data['delivery_man']}}'],
backgroundColor: [
'#FFC960',
'#0661CB',
'#7ECAFF'
],
hoverOffset: 3
}],
labels: [
'{{translate('messages.customer')}}',
'{{translate('messages.restaurant')}}',
'{{ translate('messages.delivery_man')}}'
],
},
options: {
scales: {
y: {
beginAtZero: true
}
},
legend: {
display: false,
position: 'chartArea',
}
}
});
</script>
<script>
function order_stats_update(type) {
$.ajaxSetup({
headers: {
'X-CSRF-TOKEN': $('meta[name="csrf-token"]').attr('content')
}
});
$.post({
url: '{{route('admin.dashboard-stats.order')}}',
data: {
statistics_type: type
},
beforeSend: function () {
$('#loading').show()
},
success: function (data) {
insert_param('statistics_type',type);
$('#order_stats').html(data.view)
$('#order_stats_top').html(data.order_stats_top)
},
complete: function () {
$('#loading').hide()
}
});
}
function fetch_data_zone_wise(zone_id) {
$.ajaxSetup({
headers: {
'X-CSRF-TOKEN': $('meta[name="csrf-token"]').attr('content')
}
});
$.post({
url: '{{route('admin.dashboard-stats.zone')}}',
data: {
zone_id: zone_id
},
beforeSend: function () {
$('#loading').show()
},
success: function (data) {
insert_param('zone_id', zone_id);
$('#order_stats_top').html(data.order_stats_top);
$('#order_stats').html(data.order_stats);
$('#stat_zone').html(data.stat_zone);
$('#user-overview-board').html(data.user_overview);
$('#monthly-earning-graph').html(data.monthly_graph);
$('#popular-restaurants-view').html(data.popular_restaurants);
$('#top-deliveryman-view').html(data.top_deliveryman);
$('#top-rated-foods-view').html(data.top_rated_foods);
$('#top-restaurants-view').html(data.top_restaurants);
$('#top-selling-foods-view').html(data.top_selling_foods);
},
complete: function () {
$('#loading').hide()
}
});
}
function user_overview_stats_update(type) {
$.ajaxSetup({
headers: {
'X-CSRF-TOKEN': $('meta[name="csrf-token"]').attr('content')
}
});
$.post({
url: '{{route('admin.dashboard-stats.user-overview')}}',
data: {
user_overview: type
},
beforeSend: function () {
$('#loading').show()
},
success: function (data) {
insert_param('user_overview',type);
$('#user-overview-board').html(data.view)
},
complete: function () {
$('#loading').hide()
}
});
}
</script>
<script>
function insert_param(key, value) {
key = encodeURIComponent(key);
value = encodeURIComponent(value);
// kvp looks like ['key1=value1', 'key2=value2', ...]
var kvp = document.location.search.substr(1).split('&');
let i = 0;
for (; i < kvp.length; i++) {
if (kvp[i].startsWith(key + '=')) {
let pair = kvp[i].split('=');
pair[1] = value;
kvp[i] = pair.join('=');
break;
}
}
if (i >= kvp.length) {
kvp[kvp.length] = [key, value].join('=');
}
// can return this or...
let params = kvp.join('&');
// change url page with new params
window.history.pushState('page2', 'Title', '{{url()->current()}}?' + params);
}
</script>
@endpush