mirror of
				https://github.com/crater-invoice/crater.git
				synced 2025-11-03 14:03:18 -05:00 
			
		
		
		
	
		
			
				
	
	
		
			109 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			109 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
 | 
						|
namespace Crater\Http\Controllers\V1\Admin\Customer;
 | 
						|
 | 
						|
use Crater\Http\Controllers\Controller;
 | 
						|
use Crater\Http\Requests;
 | 
						|
use Crater\Http\Requests\DeleteCustomersRequest;
 | 
						|
use Crater\Http\Resources\CustomerResource;
 | 
						|
use Crater\Models\Customer;
 | 
						|
use Illuminate\Http\Request;
 | 
						|
use Illuminate\Support\Facades\DB;
 | 
						|
 | 
						|
class CustomersController extends Controller
 | 
						|
{
 | 
						|
    /**
 | 
						|
     * Display a listing of the resource.
 | 
						|
     *
 | 
						|
     * @return \Illuminate\Http\JsonResponse
 | 
						|
     */
 | 
						|
    public function index(Request $request)
 | 
						|
    {
 | 
						|
        $this->authorize('viewAny', Customer::class);
 | 
						|
 | 
						|
        $limit = $request->has('limit') ? $request->limit : 10;
 | 
						|
 | 
						|
        $customers = Customer::with('creator')
 | 
						|
            ->whereCompany()
 | 
						|
            ->applyFilters($request->all())
 | 
						|
            ->select(
 | 
						|
                'customers.*',
 | 
						|
                DB::raw('sum(invoices.base_due_amount) as base_due_amount'),
 | 
						|
                DB::raw('sum(invoices.due_amount) as due_amount'),
 | 
						|
            )
 | 
						|
            ->groupBy('customers.id')
 | 
						|
            ->leftJoin('invoices', 'customers.id', '=', 'invoices.customer_id')
 | 
						|
            ->paginateData($limit);
 | 
						|
 | 
						|
        return (CustomerResource::collection($customers))
 | 
						|
            ->additional(['meta' => [
 | 
						|
                'customer_total_count' => Customer::whereCompany()->count(),
 | 
						|
            ]]);
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Store a newly created resource in storage.
 | 
						|
     *
 | 
						|
     * @param  \Illuminate\Http\Request  $request
 | 
						|
     * @return \Illuminate\Http\JsonResponse
 | 
						|
     */
 | 
						|
    public function store(Requests\CustomerRequest $request)
 | 
						|
    {
 | 
						|
        $this->authorize('create', Customer::class);
 | 
						|
 | 
						|
        $customer = Customer::createCustomer($request);
 | 
						|
 | 
						|
        return new CustomerResource($customer);
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Display the specified resource.
 | 
						|
     *
 | 
						|
     * @param  Customer $customer
 | 
						|
     * @return \Illuminate\Http\JsonResponse
 | 
						|
     */
 | 
						|
    public function show(Customer $customer)
 | 
						|
    {
 | 
						|
        $this->authorize('view', $customer);
 | 
						|
 | 
						|
        return new CustomerResource($customer);
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Update the specified resource in storage.
 | 
						|
     *
 | 
						|
     * @param  \Illuminate\Http\Request $request
 | 
						|
     * @param  \Crater\Models\Customer $customer
 | 
						|
     * @return \Illuminate\Http\JsonResponse
 | 
						|
     */
 | 
						|
    public function update(Requests\CustomerRequest $request, Customer $customer)
 | 
						|
    {
 | 
						|
        $this->authorize('update', $customer);
 | 
						|
 | 
						|
        $customer = Customer::updateCustomer($request, $customer);
 | 
						|
 | 
						|
        if (is_string($customer)) {
 | 
						|
            return respondJson('you_cannot_edit_currency', 'Cannot change currency once transactions created');
 | 
						|
        }
 | 
						|
 | 
						|
        return new CustomerResource($customer);
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Remove a list of Customers along side all their resources (ie. Estimates, Invoices, Payments and Addresses)
 | 
						|
     *
 | 
						|
     * @param  \Illuminate\Http\Request $request
 | 
						|
     * @return \Illuminate\Http\JsonResponse
 | 
						|
     */
 | 
						|
    public function delete(DeleteCustomersRequest $request)
 | 
						|
    {
 | 
						|
        $this->authorize('delete multiple customers');
 | 
						|
 | 
						|
        Customer::deleteCustomers($request->ids);
 | 
						|
 | 
						|
        return response()->json([
 | 
						|
            'success' => true,
 | 
						|
        ]);
 | 
						|
    }
 | 
						|
}
 |