mirror of
				https://github.com/crater-invoice/crater.git
				synced 2025-11-03 22:13:18 -05:00 
			
		
		
		
	
		
			
				
	
	
		
			234 lines
		
	
	
		
			7.1 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			234 lines
		
	
	
		
			7.1 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
namespace Laraspace\Http\Controllers;
 | 
						|
 | 
						|
use Illuminate\Http\Request;
 | 
						|
use Illuminate\Support\Facades\Auth;
 | 
						|
use Laraspace\Conversation;
 | 
						|
use Laraspace\Group;
 | 
						|
use Laraspace\Http\Requests;
 | 
						|
use Laraspace\Notifications\CustomerAdded;
 | 
						|
use Laraspace\User;
 | 
						|
use Illuminate\Support\Facades\Hash;
 | 
						|
use Laraspace\Currency;
 | 
						|
use Laraspace\CompanySetting;
 | 
						|
use Laraspace\Address;
 | 
						|
use Illuminate\Support\Facades\DB;
 | 
						|
 | 
						|
class CustomersController extends Controller
 | 
						|
{
 | 
						|
    /**
 | 
						|
     * Display a listing of the resource.
 | 
						|
     *
 | 
						|
     * @return \Illuminate\Http\Response
 | 
						|
     */
 | 
						|
    public function index(Request $request)
 | 
						|
    {
 | 
						|
        $limit = $request->has('limit') ? $request->limit : 10;
 | 
						|
 | 
						|
        $customers = User::customer()
 | 
						|
            ->applyFilters($request->only([
 | 
						|
                'search',
 | 
						|
                'contact_name',
 | 
						|
                'display_name',
 | 
						|
                'phone',
 | 
						|
                'orderByField',
 | 
						|
                'orderBy'
 | 
						|
            ]))
 | 
						|
            ->whereCompany($request->header('company'))
 | 
						|
            ->select('users.*',
 | 
						|
                DB::raw('sum(invoices.due_amount) as due_amount')
 | 
						|
            )
 | 
						|
            ->groupBy('users.id')
 | 
						|
            ->leftJoin('invoices', 'users.id', '=', 'invoices.user_id')
 | 
						|
            ->paginate($limit);
 | 
						|
 | 
						|
        $siteData = [
 | 
						|
            'customers' => $customers
 | 
						|
        ];
 | 
						|
 | 
						|
        return response()->json($siteData);
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Store a newly created resource in storage.
 | 
						|
     *
 | 
						|
     * @param  \Illuminate\Http\Request  $request
 | 
						|
     * @return \Illuminate\Http\Response
 | 
						|
     */
 | 
						|
    public function store(Requests\CustomerRequest $request)
 | 
						|
    {
 | 
						|
        $verifyEmail = User::where('email', $request->email)->first();
 | 
						|
 | 
						|
 | 
						|
        $customer = new User();
 | 
						|
        $customer->name = $request->name;
 | 
						|
        $customer->currency_id = $request->currency_id;
 | 
						|
        $customer->company_id = $request->header('company');
 | 
						|
        $customer->email = $request->email;
 | 
						|
        $customer->phone = $request->phone;
 | 
						|
        $customer->company_name = $request->company_name;
 | 
						|
        $customer->contact_name = $request->contact_name;
 | 
						|
        $customer->website = $request->website;
 | 
						|
        $customer->enable_portal = $request->enable_portal;
 | 
						|
        $customer->role = 'customer';
 | 
						|
        $customer->password = Hash::make($request->password);
 | 
						|
        $customer->save();
 | 
						|
 | 
						|
        if ($request->addresses) {
 | 
						|
            foreach ($request->addresses as $address) {
 | 
						|
                $newAddress = new Address();
 | 
						|
                $newAddress->name = $address["name"];
 | 
						|
                $newAddress->address_street_1 = $address["address_street_1"];
 | 
						|
                $newAddress->address_street_2 = $address["address_street_2"];
 | 
						|
                $newAddress->city_id = $address["city_id"];
 | 
						|
                $newAddress->state_id = $address["state_id"];
 | 
						|
                $newAddress->country_id = $address["country_id"];
 | 
						|
                $newAddress->zip = $address["zip"];
 | 
						|
                $newAddress->phone = $address["phone"];
 | 
						|
                $newAddress->type = $address["type"];
 | 
						|
                $newAddress->user_id = $customer->id;
 | 
						|
                $newAddress->save();
 | 
						|
                $customer->addresses()->save($newAddress);
 | 
						|
            }
 | 
						|
        }
 | 
						|
 | 
						|
        $customer = User::with('billingAddress', 'shippingAddress')->find($customer->id);
 | 
						|
 | 
						|
        return response()->json([
 | 
						|
            'customer' => $customer,
 | 
						|
            'success' => true
 | 
						|
        ]);
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Display the specified resource.
 | 
						|
     *
 | 
						|
     * @param  int  $id
 | 
						|
     * @return \Illuminate\Http\Response
 | 
						|
     */
 | 
						|
    public function show($id)
 | 
						|
    {
 | 
						|
        $customer = User::with([
 | 
						|
            'billingAddress',
 | 
						|
            'shippingAddress',
 | 
						|
            'billingAddress.country',
 | 
						|
            'billingAddress.state',
 | 
						|
            'billingAddress.city',
 | 
						|
            'shippingAddress.country',
 | 
						|
            'shippingAddress.state',
 | 
						|
            'shippingAddress.city',
 | 
						|
        ])->find($id);
 | 
						|
 | 
						|
        return response()->json([
 | 
						|
            'customer' => $customer
 | 
						|
        ]);
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Show the form for editing the specified resource.
 | 
						|
     *
 | 
						|
     * @param  int  $id
 | 
						|
     * @return \Illuminate\Http\Response
 | 
						|
     */
 | 
						|
    public function edit($id)
 | 
						|
    {
 | 
						|
        $customer = User::with('billingAddress', 'shippingAddress')->findOrFail($id);
 | 
						|
        $currency = $customer->currency;
 | 
						|
        $currencies = Currency::all();
 | 
						|
 | 
						|
        return response()->json([
 | 
						|
            'customer' => $customer,
 | 
						|
            'currencies' => $currencies,
 | 
						|
            'currency' => $currency
 | 
						|
        ]);
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Update the specified resource in storage.
 | 
						|
     *
 | 
						|
     * @param  \Illuminate\Http\Request  $request
 | 
						|
     * @param  int  $id
 | 
						|
     * @return \Illuminate\Http\Response
 | 
						|
     */
 | 
						|
    public function update($id, Requests\CustomerRequest $request)
 | 
						|
    {
 | 
						|
        $customer = User::find($id);
 | 
						|
 | 
						|
        if ($request->email != null) {
 | 
						|
            $verifyEmail = User::where('email', $request->email)->first();
 | 
						|
 | 
						|
            if ($verifyEmail) {
 | 
						|
                if ($verifyEmail->id !== $customer->id) {
 | 
						|
                    return response()->json([
 | 
						|
                        'error' => 'Email already in use'
 | 
						|
                    ]);
 | 
						|
                }
 | 
						|
            }
 | 
						|
        }
 | 
						|
 | 
						|
        if ($request->has('password')) {
 | 
						|
            $customer->password = Hash::make($request->password);
 | 
						|
        }
 | 
						|
 | 
						|
        $customer->name = $request->name;
 | 
						|
        $customer->currency_id = $request->currency_id;
 | 
						|
        $customer->email = $request->email;
 | 
						|
        $customer->phone = $request->phone;
 | 
						|
        $customer->company_name = $request->company_name;
 | 
						|
        $customer->contact_name = $request->contact_name;
 | 
						|
        $customer->website = $request->website;
 | 
						|
        $customer->enable_portal = $request->enable_portal;
 | 
						|
        $customer->save();
 | 
						|
 | 
						|
        if ($request->addresses) {
 | 
						|
            foreach ($request->addresses as $address) {
 | 
						|
                $newAddress = $customer->addresses()->firstOrNew(['type' => $address["type"]]);
 | 
						|
                $newAddress->name = $address["name"];
 | 
						|
                $newAddress->address_street_1 = $address["address_street_1"];
 | 
						|
                $newAddress->address_street_2 = $address["address_street_2"];
 | 
						|
                $newAddress->city_id = $address["city_id"];
 | 
						|
                $newAddress->state_id = $address["state_id"];
 | 
						|
                $newAddress->country_id = $address["country_id"];
 | 
						|
                $newAddress->zip = $address["zip"];
 | 
						|
                $newAddress->phone = $address["phone"];
 | 
						|
                $newAddress->type = $address["type"];
 | 
						|
                $newAddress->user_id = $customer->id;
 | 
						|
                $newAddress->save();
 | 
						|
            }
 | 
						|
        }
 | 
						|
 | 
						|
        $customer = User::with('billingAddress', 'shippingAddress')->find($customer->id);
 | 
						|
 | 
						|
        return response()->json([
 | 
						|
            'customer' => $customer,
 | 
						|
            'success' => true
 | 
						|
        ]);
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Remove the specified resource from storage.
 | 
						|
     *
 | 
						|
     * @param  int  $id
 | 
						|
     * @return \Illuminate\Http\Response
 | 
						|
     */
 | 
						|
    public function destroy($id)
 | 
						|
    {
 | 
						|
        User::deleteCustomer($id);
 | 
						|
 | 
						|
        return response()->json([
 | 
						|
            'success' => true
 | 
						|
        ]);
 | 
						|
    }
 | 
						|
 | 
						|
    public function delete(Request $request)
 | 
						|
    {
 | 
						|
        foreach ($request->id as $id) {
 | 
						|
            User::deleteCustomer($id);
 | 
						|
        }
 | 
						|
 | 
						|
        return response()->json([
 | 
						|
            'success' => true
 | 
						|
        ]);
 | 
						|
    }
 | 
						|
}
 |