lk.zachem.info/app/Modules/Contracts/Http/Livewire/ContractsTableLivewire.php

97 lines
2.5 KiB
PHP

<?php
namespace Modules\Contracts\Http\Livewire;
use Livewire\Component;
use Modules\Main\Models\Agent\Agent;
use Modules\Contracts\Models\Contract;
use Modules\Contracts\Models\ContractStatus;
use Modules\User\Models\UserRole;
use Modules\User\Models\Role;
use Modules\Main\Models\Company\CompanyAdmin;
class ContractsTableLivewire extends Component
{
public $mode = false;
public $filter = [];
public function mount()
{
}
function getSelectingAgents()
{
if (
$userRole =
UserRole::where('user_id', auth()->id())
->where('role_id', Role::COMPANY_ADMIN)
->count() == 1
)
{
$companyAdmin = CompanyAdmin::where('user_id', auth()->id())->first();
return $agentsIds = Agent::where('company_id', $companyAdmin->company_id)->pluck('id');
}
else
{
$agent = Agent::where('user_id', auth()->id())->first();
return [$agent->id];
}
}
private function getContracts()
{
$contracts = Contract::whereHas('deal', function ($dealSubQuery)
{
$dealSubQuery->with('deals')
->whereIn('agent_id', $this->getSelectingAgents());
});
$this->appendMode($contracts);
$this->appendFilter($contracts);
return $contracts->get();
}
private function appendMode(&$query)
{
if ($this->mode == 'active')
{
$query->whereIn('status', [
ContractStatus::NEW ,
ContractStatus::RESERVATION,
ContractStatus::SUCCESS,
]);
}
if ($this->mode == 'successed')
{
$query->whereIn('status', [
ContractStatus::SUCCESS,
ContractStatus::TREATY
]);
}
if ($this->mode == 'declined')
{
$query->whereIn('status', [
ContractStatus::DECLINE
]);
}
}
private function appendFilter(&$query)
{
foreach ($this->filter as $fKey => $fValue)
{
if (is_array($fValue))
{
$query->whereIn($fKey, $fValue);
}
else
{
$query->where($fKey, $fValue);
}
}
}
public function render()
{
return view('contracts::livewire.table.index', [
'contracts' => $this->getContracts(),
'statuses' => ContractStatus::class
]);
}
}