mirror of
				https://github.com/crater-invoice/crater.git
				synced 2025-10-28 04:01:10 -04: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,
 | |
|         ]);
 | |
|     }
 | |
| }
 |