🌱 🏗️ ⬆️ ✨add expense table 🎨 🔧
This commit is contained in:
@@ -10,32 +10,40 @@ use Inertia\Inertia;
|
||||
|
||||
class TransactionsController extends Controller
|
||||
{
|
||||
public $table = 'incomes';
|
||||
public $table = "incomes";
|
||||
|
||||
public function index(){
|
||||
|
||||
$query = $this->queryBuilder();
|
||||
$query = $this->queryBuilder("incomes");
|
||||
$data['incomes']['columns'] = collect($query->columns)->map(function($item){
|
||||
return ucfirst(substr($item, strrpos($item, '.')+1));
|
||||
});
|
||||
$data['incomes']['data'] = $query->get();
|
||||
|
||||
$query = $this->queryBuilder("expenses");
|
||||
$data['expenses']['columns'] = collect($query->columns)->map(function($item){
|
||||
return ucfirst(substr($item, strrpos($item, '.')+1));
|
||||
});
|
||||
$data['expenses']['data'] = $query->get();
|
||||
|
||||
|
||||
return Inertia::render('Transactions/index', $data);
|
||||
}
|
||||
|
||||
|
||||
private function queryBuilder(){
|
||||
$query = DB::table($this->table)
|
||||
private function queryBuilder($type){
|
||||
$query = DB::table($type)
|
||||
->select([
|
||||
// 'users.account',
|
||||
// 'users.role',
|
||||
// 'users.email',
|
||||
'incomes.amount',
|
||||
'incomes.description',
|
||||
'incomes.date',
|
||||
'type_incomes.label'
|
||||
$type.'.amount',
|
||||
$type.'.description',
|
||||
$type.'.date',
|
||||
'type_'.$type.'.label'
|
||||
])
|
||||
->join('users', 'users.id', 'incomes.id_user')
|
||||
->join('type_incomes', 'type_incomes.id', 'incomes.id_type_income')
|
||||
->join('users', 'users.id', $type.'.id_user')
|
||||
->join('type_'.$type, 'type_'.$type.'.id', $type.'.id_type_'.$type)
|
||||
;
|
||||
|
||||
return $query;
|
||||
|
||||
Reference in New Issue
Block a user