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-01 19:41:12 +10:00
|
|
|
return $this->hasMany(SiteDetails::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))
|
|
|
|
$details = new SiteDetails;
|
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-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
|
|
|
}
|
|
|
|
|
2021-07-01 19:41:12 +10:00
|
|
|
// @todo - To optimize
|
2017-12-08 10:04:02 +11:00
|
|
|
private function _address()
|
|
|
|
{
|
|
|
|
$return = [];
|
|
|
|
|
2018-07-31 14:11:00 +10:00
|
|
|
if ($this->site_address1)
|
|
|
|
array_push($return,$this->site_address1);
|
|
|
|
if ($this->site_address2)
|
|
|
|
array_push($return,$this->site_address2);
|
|
|
|
if ($this->site_city)
|
|
|
|
array_push($return,sprintf('%s %s %s',$this->site_city.(($this->site_state OR $this->site_postcode) ? ',' : ''),$this->site_state,$this->site_postcode));
|
2017-12-08 10:04:02 +11:00
|
|
|
|
|
|
|
if (! $return)
|
|
|
|
$return = ['No Address'];
|
|
|
|
|
|
|
|
return $return;
|
|
|
|
}
|
|
|
|
|
2021-07-01 19:41:12 +10:00
|
|
|
// @todo - To optimize
|
2017-12-08 10:04:02 +11:00
|
|
|
public function address($type='plain')
|
|
|
|
{
|
|
|
|
switch ($type)
|
|
|
|
{
|
|
|
|
case 'html' : return join('<br>',$this->_address());
|
|
|
|
case 'newline': return join("\m",$this->_address());
|
|
|
|
|
|
|
|
default:
|
|
|
|
return join("\n",$this->_address());
|
|
|
|
}
|
|
|
|
}
|
2018-08-07 14:26:33 +10:00
|
|
|
}
|