wyyl/beike/Admin/Http/Controllers/CustomerController.php

142 lines
5.0 KiB
PHP

<?php
/**
* CustomerController.php
*
* @copyright 2022 beikeshop.com - All Rights Reserved
* @link https://beikeshop.com
* @author TL <mengwb@guangda.work>
* @created 2022-06-28 16:17:04
* @modified 2022-06-28 16:17:04
*/
namespace Beike\Admin\Http\Controllers;
use Beike\Admin\Http\Requests\CustomerRequest;
use Beike\Admin\Http\Resources\AddressResource;
use Beike\Admin\Http\Resources\CustomerGroupDetail;
use Beike\Admin\Http\Resources\CustomerResource;
use Beike\Admin\Services\CustomerService;
use Beike\Repositories\AddressRepo;
use Beike\Repositories\CountryRepo;
use Beike\Repositories\CustomerGroupRepo;
use Beike\Repositories\CustomerRepo;
use Illuminate\Http\Request;
class CustomerController extends Controller
{
public function index(Request $request)
{
$customers = CustomerRepo::list($request->only(['name', 'email', 'status', 'from', 'customer_group_id']));
$data = [
'customers' => $customers,
'customers_format' => CustomerResource::collection($customers)->jsonSerialize(),
'customer_groups' => CustomerGroupDetail::collection(CustomerGroupRepo::list())->jsonSerialize(),
'type' => 'customer',
];
$data = hook_filter('admin.customer.index.data', $data);
if ($request->expectsJson()) {
return json_success(trans('success'), $data);
}
return view('admin::pages.customers.index', $data);
}
public function trashed(Request $request)
{
$customers = CustomerRepo::list(array_merge($request->only(['name', 'email', 'status', 'from', 'customer_group_id']), ['only_trashed' => true]));
$data = [
'customers' => $customers,
'customers_format' => CustomerResource::collection($customers)->jsonSerialize(),
'customer_groups' => CustomerGroupDetail::collection(CustomerGroupRepo::list())->jsonSerialize(),
'type' => 'trashed',
];
$data = hook_filter('admin.customer.trashed.data', $data);
if ($request->expectsJson()) {
return json_success(trans('success'), $data);
}
return view('admin::pages.customers.index', $data);
}
public function store(CustomerRequest $request)
{
$requestData = $request->all();
hook_action('admin.customer.store.before', ['request_data' => $requestData]);
$customer = CustomerService::create($requestData);
hook_action('admin.customer.store.after', ['customer_id' => $customer->id, 'request_data' => $requestData]);
return json_success(trans('common.success'), new CustomerResource($customer));
}
public function edit(Request $request, int $customerId)
{
$addresses = AddressRepo::listByCustomer($customerId);
$customer = CustomerRepo::find($customerId);
$data = [
'customer' => $customer,
'customer_groups' => CustomerGroupDetail::collection(CustomerGroupRepo::list())->jsonSerialize(),
'addresses' => AddressResource::collection($addresses)->jsonSerialize(),
'countries' => CountryRepo::all(),
'country_id' => system_setting('base.country_id'),
'_redirect' => $this->getRedirect(),
];
$data = hook_filter('admin.customer.edit.data', $data);
return view('admin::pages.customers.form', $data);
}
public function update(CustomerRequest $request, int $customerId)
{
$requestData = $request->all();
$password = $requestData['password'] ?? '';
if (empty($password)) {
unset($requestData['password']);
}
hook_action('admin.customer.update.before', ['customer_id' => $customerId, 'request_data' => $requestData]);
$customer = CustomerRepo::update($customerId, $requestData);
hook_action('admin.customer.update.after', ['customer_id' => $customerId, 'request_data' => $requestData]);
return json_success(trans('common.updated_success'), $customer);
}
public function destroy(Request $request, int $customerId)
{
CustomerRepo::delete($customerId);
hook_action('admin.customer.destroy.after', $customerId);
return json_success(trans('common.deleted_success'));
}
public function restore(Request $request, int $customerId)
{
CustomerRepo::restore($customerId);
hook_action('admin.customer.restore.after', $customerId);
return json_success(trans('common.restored_success'));
}
public function forceDelete(Request $request, int $customerId)
{
CustomerRepo::forceDelete($customerId);
hook_action('admin.customer.force_delete.after', $customerId);
return json_success(trans('common.success'));
}
public function forceDeleteAll(Request $request)
{
CustomerRepo::forceDeleteAll();
hook_action('admin.customer.force_delete_all.after', ['module' => 'customer']);
return json_success(trans('common.success'));
}
}