1
0
mirror of https://github.com/invoiceninja/invoiceninja.git synced 2024-11-14 07:02:34 +01:00
invoiceninja/app/DataMapper/ClientSettings.php

106 lines
2.3 KiB
PHP
Raw Normal View History

<?php
2019-05-11 05:32:07 +02:00
/**
* Invoice Ninja (https://invoiceninja.com)
*
* @link https://github.com/invoiceninja/invoiceninja source repository
*
* @copyright Copyright (c) 2019. Invoice Ninja LLC (https://invoiceninja.com)
*
* @license https://opensource.org/licenses/AAL
*/
namespace App\DataMapper;
use App\DataMapper\ClientSettings;
use App\DataMapper\CompanySettings;
use App\Models\Client;
use App\Utils\TranslationHelper;
/**
* ClientSettings
*
* Client settings are built as a superset of Company Settings
*
* If no client settings is specified, the default company setting is used.
*
* Client settings are passed down to the entity level where they can be further customized and then saved
* into the settings column of the entity, so there is no need to create additional entity level settings handlers.
*
*/
class ClientSettings extends BaseSettings
{
2019-04-29 00:40:38 +02:00
/**
2019-04-29 02:54:26 +02:00
* Settings which which are unique to client settings
*/
public $industry_id;
public $size_id;
2019-09-19 07:50:05 +02:00
public static $casts = [
'industry_id' => 'string',
'size_id' => 'string',
];
2019-09-18 14:43:37 +02:00
/**
* Cast object values and return entire class
* prevents missing properties from not being returned
* and always ensure an up to date class is returned
*
* @return \stdClass
*/
public function __construct($obj)
{
parent::__construct($obj);
}
/**
*
* Default Client Settings scaffold
*
* @return \stdClass
*
*/
public static function defaults() : \stdClass
{
2019-09-19 07:50:05 +02:00
$data = (object)[
'entity' => (string)Client::class,
'industry_id' => '',
'size_id' => '',
];
2019-09-19 07:50:05 +02:00
return self::setCasts($data, self::$casts);
}
/**
* Merges settings from Company to Client
*
* @param \stdClass $company_settings
* @param \stdClass $client_settings
* @return \stdClass of merged settings
*/
public static function buildClientSettings($company_settings, $client_settings)
{
2019-09-19 07:50:05 +02:00
foreach($company_settings as $key => $value)
{
2019-09-19 07:50:05 +02:00
/* pseudo code
if the property exists and is a string BUT has no length, treat it as TRUE
*/
if( ( (property_exists($client_settings, $key) && is_string($client_settings->{$key}) && (iconv_strlen($client_settings->{$key}) <1)))
|| !isset($client_settings->{$key})
&& property_exists($company_settings, $key)) {
$client_settings->{$key} = $company_settings->{$key};
2019-04-24 12:01:40 +02:00
}
}
return $client_settings;
}
}