2017-12-08 10:04:02 +11:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace App\Models;
|
|
|
|
|
2021-06-30 14:00:41 +10:00
|
|
|
use Illuminate\Database\Eloquent\Factories\HasFactory;
|
2017-12-08 10:04:02 +11:00
|
|
|
use Illuminate\Database\Eloquent\Model;
|
2021-07-01 19:41:12 +10:00
|
|
|
use Illuminate\Support\Collection;
|
2018-07-31 14:11:00 +10:00
|
|
|
use Illuminate\Support\Facades\Log;
|
2017-12-08 10:04:02 +11:00
|
|
|
|
|
|
|
class Site extends Model
|
|
|
|
{
|
2021-06-30 14:00:41 +10:00
|
|
|
use HasFactory;
|
|
|
|
|
2018-07-06 16:57:49 +10:00
|
|
|
public $timestamps = FALSE;
|
2018-07-31 14:11:00 +10:00
|
|
|
|
2017-12-08 10:04:02 +11:00
|
|
|
protected $casts = [
|
|
|
|
'address'=>'array',
|
|
|
|
];
|
|
|
|
|
2021-07-01 19:41:12 +10:00
|
|
|
/* RELATIONS */
|
|
|
|
|
|
|
|
public function country()
|
2018-07-31 14:11:00 +10:00
|
|
|
{
|
2021-07-01 19:41:12 +10:00
|
|
|
return $this->belongsTo(Country::class);
|
2018-07-31 14:11:00 +10:00
|
|
|
}
|
|
|
|
|
2021-07-01 19:41:12 +10:00
|
|
|
public function currency()
|
2018-08-01 17:09:38 +10:00
|
|
|
{
|
2021-07-01 19:41:12 +10:00
|
|
|
return $this->belongsTo(Currency::class);
|
2018-08-01 17:09:38 +10:00
|
|
|
}
|
|
|
|
|
2021-07-01 19:41:12 +10:00
|
|
|
public function details()
|
2018-07-31 14:11:00 +10:00
|
|
|
{
|
2021-07-02 09:12:34 +10:00
|
|
|
return $this->hasMany(SiteDetail::class,NULL,'site_id');
|
2018-08-07 14:26:33 +10:00
|
|
|
}
|
2018-07-31 14:11:00 +10:00
|
|
|
|
2021-07-01 19:41:12 +10:00
|
|
|
public function language()
|
2018-08-07 14:26:33 +10:00
|
|
|
{
|
2021-07-01 19:41:12 +10:00
|
|
|
return $this->belongsTo(Language::class);
|
|
|
|
}
|
2018-07-31 14:11:00 +10:00
|
|
|
|
2021-07-01 19:41:12 +10:00
|
|
|
/* ATTRIBUTES */
|
2018-08-07 14:26:33 +10:00
|
|
|
|
2021-07-01 19:41:12 +10:00
|
|
|
public function getAllowedKeysAttribute(): Collection
|
|
|
|
{
|
|
|
|
return $this->_sampledata()->keys();
|
2018-08-07 14:26:33 +10:00
|
|
|
}
|
|
|
|
|
2021-07-01 19:41:12 +10:00
|
|
|
/* METHODS */
|
|
|
|
|
|
|
|
public function __get($key)
|
2020-01-21 20:59:10 +11:00
|
|
|
{
|
2021-07-01 19:41:12 +10:00
|
|
|
static $details = NULL;
|
2020-01-21 20:59:10 +11:00
|
|
|
|
2021-07-01 19:41:12 +10:00
|
|
|
if ($x = parent::__get($key))
|
|
|
|
return $x;
|
2020-01-21 20:59:10 +11:00
|
|
|
|
2021-07-01 19:41:12 +10:00
|
|
|
// Get the value from the details table
|
|
|
|
if (($x=$this->detail_item($key)) !== NULL)
|
|
|
|
return $x;
|
2018-08-07 14:26:33 +10:00
|
|
|
|
2021-07-01 19:41:12 +10:00
|
|
|
if (is_null($details))
|
2021-07-02 09:12:34 +10:00
|
|
|
$details = new SiteDetail;
|
2018-08-07 14:26:33 +10:00
|
|
|
|
2021-07-01 19:41:12 +10:00
|
|
|
// Get a default value for this key
|
|
|
|
$value = $details->sample($key);
|
|
|
|
|
|
|
|
// At this point our DB doesnt have this value, we'll log an alert
|
|
|
|
if ($this->exists)
|
|
|
|
Log::alert(sprintf('Site is missing value for key [%s] - providing a default [%s]',$key,serialize($value)));
|
2018-08-07 14:26:33 +10:00
|
|
|
|
2021-07-01 19:41:12 +10:00
|
|
|
return $value;
|
2018-07-31 14:11:00 +10:00
|
|
|
}
|
|
|
|
|
2021-07-01 19:41:12 +10:00
|
|
|
/* GENERAL METHODS */
|
|
|
|
|
2017-12-08 10:04:02 +11:00
|
|
|
/**
|
2021-07-01 19:41:12 +10:00
|
|
|
* Get a key from the site_details
|
|
|
|
*
|
|
|
|
* @param $key
|
|
|
|
* @return mixed
|
2017-12-08 10:04:02 +11:00
|
|
|
*/
|
2021-07-01 19:41:12 +10:00
|
|
|
private function detail_item($key)
|
2017-12-08 10:04:02 +11:00
|
|
|
{
|
2021-07-01 19:41:12 +10:00
|
|
|
if (($x=$this->details->search(function($item) use ($key) { return $item->key == $key; })) !== FALSE)
|
|
|
|
return $this->details->get($x)->value;
|
2018-07-31 14:11:00 +10:00
|
|
|
|
2021-07-01 19:41:12 +10:00
|
|
|
return NULL;
|
2017-12-08 10:04:02 +11:00
|
|
|
}
|
|
|
|
|
2021-07-02 09:12:34 +10:00
|
|
|
public function getAddressAttribute(): array
|
|
|
|
{
|
|
|
|
return [
|
|
|
|
$this->site_address1,
|
|
|
|
$this->site_address2,
|
|
|
|
sprintf('%s %s %s',$this->site_city.(($this->site_state OR $this->site_postcode) ? ',' : ''),$this->site_state,$this->site_postcode)
|
|
|
|
];
|
|
|
|
}
|
|
|
|
|
2021-07-01 19:41:12 +10:00
|
|
|
/**
|
|
|
|
* Add the path to the mail logo, so it can be displayed.
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getEmailLogoAttribute()
|
2017-12-08 10:04:02 +11:00
|
|
|
{
|
2021-07-01 19:41:12 +10:00
|
|
|
return (($x=$this->detail_item('email_logo')) !== NULL) ? '/storage/'.$x : '/image/generic/150/20/fff';
|
2017-12-08 10:04:02 +11:00
|
|
|
}
|
|
|
|
|
2021-07-01 19:41:12 +10:00
|
|
|
/**
|
|
|
|
* Add the path to the site logo, so it can be displayed.
|
|
|
|
*
|
|
|
|
* @param $value
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getSiteLogoAttribute($value)
|
2017-12-08 10:04:02 +11:00
|
|
|
{
|
2021-07-01 19:41:12 +10:00
|
|
|
return (($x=$this->detail_item('site_logo')) !== NULL) ? '/storage/'.$x : '/image/generic/150/20/fff';
|
2017-12-08 10:04:02 +11:00
|
|
|
}
|
2018-08-07 14:26:33 +10:00
|
|
|
}
|