ba8a819c7d
- flight ident now use this format: VA IATA(if empty ICAO) + Flight Number + - + Flight Code (without C) + - + Flight Leg (without L) - added function __trans_choice in helpers.php for translation - fixed error in flight edit/insert panel not showing/inserting Tuesday in days - fixed an error occurring when metar retrieved is empty - edited now-ui-kit.css to align login fields correctly - added /public/assets/frontend/js/core/jquery-3.3.1.min.js to fix a missed resource error in authentication pages - added translations file for en and it locales - translated all the frontend templates
97 lines
2.9 KiB
PHP
97 lines
2.9 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers\Admin;
|
|
|
|
use App\Interfaces\Controller;
|
|
use App\Models\Enums\JournalType;
|
|
use App\Models\Journal;
|
|
use App\Models\JournalTransaction;
|
|
use App\Repositories\AirlineRepository;
|
|
use App\Support\Dates;
|
|
use App\Support\Money;
|
|
use Illuminate\Http\Request;
|
|
|
|
/**
|
|
* Class FinanceController
|
|
* @package App\Http\Controllers\Admin
|
|
*/
|
|
class FinanceController extends Controller
|
|
{
|
|
private $airlineRepo;
|
|
|
|
/**
|
|
* @param AirlineRepository $airlineRepo
|
|
*/
|
|
public function __construct(
|
|
AirlineRepository $airlineRepo
|
|
) {
|
|
$this->airlineRepo = $airlineRepo;
|
|
}
|
|
|
|
/**
|
|
* Display the summation tables for a given month by airline
|
|
* @param Request $request
|
|
* @return mixed
|
|
* @throws \UnexpectedValueException
|
|
* @throws \InvalidArgumentException
|
|
*/
|
|
public function index(Request $request)
|
|
{
|
|
$month = $request->query('month', date('Y-m'));
|
|
$between = Dates::getMonthBoundary($month);
|
|
|
|
$first_journal = Journal::where(['type' => JournalType::AIRLINE])
|
|
->orderBy('created_at', 'asc')
|
|
->limit(1)
|
|
->first();
|
|
|
|
$transaction_groups = [];
|
|
$airlines = $this->airlineRepo->orderBy('icao')->all();
|
|
|
|
# group by the airline
|
|
foreach ($airlines as $airline) {
|
|
# Return all the transactions, grouped by the transaction group
|
|
$transactions = JournalTransaction::groupBy('transaction_group', 'currency')
|
|
->selectRaw('transaction_group, currency,
|
|
SUM(credit) as sum_credits,
|
|
SUM(debit) as sum_debits')
|
|
->where([
|
|
'journal_id' => $airline->journal->id
|
|
])
|
|
->whereBetween('created_at', $between, 'AND')
|
|
->orderBy('sum_credits', 'desc')
|
|
->orderBy('sum_debits', 'desc')
|
|
->orderBy('transaction_group', 'asc')
|
|
->get();
|
|
|
|
# Summate it so we can show it on the footer of the table
|
|
$sum_all_credits = 0;
|
|
$sum_all_debits = 0;
|
|
foreach ($transactions as $ta) {
|
|
$sum_all_credits += $ta->sum_credits ?? 0;
|
|
$sum_all_debits += $ta->sum_debits ?? 0;
|
|
}
|
|
|
|
$transaction_groups[] = [
|
|
'airline' => $airline,
|
|
'credits' => new Money($sum_all_credits),
|
|
'debits' => new Money($sum_all_debits),
|
|
'transactions' => $transactions,
|
|
];
|
|
}
|
|
|
|
return view('admin.finances.index', [
|
|
'current_month' => $month,
|
|
'months_list' => Dates::getMonthsList($first_journal->created_at),
|
|
'transaction_groups' => $transaction_groups,
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* Show a month
|
|
*/
|
|
public function show($id)
|
|
{
|
|
}
|
|
}
|