323 lines
13 KiB
PHP
323 lines
13 KiB
PHP
<?php
|
|
|
|
namespace App\Models;
|
|
|
|
use Illuminate\Database\Eloquent\Model;
|
|
use Illuminate\Database\Eloquent\SoftDeletes;
|
|
use Carbon\Carbon;
|
|
|
|
|
|
/**
|
|
* App\Models\UserAccount
|
|
*
|
|
* @property-read \App\Models\Country $company_country
|
|
* @property-read \App\Models\Country $company_pre_phone
|
|
* @property-read \App\Models\Country $country
|
|
* @property mixed $birthday
|
|
* @property-read mixed $company
|
|
* @property-read \App\Models\Country $pre_mobil
|
|
* @property-read \App\Models\Country $pre_phone
|
|
* @property-read \App\User $user
|
|
* @method static bool|null forceDelete()
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\UserAccount newModelQuery()
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\UserAccount newQuery()
|
|
* @method static \Illuminate\Database\Query\Builder|\App\Models\UserAccount onlyTrashed()
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\UserAccount query()
|
|
* @method static bool|null restore()
|
|
* @method static \Illuminate\Database\Query\Builder|\App\Models\UserAccount withTrashed()
|
|
* @method static \Illuminate\Database\Query\Builder|\App\Models\UserAccount withoutTrashed()
|
|
* @property int $id
|
|
* @property string|null $salutation
|
|
* @property string|null $first_name
|
|
* @property string|null $last_name
|
|
* @property string|null $address
|
|
* @property string|null $address_2
|
|
* @property string|null $zipcode
|
|
* @property string|null $city
|
|
* @property int $country_id
|
|
* @property int|null $pre_phone_id
|
|
* @property string|null $phone
|
|
* @property int|null $pre_mobil_id
|
|
* @property string|null $mobil
|
|
* @property string|null $tax_number
|
|
* @property string|null $tax_identification_number
|
|
* @property int $same_as_billing
|
|
* @property string|null $shipping_salutation
|
|
* @property string|null $shipping_company
|
|
* @property string|null $shipping_firstname
|
|
* @property string|null $shipping_lastname
|
|
* @property string|null $shipping_address
|
|
* @property string|null $shipping_address_2
|
|
* @property string|null $shipping_zipcode
|
|
* @property string|null $shipping_city
|
|
* @property int $shipping_country_id
|
|
* @property int|null $shipping_pre_phone_id
|
|
* @property string|null $shipping_phone
|
|
* @property string|null $website
|
|
* @property string|null $facebook
|
|
* @property string|null $facebook_fanpage
|
|
* @property string|null $instagram
|
|
* @property string|null $data_protection
|
|
* @property \Illuminate\Support\Carbon|null $created_at
|
|
* @property \Illuminate\Support\Carbon|null $updated_at
|
|
* @property \Illuminate\Support\Carbon|null $deleted_at
|
|
* @property-read \App\Models\Country $shipping_country
|
|
* @property-read \App\Models\Country|null $shipping_pre_phone
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\UserAccount whereAddress($value)
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\UserAccount whereAddress2($value)
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\UserAccount whereBirthday($value)
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\UserAccount whereCity($value)
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\UserAccount whereCompany($value)
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\UserAccount whereCountryId($value)
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\UserAccount whereCreatedAt($value)
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\UserAccount whereDataProtection($value)
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\UserAccount whereDeletedAt($value)
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\UserAccount whereFacebook($value)
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\UserAccount whereFacebookFanpage($value)
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\UserAccount whereFirstName($value)
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\UserAccount whereId($value)
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\UserAccount whereInstagram($value)
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\UserAccount whereLastName($value)
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\UserAccount whereMobil($value)
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\UserAccount wherePhone($value)
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\UserAccount wherePreMobilId($value)
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\UserAccount wherePrePhoneId($value)
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\UserAccount whereSalutation($value)
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\UserAccount whereSameAsBilling($value)
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\UserAccount whereShippingAddress($value)
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\UserAccount whereShippingAddress2($value)
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\UserAccount whereShippingCity($value)
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\UserAccount whereShippingCompany($value)
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\UserAccount whereShippingCountryId($value)
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\UserAccount whereShippingFirstname($value)
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\UserAccount whereShippingLastname($value)
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\UserAccount whereShippingPhone($value)
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\UserAccount whereShippingPrePhoneId($value)
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\UserAccount whereShippingSalutation($value)
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\UserAccount whereShippingZipcode($value)
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\UserAccount whereTaxIdentificationNumber($value)
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\UserAccount whereTaxNumber($value)
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\UserAccount whereUpdatedAt($value)
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\UserAccount whereWebsite($value)
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\UserAccount whereZipcode($value)
|
|
* @property string|null $m_account
|
|
* @property string|null $m_salutation
|
|
* @property string|null $m_first_name
|
|
* @property string|null $m_last_name
|
|
* @property string|null $m_notes
|
|
* @property int|null $taxable_sales
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\UserAccount whereMAccount($value)
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\UserAccount whereMFirstName($value)
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\UserAccount whereMLastName($value)
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\UserAccount whereMNotes($value)
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\UserAccount whereMSalutation($value)
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\UserAccount whereTaxableSales($value)
|
|
* @property array|null $payment_data
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\UserAccount wherePaymentData($value)
|
|
* @property string|null $accepted_contract
|
|
* @property array|null $notice
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\UserAccount whereAcceptedContract($value)
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\UserAccount whereNotice($value)
|
|
* @property int $reverse_charge
|
|
* @property string|null $reverse_charge_code
|
|
* @property string|null $reverse_charge_valid
|
|
* @method static \Illuminate\Database\Eloquent\Builder|UserAccount whereReverseCharge($value)
|
|
* @method static \Illuminate\Database\Eloquent\Builder|UserAccount whereReverseChargeCode($value)
|
|
* @method static \Illuminate\Database\Eloquent\Builder|UserAccount whereReverseChargeValid($value)
|
|
* @property string|null $bank_owner
|
|
* @property string|null $bank_iban
|
|
* @property string|null $bank_bic
|
|
* @method static \Illuminate\Database\Eloquent\Builder|UserAccount whereBankBic($value)
|
|
* @method static \Illuminate\Database\Eloquent\Builder|UserAccount whereBankIban($value)
|
|
* @method static \Illuminate\Database\Eloquent\Builder|UserAccount whereBankOwner($value)
|
|
* @mixin \Eloquent
|
|
*/
|
|
class UserAccount extends Model
|
|
{
|
|
protected $table = 'user_accounts';
|
|
protected $fillable = [
|
|
'm_account',
|
|
'm_salutation',
|
|
'm_first_name',
|
|
'm_last_name',
|
|
'm_notes',
|
|
'company',
|
|
'salutation',
|
|
'first_name',
|
|
'last_name',
|
|
'address',
|
|
'address_2',
|
|
'zipcode',
|
|
'city',
|
|
'country_id',
|
|
'pre_phone_id',
|
|
'phone',
|
|
'pre_mobil_id',
|
|
'mobil',
|
|
'tax_number',
|
|
'tax_identification_number',
|
|
'taxable_sales',
|
|
'same_as_billing',
|
|
'shipping_salutation',
|
|
'shipping_company',
|
|
'shipping_firstname',
|
|
'shipping_lastname',
|
|
'shipping_address',
|
|
'shipping_address_2',
|
|
'shipping_zipcode',
|
|
'shipping_city',
|
|
'shipping_country_id',
|
|
'shipping_pre_phone_id',
|
|
'shipping_phone',
|
|
'shipping_postnumber',
|
|
'birthday',
|
|
'website',
|
|
'facebook',
|
|
'facebook_fanpage',
|
|
'instagram',
|
|
'bank_owner',
|
|
'bank_iban',
|
|
'bank_bic',
|
|
'notice'
|
|
];
|
|
//'reverse_charge', 'reverse_charge_valid'
|
|
|
|
protected $casts = [
|
|
'payment_data' => 'array',
|
|
'notice' => 'array',
|
|
//'reverse_charge' => 'bool'
|
|
];
|
|
|
|
use SoftDeletes;
|
|
protected $dates = ['deleted_at'];
|
|
|
|
|
|
public function user()
|
|
{
|
|
return $this->hasOne('App\User', 'account_id');
|
|
}
|
|
|
|
public function country()
|
|
{
|
|
return $this->belongsTo('App\Models\Country', 'country_id');
|
|
}
|
|
|
|
public function shipping_country()
|
|
{
|
|
return $this->belongsTo('App\Models\Country', 'shipping_country_id');
|
|
}
|
|
|
|
public function pre_phone()
|
|
{
|
|
return $this->belongsTo('App\Models\Country', 'pre_phone_id');
|
|
}
|
|
|
|
public function pre_mobil()
|
|
{
|
|
return $this->belongsTo('App\Models\Country', 'pre_mobil_id');
|
|
}
|
|
|
|
public function shipping_pre_phone()
|
|
{
|
|
return $this->belongsTo('App\Models\Country', 'shipping_pre_phone_id');
|
|
}
|
|
|
|
public function getBirthdayAttribute($value)
|
|
{
|
|
if (!$value) {
|
|
return "";
|
|
}
|
|
return Carbon::parse($value)->format(\Util::formatDateDB());
|
|
}
|
|
|
|
public function setBirthdayAttribute($value)
|
|
{
|
|
$this->attributes['birthday'] = isset($value) ? (new Carbon($value))->format('Y-m-d') : NULL;
|
|
}
|
|
|
|
public function getDataProtectionFormat()
|
|
{
|
|
if (!$this->attributes['data_protection']) {
|
|
return "";
|
|
}
|
|
return Carbon::parse($this->attributes['data_protection'])->format(\Util::formatDateTimeDB());
|
|
}
|
|
|
|
public function getAcceptContractFormat()
|
|
{
|
|
if (!$this->attributes['accept_contract']) {
|
|
return "";
|
|
}
|
|
return Carbon::parse($this->attributes['accept_contract'])->format(\Util::formatDateTimeDB());
|
|
}
|
|
|
|
public function getReverseChargeValidFormat()
|
|
{
|
|
if (!$this->attributes['reverse_charge_valid']) {
|
|
return "";
|
|
}
|
|
return Carbon::parse($this->attributes['reverse_charge_valid'])->format(\Util::formatDateTimeDB());
|
|
}
|
|
|
|
public function getCountryAttrAs($attr, $as = false)
|
|
{
|
|
if ($this->country) {
|
|
$val = $this->country->getAttrByKey($attr);
|
|
|
|
if ($val) {
|
|
if ($as) {
|
|
return $as;
|
|
}
|
|
return true;
|
|
}
|
|
}
|
|
return "";
|
|
}
|
|
|
|
public function setNotice($key, $value)
|
|
{
|
|
$notice = $this->notice;
|
|
$notice[$key] = $value;
|
|
$this->notice = $notice;
|
|
$this->save();
|
|
}
|
|
|
|
public function getNotice($key)
|
|
{
|
|
return isset($this->notice[$key]) ? $this->notice[$key] : false;
|
|
}
|
|
|
|
public function getPhoneNumber()
|
|
{
|
|
if ($this->mobil && $this->mobil !== "") {
|
|
return ($this->pre_mobil ? $this->pre_mobil->phone : '') . " " . $this->mobil;
|
|
}
|
|
if ($this->phone && $this->phone !== "") {
|
|
return ($this->pre_phone ? $this->pre_phone->phone : '') . " " . $this->phone;
|
|
}
|
|
}
|
|
|
|
public function getPhoneFull()
|
|
{
|
|
if ($this->phone && $this->phone !== "") {
|
|
return ($this->pre_phone ? $this->pre_phone->phone : '') . " " . $this->phone;
|
|
}
|
|
return "";
|
|
}
|
|
|
|
public function getMobilFull()
|
|
{
|
|
if ($this->mobil && $this->mobil !== "") {
|
|
return ($this->pre_mobil ? $this->pre_mobil->phone : '') . " " . $this->mobil;
|
|
}
|
|
return "";
|
|
}
|
|
|
|
public function getShippingPhoneFull()
|
|
{
|
|
if ($this->shipping_phone && $this->shipping_phone !== "") {
|
|
return ($this->shipping_pre_phone ? $this->shipping_pre_phone->phone : '') . " " . $this->shipping_phone;
|
|
}
|
|
return "";
|
|
}
|
|
}
|