2019-11-16 10:21:14 +03:00
|
|
|
@extends('layouts.portal')
|
|
|
|
|
2020-01-07 17:25:54 +03:00
|
|
|
@section('title', trans_choice('general.dashboards', 1))
|
2019-11-16 10:21:14 +03:00
|
|
|
|
2021-06-04 16:21:05 +03:00
|
|
|
@section('new_button')
|
|
|
|
<!--Dashboard General Filter-->
|
|
|
|
<el-date-picker
|
|
|
|
v-model="filter_date"
|
|
|
|
type="daterange"
|
|
|
|
align="right"
|
|
|
|
unlink-panels
|
|
|
|
:format="'yyyy-MM-dd'"
|
|
|
|
value-format="yyyy-MM-dd"
|
|
|
|
@change="onChangeFilterDate"
|
|
|
|
range-separator=">>"
|
|
|
|
start-placeholder="{{ $date_picker_shortcuts[trans("reports.this_year")]["start"] }}"
|
|
|
|
end-placeholder="{{ $date_picker_shortcuts[trans("reports.this_year")]["end"] }}"
|
|
|
|
:picker-options="{
|
|
|
|
shortcuts: [
|
|
|
|
{
|
|
|
|
text: '{{ trans("reports.this_year") }}',
|
|
|
|
onClick(picker) {
|
|
|
|
const start = new Date('{{ $date_picker_shortcuts[trans("reports.this_year")]["start"] }}');
|
|
|
|
const end = new Date('{{ $date_picker_shortcuts[trans("reports.this_year")]["end"] }}');
|
|
|
|
|
|
|
|
picker.$emit('pick', [start, end]);
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
text: '{{ trans("reports.previous_year") }}',
|
|
|
|
onClick(picker) {
|
|
|
|
const start = new Date('{{ $date_picker_shortcuts[trans("reports.previous_year")]["start"] }}');
|
|
|
|
const end = new Date('{{ $date_picker_shortcuts[trans("reports.previous_year")]["end"] }}');
|
|
|
|
|
|
|
|
picker.$emit('pick', [start, end]);
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
text: '{{ trans("reports.this_quarter") }}',
|
|
|
|
onClick(picker) {
|
|
|
|
const start = new Date('{{ $date_picker_shortcuts[trans("reports.this_quarter")]["start"] }}');
|
|
|
|
const end = new Date('{{ $date_picker_shortcuts[trans("reports.this_quarter")]["end"] }}');
|
|
|
|
|
|
|
|
picker.$emit('pick', [start, end]);
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
text: '{{ trans("reports.previous_quarter") }}',
|
|
|
|
onClick(picker) {
|
|
|
|
const start = new Date('{{ $date_picker_shortcuts[trans("reports.previous_quarter")]["start"] }}');
|
|
|
|
const end = new Date('{{ $date_picker_shortcuts[trans("reports.previous_quarter")]["end"] }}');
|
|
|
|
|
|
|
|
picker.$emit('pick', [start, end]);
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
text: '{{ trans("reports.last_12_months") }}',
|
|
|
|
onClick(picker) {
|
|
|
|
const start = new Date('{{ $date_picker_shortcuts[trans("reports.last_12_months")]["start"] }}');
|
|
|
|
const end = new Date('{{ $date_picker_shortcuts[trans("reports.last_12_months")]["end"] }}');
|
|
|
|
|
|
|
|
picker.$emit('pick', [start, end]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
]
|
|
|
|
}">
|
|
|
|
</el-date-picker>
|
|
|
|
@endsection
|
|
|
|
|
2019-11-16 10:21:14 +03:00
|
|
|
@section('content')
|
|
|
|
<div class="row">
|
2020-04-05 19:50:51 +03:00
|
|
|
<div class="col-md-4">
|
2019-11-16 17:53:58 +03:00
|
|
|
<div class="card bg-gradient-success card-stats">
|
|
|
|
<div class="card-body">
|
|
|
|
<div class="row">
|
|
|
|
<div class="col">
|
|
|
|
<h5 class="text-uppercase text-white mb-0">{{ trans('general.paid') }}</h5>
|
2020-04-05 19:50:51 +03:00
|
|
|
<span class="font-weight-bold text-white mb-0">{{ $totals['paid'] }}</span>
|
2019-11-16 17:53:58 +03:00
|
|
|
</div>
|
2021-06-04 16:21:05 +03:00
|
|
|
|
2019-11-16 17:53:58 +03:00
|
|
|
<div class="col-auto">
|
|
|
|
<div class="icon icon-shape bg-white text-success rounded-circle shadow">
|
|
|
|
<i class="fa fa-money-bill"></i>
|
2019-11-16 10:21:14 +03:00
|
|
|
</div>
|
|
|
|
</div>
|
2019-11-16 17:53:58 +03:00
|
|
|
</div>
|
|
|
|
</div>
|
2021-06-04 16:21:05 +03:00
|
|
|
|
2020-04-05 19:50:51 +03:00
|
|
|
<div class="card-footer">
|
|
|
|
<div class="progress progress-xs mb-0">
|
|
|
|
<div class="progress-bar bg-success" role="progressbar" aria-valuenow="{{ $progress['paid'] }}" aria-valuemin="0" aria-valuemax="100" style="width: {{ $progress['paid'] }}%"></div>
|
2019-11-16 17:53:58 +03:00
|
|
|
</div>
|
2020-04-05 19:50:51 +03:00
|
|
|
</div>
|
2019-11-16 17:53:58 +03:00
|
|
|
</div>
|
|
|
|
</div>
|
2021-06-04 16:21:05 +03:00
|
|
|
|
2020-04-05 19:50:51 +03:00
|
|
|
<div class="col-md-4">
|
2019-11-16 17:53:58 +03:00
|
|
|
<div class="card bg-gradient-warning card-stats">
|
|
|
|
<div class="card-body">
|
|
|
|
<div class="row">
|
|
|
|
<div class="col">
|
2020-04-05 19:50:51 +03:00
|
|
|
<h5 class="text-uppercase text-white mb-0">{{ trans('general.unpaid') }}</h5>
|
|
|
|
<span class="font-weight-bold text-white mb-0">{{ $totals['unpaid'] }}</span>
|
2019-11-16 17:53:58 +03:00
|
|
|
</div>
|
2021-06-04 16:21:05 +03:00
|
|
|
|
2019-11-16 17:53:58 +03:00
|
|
|
<div class="col-auto">
|
|
|
|
<div class="icon icon-shape bg-white text-warning rounded-circle shadow">
|
|
|
|
<i class="fa fa-money-bill"></i>
|
2019-11-16 10:21:14 +03:00
|
|
|
</div>
|
2019-11-16 17:53:58 +03:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
2021-06-04 16:21:05 +03:00
|
|
|
|
2020-04-05 19:50:51 +03:00
|
|
|
<div class="card-footer">
|
|
|
|
<div class="progress progress-xs mb-0">
|
|
|
|
<div class="progress-bar bg-warning" role="progressbar" aria-valuenow="{{ $progress['unpaid'] }}" aria-valuemin="0" aria-valuemax="100" style="width: {{ $progress['unpaid'] }}%"></div>
|
2019-11-16 17:53:58 +03:00
|
|
|
</div>
|
2020-04-05 19:50:51 +03:00
|
|
|
</div>
|
2019-11-16 17:53:58 +03:00
|
|
|
</div>
|
|
|
|
</div>
|
2021-06-04 16:21:05 +03:00
|
|
|
|
2020-04-05 19:50:51 +03:00
|
|
|
<div class="col-md-4">
|
|
|
|
<div class="card bg-gradient-danger card-stats">
|
2019-11-16 17:53:58 +03:00
|
|
|
<div class="card-body">
|
|
|
|
<div class="row">
|
|
|
|
<div class="col">
|
2020-04-05 19:50:51 +03:00
|
|
|
<h5 class="text-uppercase text-white mb-0">{{ trans('general.overdue') }}</h5>
|
|
|
|
<span class="font-weight-bold text-white mb-0">{{ $totals['overdue'] }}</span>
|
2019-11-16 17:53:58 +03:00
|
|
|
</div>
|
2021-06-04 16:21:05 +03:00
|
|
|
|
2019-11-16 17:53:58 +03:00
|
|
|
<div class="col-auto">
|
2020-04-05 19:50:51 +03:00
|
|
|
<div class="icon icon-shape bg-white text-danger rounded-circle shadow">
|
2019-11-16 17:53:58 +03:00
|
|
|
<i class="fa fa-money-bill"></i>
|
2019-11-16 10:21:14 +03:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
2021-06-04 16:21:05 +03:00
|
|
|
|
2020-04-05 19:50:51 +03:00
|
|
|
<div class="card-footer">
|
|
|
|
<div class="progress progress-xs mb-0">
|
|
|
|
<div class="progress-bar bg-danger" role="progressbar" aria-valuenow="{{ $progress['overdue'] }}" aria-valuemin="0" aria-valuemax="100" style="width: {{ $progress['overdue'] }}%"></div>
|
2019-11-16 17:53:58 +03:00
|
|
|
</div>
|
2020-04-05 19:50:51 +03:00
|
|
|
</div>
|
2019-11-16 17:53:58 +03:00
|
|
|
</div>
|
|
|
|
</div>
|
2021-06-04 16:21:05 +03:00
|
|
|
|
2019-11-16 17:53:58 +03:00
|
|
|
<div class="col-md-12">
|
|
|
|
<div class="card">
|
|
|
|
<div class="card-header">
|
2020-01-02 13:08:50 +03:00
|
|
|
<h4 class="mb-0">{{ trans('widgets.cash_flow') }}</h4>
|
2019-11-16 17:53:58 +03:00
|
|
|
</div>
|
2020-01-15 19:45:09 +03:00
|
|
|
<div class="card-body" id="chart">
|
2019-11-16 10:21:14 +03:00
|
|
|
{!! $chart->container() !!}
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
@endsection
|
|
|
|
|
|
|
|
@push('body_js')
|
|
|
|
{!! $chart->script() !!}
|
2019-11-16 17:53:58 +03:00
|
|
|
@endpush
|
2020-01-02 13:08:50 +03:00
|
|
|
|
|
|
|
@push('scripts_start')
|
|
|
|
<script src="{{ asset('public/js/portal/dashboard.js?v=' . version('short')) }}"></script>
|
|
|
|
@endpush
|