'timestamp', 'created_at' => 'timestamp', 'deleted_at' => 'timestamp', ]; protected $dateFormat = 'Y-m-d H:i:s.u'; public function getHashedIdAttribute() { return $this->encodePrimaryKey($this->id); } public function dateMutator($value) { if (! empty($value)) { return (new Carbon($value))->format('Y-m-d'); } return $value; } public function __call($method, $params) { $entity = strtolower(class_basename($this)); if ($entity) { $configPath = "modules.relations.$entity.$method"; if (config()->has($configPath)) { $function = config()->get($configPath); return call_user_func_array([$this, $function[0]], $function[1]); } } return parent::__call($method, $params); } /* V2 type of scope */ public function scopeCompany($query) { $query->where('company_id', auth()->user()->companyId()); return $query; } /* V1 type of scope */ public function scopeScope($query) { $query->where($this->getTable().'.company_id', '=', auth()->user()->company()->id); return $query; } /** * Gets the settings by key. * * When we need to update a setting value, we need to harvest * the object of the setting. This is not possible when using the merged settings * as we do not know which object the setting has come from. * * The following method will return the entire object of the property searched for * where a value exists for $key. * * This object can then be mutated by the handling class, * to persist the new settings we will also need to pass back a * reference to the parent class. * * @param $key The key of property * @return */ public function getSettingsByKey($key) { /* Does Setting Exist @ client level */ if (isset($this->getSettings()->{$key})) { return $this->getSettings()->{$key}; } else { return (new CompanySettings($this->company->settings))->{$key}; } } public function setSettingsByEntity($entity, $settings) { switch ($entity) { case Client::class: $this->settings = $settings; $this->save(); $this->fresh(); break; case Company::class: $this->company->settings = $settings; $this->company->save(); break; //todo check that saving any other entity (Invoice:: RecurringInvoice::) settings is valid using the default: default: $this->client->settings = $settings; $this->client->save(); break; } } /** * Gets the settings. * * Generic getter for client settings * * @return ClientSettings The settings. */ public function getSettings() { return new ClientSettings($this->settings); } /** * Retrieve the model for a bound value. * * @param mixed $value * @param null $field * @return Model|null */ public function resolveRouteBinding($value, $field = null) { if (is_numeric($value)) { throw new ModelNotFoundException("Record with value {$value} not found"); } return $this ->withTrashed() ->where('id', $this->decodePrimaryKey($value))->firstOrFail(); } /** * @param string $extension * @return string */ public function getFileName($extension = 'pdf') { return $this->numberFormatter().'.'.$extension; } public function numberFormatter() { $number = strlen($this->number) > 1 ? $this->number : class_basename($this); $formatted_number = mb_ereg_replace("([^\w\s\d\-_~,;\[\]\(\).])", '', $number); // Remove any runs of periods (thanks falstro!) $formatted_number = mb_ereg_replace("([\.]{2,})", '', $formatted_number); $formatted_number = str_replace(" ", "_", $formatted_number); return $formatted_number; } }