Merge pull request #2011 from burakcakirel/update_customer_user

Update customer/user relationships
This commit is contained in:
Cüneyt Şentürk 2021-04-29 16:16:53 +03:00 committed by GitHub
commit ca0ef0a696
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 41 additions and 4 deletions

View File

@ -6,6 +6,7 @@ use Illuminate\Foundation\Http\FormRequest;
class User extends FormRequest class User extends FormRequest
{ {
/** /**
* Determine if the user is authorized to make this request. * Determine if the user is authorized to make this request.
* *
@ -29,12 +30,22 @@ class User extends FormRequest
$picture = 'mimes:' . config('filesystems.mimes') . '|between:0,' . config('filesystems.max_size') * 1024; $picture = 'mimes:' . config('filesystems.mimes') . '|between:0,' . config('filesystems.max_size') * 1024;
} }
$email = 'required|email';
if ($this->getMethod() == 'PATCH') { if ($this->getMethod() == 'PATCH') {
// Updating user // Updating user
$id = is_numeric($this->user) ? $this->user : $this->user->getAttribute('id'); $id = is_numeric($this->user) ? $this->user : $this->user->getAttribute('id');
$password = ''; $password = '';
$companies = $this->user->can('read-common-companies') ? 'required' : ''; $companies = $this->user->can('read-common-companies') ? 'required' : '';
$roles = $this->user->can('read-auth-roles') ? 'required' : ''; $roles = $this->user->can('read-auth-roles') ? 'required' : '';
if ($this->user->contact) {
$email .= '|unique:contacts,NULL,'
. $this->user->contact->id . ',id'
. ',company_id,' . company_id()
. ',type,customer'
. ',deleted_at,NULL';
}
} else { } else {
// Creating user // Creating user
$id = null; $id = null;
@ -43,9 +54,11 @@ class User extends FormRequest
$roles = 'required'; $roles = 'required';
} }
$email .= '|unique:users,email,' . $id . ',id,deleted_at,NULL';
return [ return [
'name' => 'required|string', 'name' => 'required|string',
'email' => 'required|email|unique:users,email,' . $id . ',id,deleted_at,NULL', 'email' => $email,
'password' => $password . 'confirmed', 'password' => $password . 'confirmed',
'companies' => $companies, 'companies' => $companies,
'roles' => $roles, 'roles' => $roles,

View File

@ -43,7 +43,15 @@ class Contact extends FormRequest
} }
if (!empty($this->request->get('email'))) { if (!empty($this->request->get('email'))) {
$email = 'email|unique:contacts,NULL,' . $id . ',id,company_id,' . $company_id . ',type,' . $type . ',deleted_at,NULL'; $email .= 'email|unique:contacts,NULL,'
. $id . ',id'
. ',company_id,' . $company_id
. ',type,' . $type
. ',deleted_at,NULL';
if (isset($model) && $this->$model->user_id) {
$email .= '|unique:users,NULL,' . $this->$model->user_id . ',id,deleted_at,NULL';
}
} }
return [ return [

View File

@ -31,9 +31,19 @@ class Profile extends FormRequest
$picture = 'mimes:' . config('filesystems.mimes') . '|between:0,' . config('filesystems.max_size') * 1024; $picture = 'mimes:' . config('filesystems.mimes') . '|between:0,' . config('filesystems.max_size') * 1024;
} }
$email = 'required|email|unique:users,email,' . $id . ',id,deleted_at,NULL';
if (user()->contact) {
$email .= '|unique:contacts,NULL,'
. user()->contact->id . ',id'
. ',company_id,' . company_id()
. ',type,customer'
. ',deleted_at,NULL';
}
return [ return [
'name' => 'required|string', 'name' => 'required|string',
'email' => 'required|email|unique:users,email,' . $id . ',id,deleted_at,NULL', 'email' => $email,
'password' => 'confirmed', 'password' => 'confirmed',
'picture' => $picture, 'picture' => $picture,
]; ];

View File

@ -55,6 +55,10 @@ class UpdateUser extends Job
if ($this->request->has('companies')) { if ($this->request->has('companies')) {
$this->user->companies()->sync($this->request->get('companies')); $this->user->companies()->sync($this->request->get('companies'));
} }
if ($this->user->contact) {
$this->user->contact->update($this->request->input());
}
}); });
return $this->user; return $this->user;

View File

@ -38,6 +38,8 @@ class UpdateContact extends Job
\DB::transaction(function () { \DB::transaction(function () {
if ($this->request->get('create_user', 'false') === 'true') { if ($this->request->get('create_user', 'false') === 'true') {
$this->createUser(); $this->createUser();
} elseif ($this->contact->user) {
$this->contact->user->update($this->request->all());
} }
// Upload logo // Upload logo