2021-12-24 12:14:01 +11:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace App\Models\Product;
|
|
|
|
|
|
|
|
use Illuminate\Support\Collection;
|
2022-04-02 18:06:34 +11:00
|
|
|
use Leenooks\Traits\ScopeActive;
|
2021-12-24 12:14:01 +11:00
|
|
|
|
2022-02-01 16:40:46 +11:00
|
|
|
use App\Interfaces\ProductItem;
|
|
|
|
use App\Models\Supplier;
|
2021-12-24 12:14:01 +11:00
|
|
|
use App\Models\Service\Broadband as ServiceBroadband;
|
|
|
|
use App\Models\Supplier\Broadband as SupplierBroadband;
|
|
|
|
|
2022-04-19 17:07:39 +10:00
|
|
|
// @todo does this need to extend Type? Perhaps have a ProductType consistent with ServiceType.
|
2022-02-01 16:40:46 +11:00
|
|
|
final class Broadband extends Type implements ProductItem
|
2021-12-24 12:14:01 +11:00
|
|
|
{
|
2022-04-02 18:06:34 +11:00
|
|
|
use ScopeActive;
|
|
|
|
|
2021-12-24 12:14:01 +11:00
|
|
|
protected $table = 'product_broadband';
|
|
|
|
|
|
|
|
// Information required during the order process
|
2022-04-04 20:29:45 +10:00
|
|
|
protected array $order_attributes = [
|
2021-12-24 12:14:01 +11:00
|
|
|
'options.address'=>[
|
|
|
|
'request'=>'options.address',
|
|
|
|
'key'=>'service_address',
|
2022-04-20 16:24:58 +10:00
|
|
|
'validation'=>'required|string:10|unique:service_broadband,service_address',
|
2021-12-24 12:14:01 +11:00
|
|
|
'validation_message'=>'Address is a required field.',
|
|
|
|
],
|
|
|
|
'options.notes'=>[
|
|
|
|
'request'=>'options.notes',
|
|
|
|
'key'=>'order_info.notes',
|
|
|
|
'validation'=>'present',
|
|
|
|
'validation_message'=>'Special Instructions here.',
|
|
|
|
],
|
|
|
|
];
|
|
|
|
|
2022-02-01 16:40:46 +11:00
|
|
|
// The model that is referenced when this product is ordered
|
2021-12-24 12:14:01 +11:00
|
|
|
protected string $order_model = ServiceBroadband::class;
|
|
|
|
|
|
|
|
/* RELATIONS */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The offering supplied with this product
|
|
|
|
*
|
|
|
|
* @return \Illuminate\Database\Eloquent\Relations\HasOne
|
|
|
|
*/
|
|
|
|
public function supplied()
|
|
|
|
{
|
2022-04-19 17:07:39 +10:00
|
|
|
return $this->hasOne(SupplierBroadband::class,'id','supplier_item_id');
|
2021-12-24 12:14:01 +11:00
|
|
|
}
|
|
|
|
|
|
|
|
/* INTERFACES */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Calculate the allowance array or traffic used array
|
|
|
|
*
|
|
|
|
* @param array Traffic Used in each metric.
|
|
|
|
* @param bool $ceil Round the numbers to integers
|
|
|
|
* @return array|string
|
|
|
|
*/
|
|
|
|
public function allowance(array $data=[],bool $ceil=TRUE): Collection
|
|
|
|
{
|
|
|
|
$config = collect();
|
|
|
|
|
|
|
|
foreach (array_keys(Supplier\Broadband::traffic_map) as $k => $v) {
|
|
|
|
// Base Config
|
|
|
|
$config->put($k,$this->{$k});
|
|
|
|
// Excess Config
|
|
|
|
$config->put($v,$this->{$v});
|
|
|
|
}
|
|
|
|
|
|
|
|
// Shaped or Charge
|
|
|
|
$config->put('shaped',$this->extra_shaped);
|
|
|
|
$config->put('charged',$this->extra_charged);
|
|
|
|
|
|
|
|
// Metric - used to round down data in $data.
|
|
|
|
$config->put('metric',$this->metric);
|
|
|
|
|
|
|
|
return $this->supplied->allowance($config,$data,$ceil);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* ATTRIBUTES */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return the suppliers cost for this service
|
|
|
|
*
|
|
|
|
* @return float
|
|
|
|
*/
|
|
|
|
// @todo To check
|
|
|
|
public function allowance_cost(): float
|
|
|
|
{
|
|
|
|
$result = 0;
|
|
|
|
foreach ($this->supplied->allowance(NULL,$this->allowance([])->toArray()) as $k=>$v) {
|
|
|
|
$result += -$v*$this->supplied->{Supplier\Broadband::traffic_map[$k]};
|
|
|
|
}
|
|
|
|
|
|
|
|
return $result;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Render the allowance as a string
|
|
|
|
* eg: 50/100
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
2022-02-01 16:40:46 +11:00
|
|
|
// @todo To check
|
2021-12-24 12:14:01 +11:00
|
|
|
public function allowance_string(): string
|
|
|
|
{
|
|
|
|
$result = '';
|
|
|
|
$data = $this->allowance();
|
|
|
|
|
|
|
|
foreach ([
|
|
|
|
'base_down_peak',
|
|
|
|
'base_up_peak',
|
|
|
|
'base_down_offpeak',
|
|
|
|
'base_up_offpeak',
|
|
|
|
] as $k)
|
|
|
|
{
|
|
|
|
if ($data->has($k)) {
|
|
|
|
if ($result)
|
|
|
|
$result .= '/';
|
|
|
|
|
|
|
|
$result .= $data->get($k);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return $result;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The product contract term is the highest of
|
|
|
|
* + This defined contract_term
|
|
|
|
* + The suppliers contract_term
|
|
|
|
*
|
|
|
|
* @return int
|
|
|
|
*/
|
|
|
|
public function getContractTermAttribute(): int
|
|
|
|
{
|
|
|
|
return max($this->attributes['contract_term'],$this->supplied->getContractTermAttribute());
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getCostAttribute(): float
|
|
|
|
{
|
|
|
|
abort(500,'deprecated');
|
|
|
|
// @todo Tax shouldnt be hard coded
|
|
|
|
return ($this->supplied->base_cost+$this->allowance_cost())*1.1;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getSupplierAttribute()
|
|
|
|
{
|
|
|
|
abort(500,'deprecated');
|
|
|
|
return $this->getRelationValue('supplier');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function hasUsage(): bool
|
|
|
|
{
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
}
|