user()->can('edit', $this->expense); } public function rules() { /* Ensure we have a client name, and that all emails are unique*/ $rules = []; if (isset($this->number)) { $rules['number'] = Rule::unique('expenses')->where('company_id', auth()->user()->company()->id)->ignore($this->expense->id); } if ($this->client_id) { $rules['client_id'] = 'bail|sometimes|exists:clients,id,company_id,'.auth()->user()->company()->id; } $rules['category_id'] = 'bail|sometimes|nullable|exists:expense_categories,id,company_id,'.auth()->user()->company()->id.',is_deleted,0'; return $this->globalRules($rules); } public function prepareForValidation() { $input = $this->all(); $input = $this->decodePrimaryKeys($input); if (array_key_exists('documents', $input)) { unset($input['documents']); } if (! array_key_exists('currency_id', $input) || strlen($input['currency_id']) == 0) { $input['currency_id'] = (string) auth()->user()->company()->settings->currency_id; } /* Ensure the project is related */ if (array_key_exists('project_id', $input) && isset($input['project_id'])) { $project = Project::withTrashed()->where('id', $input['project_id'])->company()->first(); if($project){ $input['client_id'] = $project->client_id; } else { unset($input['project_id']); } } $this->replace($input); } }