* @created 2022-06-16 17:45:41 * @modified 2022-06-16 17:45:41 */ namespace Beike\Repositories; use Beike\Models\Customer; use Illuminate\Support\Facades\Hash; class CustomerRepo { /** * 创建一个customer记录 * @param $customerData * @return int */ public static function create($customerData) { $customerData['password'] = Hash::make($customerData['password']); return Customer::query()->create($customerData); } /** * @param $customer * @param $data * @return bool|int */ public static function update($customer, $data) { if (!$customer instanceof Customer) { $customer = Customer::query()->findOrFail($customer); } if (isset($data['password'])) { $data['password'] = Hash::make($data['password']); } return $customer->update($data); } public static function findByEmail($email) { return Customer::query()->where('email', $email)->first(); } /** * @param $id * @return \Illuminate\Database\Eloquent\Builder|\Illuminate\Database\Eloquent\Builder[]|\Illuminate\Database\Eloquent\Collection|\Illuminate\Database\Eloquent\Model|null */ public static function find($id) { return Customer::query()->find($id); } /** * @param $id * @return void */ public static function delete($id) { Customer::query()->find($id)->delete(); } /** * @param $data * @return \Illuminate\Contracts\Pagination\LengthAwarePaginator */ public static function list($data) { $builder = Customer::query()->with("customerGroup.description"); if (isset($data['name'])) { $builder->where('customers.name', 'like', "%{$data['name']}%"); } if (isset($data['email'])) { $builder->where('customers.email', 'like', "%{$data['email']}%"); } if (isset($data['status'])) { $builder->where('customers.status', $data['status']); } if (isset($data['from'])) { $builder->where('customers.from', $data['from']); } if (isset($data['customer_group_id'])) { $builder->where('customers.customer_group_id', $data['customer_group_id']); } return $builder->paginate(20)->withQueryString(); } public static function restore($id) { Customer::withTrashed()->find($id)->restore(); } }