From 8262e409422c5fd5591d6224bfaa14fb198cf08b Mon Sep 17 00:00:00 2001 From: Hillel Coren Date: Mon, 15 Aug 2016 06:46:47 +0300 Subject: [PATCH] Working on dashboard API --- .../Controllers/DashboardApiController.php | 190 +++-------------- app/Http/Controllers/DashboardController.php | 190 ++--------------- .../Repositories/DashboardRepository.php | 196 ++++++++++++++++++ 3 files changed, 248 insertions(+), 328 deletions(-) create mode 100644 app/Ninja/Repositories/DashboardRepository.php diff --git a/app/Http/Controllers/DashboardApiController.php b/app/Http/Controllers/DashboardApiController.php index c97f1408b07e..bfa1ce4a006f 100644 --- a/app/Http/Controllers/DashboardApiController.php +++ b/app/Http/Controllers/DashboardApiController.php @@ -2,155 +2,31 @@ use Auth; use DB; +use App\Ninja\Repositories\DashboardRepository; class DashboardApiController extends BaseAPIController { + public function __construct(DashboardRepository $dashboardRepo) + { + $this->dashboardRepo = $dashboardRepo; + } + public function index() { - $view_all = Auth::user()->hasPermission('view_all'); - $user_id = Auth::user()->id; + $user = Auth::user(); + $viewAll = $user->hasPermission('view_all'); + $userId = $user->id; + $accountId = $user->account->id; - // total_income, billed_clients, invoice_sent and active_clients - $select = DB::raw('COUNT(DISTINCT CASE WHEN invoices.id IS NOT NULL THEN clients.id ELSE null END) billed_clients, - SUM(CASE WHEN invoices.invoice_status_id >= '.INVOICE_STATUS_SENT.' THEN 1 ELSE 0 END) invoices_sent, - COUNT(DISTINCT clients.id) active_clients'); - $metrics = DB::table('accounts') - ->select($select) - ->leftJoin('clients', 'accounts.id', '=', 'clients.account_id') - ->leftJoin('invoices', 'clients.id', '=', 'invoices.client_id') - ->where('accounts.id', '=', Auth::user()->account_id) - ->where('clients.is_deleted', '=', false) - ->where('invoices.is_deleted', '=', false) - ->where('invoices.is_recurring', '=', false) - ->where('invoices.invoice_type_id', '=', false); - - if(!$view_all){ - $metrics = $metrics->where(function($query) use($user_id){ - $query->where('invoices.user_id', '=', $user_id); - $query->orwhere(function($query) use($user_id){ - $query->where('invoices.user_id', '=', null); - $query->where('clients.user_id', '=', $user_id); - }); - }); - } - - $metrics = $metrics->groupBy('accounts.id') - ->first(); - - $select = DB::raw('SUM(clients.paid_to_date) as value, clients.currency_id as currency_id'); - $paidToDate = DB::table('accounts') - ->select($select) - ->leftJoin('clients', 'accounts.id', '=', 'clients.account_id') - ->where('accounts.id', '=', Auth::user()->account_id) - ->where('clients.is_deleted', '=', false); - - if(!$view_all){ - $paidToDate = $paidToDate->where('clients.user_id', '=', $user_id); - } - - $paidToDate = $paidToDate->groupBy('accounts.id') - ->groupBy(DB::raw('CASE WHEN clients.currency_id IS NULL THEN CASE WHEN accounts.currency_id IS NULL THEN 1 ELSE accounts.currency_id END ELSE clients.currency_id END')) - ->get(); - - $select = DB::raw('AVG(invoices.amount) as invoice_avg, clients.currency_id as currency_id'); - $averageInvoice = DB::table('accounts') - ->select($select) - ->leftJoin('clients', 'accounts.id', '=', 'clients.account_id') - ->leftJoin('invoices', 'clients.id', '=', 'invoices.client_id') - ->where('accounts.id', '=', Auth::user()->account_id) - ->where('clients.is_deleted', '=', false) - ->where('invoices.is_deleted', '=', false) - ->where('invoices.invoice_type_id', '=', INVOICE_TYPE_STANDARD) - ->where('invoices.is_recurring', '=', false); - - if(!$view_all){ - $averageInvoice = $averageInvoice->where('invoices.user_id', '=', $user_id); - } - - $averageInvoice = $averageInvoice->groupBy('accounts.id') - ->groupBy(DB::raw('CASE WHEN clients.currency_id IS NULL THEN CASE WHEN accounts.currency_id IS NULL THEN 1 ELSE accounts.currency_id END ELSE clients.currency_id END')) - ->get(); - - $select = DB::raw('SUM(clients.balance) as value, clients.currency_id as currency_id'); - $balances = DB::table('accounts') - ->select($select) - ->leftJoin('clients', 'accounts.id', '=', 'clients.account_id') - ->where('accounts.id', '=', Auth::user()->account_id) - ->where('clients.is_deleted', '=', false) - ->groupBy('accounts.id') - ->groupBy(DB::raw('CASE WHEN clients.currency_id IS NULL THEN CASE WHEN accounts.currency_id IS NULL THEN 1 ELSE accounts.currency_id END ELSE clients.currency_id END')); - - if (!$view_all) { - $balances->where('clients.user_id', '=', $user_id); - } - - $balances = $balances->get(); - - $pastDue = DB::table('invoices') - ->leftJoin('clients', 'clients.id', '=', 'invoices.client_id') - ->leftJoin('contacts', 'contacts.client_id', '=', 'clients.id') - ->where('invoices.account_id', '=', Auth::user()->account_id) - ->where('clients.deleted_at', '=', null) - ->where('contacts.deleted_at', '=', null) - ->where('invoices.is_recurring', '=', false) - //->where('invoices.is_quote', '=', false) - ->where('invoices.balance', '>', 0) - ->where('invoices.is_deleted', '=', false) - ->where('invoices.deleted_at', '=', null) - ->where('contacts.is_primary', '=', true) - ->where('invoices.due_date', '<', date('Y-m-d')); - - if(!$view_all){ - $pastDue = $pastDue->where('invoices.user_id', '=', $user_id); - } - - $pastDue = $pastDue->select(['invoices.due_date', 'invoices.balance', 'invoices.public_id', 'invoices.invoice_number', 'clients.name as client_name', 'contacts.email', 'contacts.first_name', 'contacts.last_name', 'clients.currency_id', 'clients.public_id as client_public_id', 'clients.user_id as client_user_id', 'invoice_type_id']) - ->orderBy('invoices.due_date', 'asc') - ->take(50) - ->get(); - - $upcoming = DB::table('invoices') - ->leftJoin('clients', 'clients.id', '=', 'invoices.client_id') - ->leftJoin('contacts', 'contacts.client_id', '=', 'clients.id') - ->where('invoices.account_id', '=', Auth::user()->account_id) - ->where('clients.deleted_at', '=', null) - ->where('contacts.deleted_at', '=', null) - ->where('invoices.deleted_at', '=', null) - ->where('invoices.is_recurring', '=', false) - //->where('invoices.is_quote', '=', false) - ->where('invoices.balance', '>', 0) - ->where('invoices.is_deleted', '=', false) - ->where('contacts.is_primary', '=', true) - ->where('invoices.due_date', '>=', date('Y-m-d')) - ->orderBy('invoices.due_date', 'asc'); - - if(!$view_all){ - $upcoming = $upcoming->where('invoices.user_id', '=', $user_id); - } - - $upcoming = $upcoming->take(50) - ->select(['invoices.due_date', 'invoices.balance', 'invoices.public_id', 'invoices.invoice_number', 'clients.name as client_name', 'contacts.email', 'contacts.first_name', 'contacts.last_name', 'clients.currency_id', 'clients.public_id as client_public_id', 'clients.user_id as client_user_id', 'invoice_type_id']) - ->get(); - - $payments = DB::table('payments') - ->leftJoin('clients', 'clients.id', '=', 'payments.client_id') - ->leftJoin('contacts', 'contacts.client_id', '=', 'clients.id') - ->leftJoin('invoices', 'invoices.id', '=', 'payments.invoice_id') - ->where('payments.account_id', '=', Auth::user()->account_id) - ->where('payments.is_deleted', '=', false) - ->where('invoices.is_deleted', '=', false) - ->where('clients.is_deleted', '=', false) - ->where('contacts.deleted_at', '=', null) - ->where('contacts.is_primary', '=', true); - - if(!$view_all){ - $payments = $payments->where('payments.user_id', '=', $user_id); - } - - $payments = $payments->select(['payments.payment_date', 'payments.amount', 'invoices.public_id', 'invoices.invoice_number', 'clients.name as client_name', 'contacts.email', 'contacts.first_name', 'contacts.last_name', 'clients.currency_id', 'clients.public_id as client_public_id', 'clients.user_id as client_user_id']) - ->orderBy('payments.payment_date', 'desc') - ->take(50) - ->get(); + $dashboardRepo = $this->dashboardRepo; + $metrics = $dashboardRepo->totals($accountId, $userId, $viewAll); + $paidToDate = $dashboardRepo->paidToDate($accountId, $userId, $viewAll); + $averageInvoice = $dashboardRepo->averages($accountId, $userId, $viewAll); + $balances = $dashboardRepo->balances($accountId, $userId, $viewAll); + $activities = $dashboardRepo->activities($accountId, $userId, $viewAll); + $pastDue = $dashboardRepo->pastDue($accountId, $userId, $viewAll); + $upcoming = $dashboardRepo->upcoming($accountId, $userId, $viewAll); + $payments = $dashboardRepo->payments($accountId, $userId, $viewAll); $hasQuotes = false; foreach ([$upcoming, $pastDue] as $data) { @@ -160,22 +36,20 @@ class DashboardApiController extends BaseAPIController } } } - + $data = [ - 'id' => 1, - 'paidToDate' => $paidToDate[0]->value ? $paidToDate[0]->value : 0, - 'paidToDateCurrency' => $paidToDate[0]->currency_id ? $paidToDate[0]->currency_id : 0, - 'balances' => $balances[0]->value ? $balances[0]->value : 0, - 'balancesCurrency' => $balances[0]->currency_id ? $balances[0]->currency_id : 0, - 'averageInvoice' => $averageInvoice[0]->invoice_avg ? $averageInvoice[0]->invoice_avg : 0, - 'averageInvoiceCurrency' => $averageInvoice[0]->currency_id ? $averageInvoice[0]->currency_id : 0, - 'invoicesSent' => $metrics ? $metrics->invoices_sent : 0, - 'activeClients' => $metrics ? $metrics->active_clients : 0, - ]; - - - - return $this->response($data); + 'id' => 1, + 'paidToDate' => $paidToDate[0]->value ? $paidToDate[0]->value : 0, + 'paidToDateCurrency' => $paidToDate[0]->currency_id ? $paidToDate[0]->currency_id : 0, + 'balances' => $balances[0]->value ? $balances[0]->value : 0, + 'balancesCurrency' => $balances[0]->currency_id ? $balances[0]->currency_id : 0, + 'averageInvoice' => $averageInvoice[0]->invoice_avg ? $averageInvoice[0]->invoice_avg : 0, + 'averageInvoiceCurrency' => $averageInvoice[0]->currency_id ? $averageInvoice[0]->currency_id : 0, + 'invoicesSent' => $metrics ? $metrics->invoices_sent : 0, + 'activeClients' => $metrics ? $metrics->active_clients : 0, + //'activities' => $activities, + ]; + return $this->response($data); } } diff --git a/app/Http/Controllers/DashboardController.php b/app/Http/Controllers/DashboardController.php index 209e88b0c0dc..7da13c04aaef 100644 --- a/app/Http/Controllers/DashboardController.php +++ b/app/Http/Controllers/DashboardController.php @@ -3,189 +3,39 @@ use Auth; use DB; use View; -use App\Models\Activity; use App\Models\Invoice; use App\Models\Payment; +use App\Ninja\Repositories\DashboardRepository; /** * Class DashboardController */ class DashboardController extends BaseController { + public function __construct(DashboardRepository $dashboardRepo) + { + $this->dashboardRepo = $dashboardRepo; + } + /** * @return \Illuminate\Contracts\View\View */ public function index() { - $view_all = Auth::user()->hasPermission('view_all'); - $user_id = Auth::user()->id; + $user = Auth::user(); + $viewAll = $user->hasPermission('view_all'); + $userId = $user->id; + $accountId = $user->account->id; - // total_income, billed_clients, invoice_sent and active_clients - $select = DB::raw( - 'COUNT(DISTINCT CASE WHEN '.DB::getQueryGrammar()->wrap('invoices.id', true).' IS NOT NULL THEN '.DB::getQueryGrammar()->wrap('clients.id', true).' ELSE null END) billed_clients, - SUM(CASE WHEN '.DB::getQueryGrammar()->wrap('invoices.invoice_status_id', true).' >= '.INVOICE_STATUS_SENT.' THEN 1 ELSE 0 END) invoices_sent, - COUNT(DISTINCT '.DB::getQueryGrammar()->wrap('clients.id', true).') active_clients' - ); - $metrics = DB::table('accounts') - ->select($select) - ->leftJoin('clients', 'accounts.id', '=', 'clients.account_id') - ->leftJoin('invoices', 'clients.id', '=', 'invoices.client_id') - ->where('accounts.id', '=', Auth::user()->account_id) - ->where('clients.is_deleted', '=', false) - ->where('invoices.is_deleted', '=', false) - ->where('invoices.is_recurring', '=', false) - ->where('invoices.invoice_type_id', '=', INVOICE_TYPE_STANDARD); - - if(!$view_all){ - $metrics = $metrics->where(function($query) use($user_id){ - $query->where('invoices.user_id', '=', $user_id); - $query->orwhere(function($query) use($user_id){ - $query->where('invoices.user_id', '=', null); - $query->where('clients.user_id', '=', $user_id); - }); - }); - } - - $metrics = $metrics->groupBy('accounts.id') - ->first(); - - $select = DB::raw( - 'SUM('.DB::getQueryGrammar()->wrap('clients.paid_to_date', true).') as value,' - .DB::getQueryGrammar()->wrap('clients.currency_id', true).' as currency_id' - ); - $paidToDate = DB::table('accounts') - ->select($select) - ->leftJoin('clients', 'accounts.id', '=', 'clients.account_id') - ->where('accounts.id', '=', Auth::user()->account_id) - ->where('clients.is_deleted', '=', false); - - if(!$view_all){ - $paidToDate = $paidToDate->where('clients.user_id', '=', $user_id); - } - - $paidToDate = $paidToDate->groupBy('accounts.id') - ->groupBy(DB::raw('CASE WHEN '.DB::getQueryGrammar()->wrap('clients.currency_id', true).' IS NULL THEN CASE WHEN '.DB::getQueryGrammar()->wrap('accounts.currency_id', true).' IS NULL THEN 1 ELSE '.DB::getQueryGrammar()->wrap('accounts.currency_id', true).' END ELSE '.DB::getQueryGrammar()->wrap('clients.currency_id', true).' END')) - ->get(); - - $select = DB::raw( - 'AVG('.DB::getQueryGrammar()->wrap('invoices.amount', true).') as invoice_avg, ' - .DB::getQueryGrammar()->wrap('clients.currency_id', true).' as currency_id' - ); - $averageInvoice = DB::table('accounts') - ->select($select) - ->leftJoin('clients', 'accounts.id', '=', 'clients.account_id') - ->leftJoin('invoices', 'clients.id', '=', 'invoices.client_id') - ->where('accounts.id', '=', Auth::user()->account_id) - ->where('clients.is_deleted', '=', false) - ->where('invoices.is_deleted', '=', false) - ->where('invoices.invoice_type_id', '=', INVOICE_TYPE_STANDARD) - ->where('invoices.is_recurring', '=', false); - - if(!$view_all){ - $averageInvoice = $averageInvoice->where('invoices.user_id', '=', $user_id); - } - - $averageInvoice = $averageInvoice->groupBy('accounts.id') - ->groupBy(DB::raw('CASE WHEN '.DB::getQueryGrammar()->wrap('clients.currency_id', true).' IS NULL THEN CASE WHEN '.DB::getQueryGrammar()->wrap('accounts.currency_id', true).' IS NULL THEN 1 ELSE '.DB::getQueryGrammar()->wrap('accounts.currency_id', true).' END ELSE '.DB::getQueryGrammar()->wrap('clients.currency_id', true).' END')) - ->get(); - - $select = DB::raw( - 'SUM('.DB::getQueryGrammar()->wrap('clients.balance', true).') as value, ' - .DB::getQueryGrammar()->wrap('clients.currency_id', true).' as currency_id' - ); - $balances = DB::table('accounts') - ->select($select) - ->leftJoin('clients', 'accounts.id', '=', 'clients.account_id') - ->where('accounts.id', '=', Auth::user()->account_id) - ->where('clients.is_deleted', '=', false) - ->groupBy('accounts.id') - ->groupBy(DB::raw('CASE WHEN '.DB::getQueryGrammar()->wrap('clients.currency_id', true).' IS NULL THEN CASE WHEN '.DB::getQueryGrammar()->wrap('accounts.currency_id', true).' IS NULL THEN 1 ELSE '.DB::getQueryGrammar()->wrap('accounts.currency_id', true).' END ELSE '.DB::getQueryGrammar()->wrap('clients.currency_id', true).' END')); - - if (!$view_all) { - $balances->where('clients.user_id', '=', $user_id); - } - - $balances = $balances->get(); - - $activities = Activity::where('activities.account_id', '=', Auth::user()->account_id) - ->where('activities.activity_type_id', '>', 0); - - if(!$view_all){ - $activities = $activities->where('activities.user_id', '=', $user_id); - } - - $activities = $activities->orderBy('activities.created_at', 'desc') - ->with('client.contacts', 'user', 'invoice', 'payment', 'credit', 'account') - ->take(50) - ->get(); - - $pastDue = DB::table('invoices') - ->leftJoin('clients', 'clients.id', '=', 'invoices.client_id') - ->leftJoin('contacts', 'contacts.client_id', '=', 'clients.id') - ->where('invoices.account_id', '=', Auth::user()->account_id) - ->where('clients.deleted_at', '=', null) - ->where('contacts.deleted_at', '=', null) - ->where('invoices.is_recurring', '=', false) - //->where('invoices.is_quote', '=', false) - ->where('invoices.quote_invoice_id', '=', null) - ->where('invoices.balance', '>', 0) - ->where('invoices.is_deleted', '=', false) - ->where('invoices.deleted_at', '=', null) - ->where('contacts.is_primary', '=', true) - ->where('invoices.due_date', '<', date('Y-m-d')); - - if(!$view_all){ - $pastDue = $pastDue->where('invoices.user_id', '=', $user_id); - } - - $pastDue = $pastDue->select(['invoices.due_date', 'invoices.balance', 'invoices.public_id', 'invoices.invoice_number', 'clients.name as client_name', 'contacts.email', 'contacts.first_name', 'contacts.last_name', 'clients.currency_id', 'clients.public_id as client_public_id', 'clients.user_id as client_user_id', 'invoice_type_id']) - ->orderBy('invoices.due_date', 'asc') - ->take(50) - ->get(); - - $upcoming = DB::table('invoices') - ->leftJoin('clients', 'clients.id', '=', 'invoices.client_id') - ->leftJoin('contacts', 'contacts.client_id', '=', 'clients.id') - ->where('invoices.account_id', '=', Auth::user()->account_id) - ->where('clients.deleted_at', '=', null) - ->where('contacts.deleted_at', '=', null) - ->where('invoices.deleted_at', '=', null) - ->where('invoices.is_recurring', '=', false) - //->where('invoices.is_quote', '=', false) - ->where('invoices.quote_invoice_id', '=', null) - ->where('invoices.balance', '>', 0) - ->where('invoices.is_deleted', '=', false) - ->where('contacts.is_primary', '=', true) - ->where('invoices.due_date', '>=', date('Y-m-d')) - ->orderBy('invoices.due_date', 'asc'); - - if(!$view_all){ - $upcoming = $upcoming->where('invoices.user_id', '=', $user_id); - } - - $upcoming = $upcoming->take(50) - ->select(['invoices.due_date', 'invoices.balance', 'invoices.public_id', 'invoices.invoice_number', 'clients.name as client_name', 'contacts.email', 'contacts.first_name', 'contacts.last_name', 'clients.currency_id', 'clients.public_id as client_public_id', 'clients.user_id as client_user_id', 'invoice_type_id']) - ->get(); - - $payments = DB::table('payments') - ->leftJoin('clients', 'clients.id', '=', 'payments.client_id') - ->leftJoin('contacts', 'contacts.client_id', '=', 'clients.id') - ->leftJoin('invoices', 'invoices.id', '=', 'payments.invoice_id') - ->where('payments.account_id', '=', Auth::user()->account_id) - ->where('payments.is_deleted', '=', false) - ->where('invoices.is_deleted', '=', false) - ->where('clients.is_deleted', '=', false) - ->where('contacts.deleted_at', '=', null) - ->where('contacts.is_primary', '=', true); - - if(!$view_all){ - $payments = $payments->where('payments.user_id', '=', $user_id); - } - - $payments = $payments->select(['payments.payment_date', 'payments.amount', 'invoices.public_id', 'invoices.invoice_number', 'clients.name as client_name', 'contacts.email', 'contacts.first_name', 'contacts.last_name', 'clients.currency_id', 'clients.public_id as client_public_id', 'clients.user_id as client_user_id']) - ->orderBy('payments.payment_date', 'desc') - ->take(50) - ->get(); + $dashboardRepo = $this->dashboardRepo; + $metrics = $dashboardRepo->totals($accountId, $userId, $viewAll); + $paidToDate = $dashboardRepo->paidToDate($accountId, $userId, $viewAll); + $averageInvoice = $dashboardRepo->averages($accountId, $userId, $viewAll); + $balances = $dashboardRepo->balances($accountId, $userId, $viewAll); + $activities = $dashboardRepo->activities($accountId, $userId, $viewAll); + $pastDue = $dashboardRepo->pastDue($accountId, $userId, $viewAll); + $upcoming = $dashboardRepo->upcoming($accountId, $userId, $viewAll); + $payments = $dashboardRepo->payments($accountId, $userId, $viewAll); $hasQuotes = false; foreach ([$upcoming, $pastDue] as $data) { @@ -197,7 +47,7 @@ class DashboardController extends BaseController } $data = [ - 'account' => Auth::user()->account, + 'account' => $user->account, 'paidToDate' => $paidToDate, 'balances' => $balances, 'averageInvoice' => $averageInvoice, diff --git a/app/Ninja/Repositories/DashboardRepository.php b/app/Ninja/Repositories/DashboardRepository.php new file mode 100644 index 000000000000..47046ffc091d --- /dev/null +++ b/app/Ninja/Repositories/DashboardRepository.php @@ -0,0 +1,196 @@ +wrap('invoices.id', true).' IS NOT NULL THEN '.DB::getQueryGrammar()->wrap('clients.id', true).' ELSE null END) billed_clients, + SUM(CASE WHEN '.DB::getQueryGrammar()->wrap('invoices.invoice_status_id', true).' >= '.INVOICE_STATUS_SENT.' THEN 1 ELSE 0 END) invoices_sent, + COUNT(DISTINCT '.DB::getQueryGrammar()->wrap('clients.id', true).') active_clients' + ); + + $metrics = DB::table('accounts') + ->select($select) + ->leftJoin('clients', 'accounts.id', '=', 'clients.account_id') + ->leftJoin('invoices', 'clients.id', '=', 'invoices.client_id') + ->where('accounts.id', '=', $accountId) + ->where('clients.is_deleted', '=', false) + ->where('invoices.is_deleted', '=', false) + ->where('invoices.is_recurring', '=', false) + ->where('invoices.invoice_type_id', '=', INVOICE_TYPE_STANDARD); + + if (!$viewAll){ + $metrics = $metrics->where(function($query) use($userId){ + $query->where('invoices.user_id', '=', $userId); + $query->orwhere(function($query) use($userId){ + $query->where('invoices.user_id', '=', null); + $query->where('clients.user_id', '=', $userId); + }); + }); + } + + return $metrics->groupBy('accounts.id')->first(); + } + + public function paidToDate($accountId, $userId, $viewAll) + { + $select = DB::raw( + 'SUM('.DB::getQueryGrammar()->wrap('clients.paid_to_date', true).') as value,' + .DB::getQueryGrammar()->wrap('clients.currency_id', true).' as currency_id' + ); + $paidToDate = DB::table('accounts') + ->select($select) + ->leftJoin('clients', 'accounts.id', '=', 'clients.account_id') + ->where('accounts.id', '=', $accountId) + ->where('clients.is_deleted', '=', false); + + if (!$viewAll){ + $paidToDate = $paidToDate->where('clients.user_id', '=', $userId); + } + + return $paidToDate->groupBy('accounts.id') + ->groupBy(DB::raw('CASE WHEN '.DB::getQueryGrammar()->wrap('clients.currency_id', true).' IS NULL THEN CASE WHEN '.DB::getQueryGrammar()->wrap('accounts.currency_id', true).' IS NULL THEN 1 ELSE '.DB::getQueryGrammar()->wrap('accounts.currency_id', true).' END ELSE '.DB::getQueryGrammar()->wrap('clients.currency_id', true).' END')) + ->get(); + } + + public function averages($accountId, $userId, $viewAll) + { + $select = DB::raw( + 'AVG('.DB::getQueryGrammar()->wrap('invoices.amount', true).') as invoice_avg, ' + .DB::getQueryGrammar()->wrap('clients.currency_id', true).' as currency_id' + ); + $averageInvoice = DB::table('accounts') + ->select($select) + ->leftJoin('clients', 'accounts.id', '=', 'clients.account_id') + ->leftJoin('invoices', 'clients.id', '=', 'invoices.client_id') + ->where('accounts.id', '=', $accountId) + ->where('clients.is_deleted', '=', false) + ->where('invoices.is_deleted', '=', false) + ->where('invoices.invoice_type_id', '=', INVOICE_TYPE_STANDARD) + ->where('invoices.is_recurring', '=', false); + + if (!$viewAll){ + $averageInvoice = $averageInvoice->where('invoices.user_id', '=', $userId); + } + + return $averageInvoice->groupBy('accounts.id') + ->groupBy(DB::raw('CASE WHEN '.DB::getQueryGrammar()->wrap('clients.currency_id', true).' IS NULL THEN CASE WHEN '.DB::getQueryGrammar()->wrap('accounts.currency_id', true).' IS NULL THEN 1 ELSE '.DB::getQueryGrammar()->wrap('accounts.currency_id', true).' END ELSE '.DB::getQueryGrammar()->wrap('clients.currency_id', true).' END')) + ->get(); + } + + public function balances($accountId, $userId, $viewAll) + { + $select = DB::raw( + 'SUM('.DB::getQueryGrammar()->wrap('clients.balance', true).') as value, ' + .DB::getQueryGrammar()->wrap('clients.currency_id', true).' as currency_id' + ); + $balances = DB::table('accounts') + ->select($select) + ->leftJoin('clients', 'accounts.id', '=', 'clients.account_id') + ->where('accounts.id', '=', $accountId) + ->where('clients.is_deleted', '=', false) + ->groupBy('accounts.id') + ->groupBy(DB::raw('CASE WHEN '.DB::getQueryGrammar()->wrap('clients.currency_id', true).' IS NULL THEN CASE WHEN '.DB::getQueryGrammar()->wrap('accounts.currency_id', true).' IS NULL THEN 1 ELSE '.DB::getQueryGrammar()->wrap('accounts.currency_id', true).' END ELSE '.DB::getQueryGrammar()->wrap('clients.currency_id', true).' END')); + + if (!$viewAll) { + $balances->where('clients.user_id', '=', $userId); + } + + return $balances->get(); + } + + public function activities($accountId, $userId, $viewAll) + { + $activities = Activity::where('activities.account_id', '=', $accountId) + ->where('activities.activity_type_id', '>', 0); + + if (!$viewAll){ + $activities = $activities->where('activities.user_id', '=', $userId); + } + + return $activities->orderBy('activities.created_at', 'desc') + ->with('client.contacts', 'user', 'invoice', 'payment', 'credit', 'account') + ->take(50) + ->get(); + } + + public function pastDue($accountId, $userId, $viewAll) + { + $pastDue = DB::table('invoices') + ->leftJoin('clients', 'clients.id', '=', 'invoices.client_id') + ->leftJoin('contacts', 'contacts.client_id', '=', 'clients.id') + ->where('invoices.account_id', '=', $accountId) + ->where('clients.deleted_at', '=', null) + ->where('contacts.deleted_at', '=', null) + ->where('invoices.is_recurring', '=', false) + ->where('invoices.quote_invoice_id', '=', null) + ->where('invoices.balance', '>', 0) + ->where('invoices.is_deleted', '=', false) + ->where('invoices.deleted_at', '=', null) + ->where('contacts.is_primary', '=', true) + ->where('invoices.due_date', '<', date('Y-m-d')); + + if (!$viewAll){ + $pastDue = $pastDue->where('invoices.user_id', '=', $userId); + } + + return $pastDue->select(['invoices.due_date', 'invoices.balance', 'invoices.public_id', 'invoices.invoice_number', 'clients.name as client_name', 'contacts.email', 'contacts.first_name', 'contacts.last_name', 'clients.currency_id', 'clients.public_id as client_public_id', 'clients.user_id as client_user_id', 'invoice_type_id']) + ->orderBy('invoices.due_date', 'asc') + ->take(50) + ->get(); + } + + public function upcoming($accountId, $userId, $viewAll) + { + $upcoming = DB::table('invoices') + ->leftJoin('clients', 'clients.id', '=', 'invoices.client_id') + ->leftJoin('contacts', 'contacts.client_id', '=', 'clients.id') + ->where('invoices.account_id', '=', $accountId) + ->where('clients.deleted_at', '=', null) + ->where('contacts.deleted_at', '=', null) + ->where('invoices.deleted_at', '=', null) + ->where('invoices.is_recurring', '=', false) + ->where('invoices.quote_invoice_id', '=', null) + ->where('invoices.balance', '>', 0) + ->where('invoices.is_deleted', '=', false) + ->where('contacts.is_primary', '=', true) + ->where('invoices.due_date', '>=', date('Y-m-d')) + ->orderBy('invoices.due_date', 'asc'); + + if (!$viewAll){ + $upcoming = $upcoming->where('invoices.user_id', '=', $userId); + } + + return $upcoming->take(50) + ->select(['invoices.due_date', 'invoices.balance', 'invoices.public_id', 'invoices.invoice_number', 'clients.name as client_name', 'contacts.email', 'contacts.first_name', 'contacts.last_name', 'clients.currency_id', 'clients.public_id as client_public_id', 'clients.user_id as client_user_id', 'invoice_type_id']) + ->get(); + } + + public function payments($accountId, $userId, $viewAll) + { + $payments = DB::table('payments') + ->leftJoin('clients', 'clients.id', '=', 'payments.client_id') + ->leftJoin('contacts', 'contacts.client_id', '=', 'clients.id') + ->leftJoin('invoices', 'invoices.id', '=', 'payments.invoice_id') + ->where('payments.account_id', '=', $accountId) + ->where('payments.is_deleted', '=', false) + ->where('invoices.is_deleted', '=', false) + ->where('clients.is_deleted', '=', false) + ->where('contacts.deleted_at', '=', null) + ->where('contacts.is_primary', '=', true); + + if (!$viewAll){ + $payments = $payments->where('payments.user_id', '=', $userId); + } + + return $payments->select(['payments.payment_date', 'payments.amount', 'invoices.public_id', 'invoices.invoice_number', 'clients.name as client_name', 'contacts.email', 'contacts.first_name', 'contacts.last_name', 'clients.currency_id', 'clients.public_id as client_public_id', 'clients.user_id as client_user_id']) + ->orderBy('payments.payment_date', 'desc') + ->take(50) + ->get(); + } +}