Newer
Older
<?php
/**
* This file contains QUI\ERP\Accounting\Article
*/
namespace QUI\ERP\Accounting;
use QUI;
use QUI\ERP\Money\Price;
/**
* Class Article
*
* @package QUI\ERP\Accounting
*/
class Article implements ArticleInterface
{
/**
* @var array
*/

Henning Leutz
committed
/**
* Custom fields are data which field out the customer
* This data is not used for presentation or calculation
*
* in a custom field are only allowed string and numeric values
*
* @var array
*/
protected $customFields = [];
/**
* Custom data for plugins and modules
*
* @var array
*/
protected $customData = [];
/**
* Should the price displayed?
* default = yes
*/
protected $displayPrice = true;
/**
* @var bool
*/
protected $calculated = false;
/**
*/
protected $price;
/**
*/
protected $basisPrice;
/**
*/
protected $sum;
/**
* The calculated netto sum with quantity and discount
* @var float|int
*/
protected $nettoSum;
/**
* Sum from the article, without discount and with quantity
*
* @var float|int
*/
protected $nettoSubSum;
/**
* The article netto price, without discount, without quantity
* comes from article
*
* @var float|int
*/
protected $nettoPrice;
/**
* The article netto price, without discount, without quantity
* comes from calc
*
* @var float|int
*/
protected $nettoBasisPrice;
/**
* @var array
*/
protected $vatArray;
/**
*/
protected $isEuVat;
/**
*/
protected $isNetto;
/**
* @var ArticleDiscount|null
*/
protected $Discount = null;
/**
* @var null|QUI\Interfaces\Users\User
*/
protected $User = null;
/**
* @var null
*/
protected $Currency = null;
/**
* Article constructor.
*
* @param array $attributes - (id, articleNo, title, description, unitPrice, quantity, discount, customData)
public function __construct($attributes = [])
'id',
'articleNo',
'title',
'description',
'unitPrice',
'control',
'quantity'
foreach ($defaults as $key) {
if (isset($attributes[$key])) {
$this->attributes[$key] = $attributes[$key];
}
if (isset($attributes['vat']) && $attributes['vat'] !== '') {
$this->attributes['vat'] = $attributes['vat'];
if (isset($attributes['discount'])) {
$this->Discount = ArticleDiscount::unserialize($attributes['discount']);
}
if (isset($attributes['calculated'])) {
$calc = $attributes['calculated'];
$this->price = $calc['price'];
$this->basisPrice = $calc['basisPrice'];
$this->sum = $calc['sum'];
$this->nettoPrice = $calc['nettoPrice'];
$this->nettoBasisPrice = $calc['nettoBasisPrice'];
$this->nettoSum = $calc['nettoSum'];
$this->vatArray = $calc['vatArray'];
$this->isEuVat = $calc['isEuVat'];
$this->isNetto = $calc['isNetto'];
$this->calculated = true;

Henning Leutz
committed
if (isset($attributes['customFields']) && \is_array($attributes['customFields'])) {

Henning Leutz
committed
$this->customFields = $attributes['customFields'];
}
if (isset($attributes['customData']) && \is_array($attributes['customData'])) {
$this->customData = $attributes['customData'];
}
if (isset($attributes['displayPrice'])) {
$this->displayPrice = (bool)$attributes['displayPrice'];
}
if (isset($attributes['currency'])) {
try {
$this->Currency = QUI\ERP\Currency\Handler::getCurrency($attributes['currency']);
} catch (QUI\Exception $Exception) {
QUI\System\Log::writeDebugException($Exception);
}
}
if (!$this->Currency) {
$this->Currency = QUI\ERP\Currency\Handler::getDefaultCurrency();
}
/**
* Return the article view
*
* @return ArticleView
*/
public function getView()
{
return new ArticleView($this);
}
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
/**
* Return the Article ID
*
* @return mixed|string
*/
public function getId()
{
if (isset($this->attributes['id'])) {
return $this->attributes['id'];
}
return '';
}
/**
* Return the Article Number
*
* @return mixed|string
*/
public function getArticleNo()
{
if (isset($this->attributes['articleNo'])) {
return $this->attributes['articleNo'];
}
return '';
}
/**
* Returns the article title
*
* @return string
*/
public function getTitle()
{
if (isset($this->attributes['title'])) {
return $this->attributes['title'];
}
return '';
}

Henning Leutz
committed
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
/**
* Return the article image
*
* @return null|QUI\Projects\Media\Image
*/
public function getImage()
{
if (isset($this->attributes['image'])) {
try {
return QUI\Projects\Media\Utils::getImageByUrl(
$this->attributes['image']
);
} catch (QUI\Exception $Exception) {
QUI\System\Log::writeDebugException($Exception);
}
}
$Product = null;
try {
$Product = QUI\ERP\Products\Handler\Products::getProductByProductNo(
$this->getArticleNo()
);
} catch (QUI\Exception $Exception) {
QUI\System\Log::writeDebugException($Exception);
}
if (!empty($Product)) {
try {
return $Product->getImage();
} catch (QUI\Exception $Exception) {
}
}
try {
$Project = QUI::getRewrite()->getProject();
return $Project->getMedia()->getPlaceholderImage();
} catch (QUI\Exception $Exception) {
QUI\System\Log::writeDebugException($Exception);
}
return null;
}
/**
* Returns the article description
*
* @return string
*/
public function getDescription()
{
if (isset($this->attributes['description'])) {
return $this->attributes['description'];
}
return '';
}
/**
* Returns the article unit price
*
*/
public function getUnitPrice()
{
if (isset($this->attributes['unitPrice'])) {
$unitPrice = $this->attributes['unitPrice'];
return new Price($unitPrice, $this->Currency);
}
/**
* Returns the article total sum
*
*/
public function getSum()
{
$this->calc();
return new Price($this->sum, $this->Currency);
}
/**
* Return the VAT for the article
*
* @return int
*/
public function getVat()
{
if (isset($this->attributes['vat']) && $this->attributes['vat'] !== '') {
return (int)$this->attributes['vat'];
}
// check if product exists and has a vat
if (!empty($this->attributes['id'])) {
try {
$Area = null;
if ($this->getUser()) {
$Area = QUI\ERP\Areas\Utils::getAreaByCountry($this->getUser()->getCountry());
}
if (!$Area) {
$Area = QUI\ERP\Defaults::getArea();
}
$Product = QUI\ERP\Products\Handler\Products::getProduct($this->attributes['id']);
$Vat = $Product->getField(QUI\ERP\Products\Handler\Fields::FIELD_VAT);
$TaxType = new QUI\ERP\Tax\TaxType($Vat->getValue());
$TaxEntry = TaxUtils::getTaxEntry($TaxType, $Area);
return $TaxEntry->getValue();
} catch (QUI\Exception $Exception) {
QUI\System\Log::addDebug($Exception->getMessage());
}
}
try {
if ($this->getUser()) {
return QUI\ERP\Tax\Utils::getTaxByUser($this->getUser())->getValue();
}
// return default vat
$Area = QUI\ERP\Defaults::getArea();
$TaxType = QUI\ERP\Tax\Utils::getTaxTypeByArea($Area);
$TaxEntry = QUI\ERP\Tax\Utils::getTaxEntry($TaxType, $Area);
return $TaxEntry->getValue();
} catch (QUI\Exception $Exception) {
QUI\System\Log::addCritical($Exception->getMessage());
QUI\System\Log::writeException($Exception);
return 0;
}
}
/**
* @return null|QUI\Interfaces\Users\User
*/
public function getUser()
{
return $this->User;
}
/**
* Set the user to the product, this user will be used for the calculation
*
* @param QUI\Interfaces\Users\User $User
*/
public function setUser(QUI\Interfaces\Users\User $User)
{
$this->calculated = false;
$this->User = $User;
/**
* Return the currency of the article
*
* @return QUI\ERP\Currency\Currency|null
*/
public function getCurrency()
{
return $this->Currency;
}
/**
* Set the currency for the article
*
* @param QUI\ERP\Currency\Currency $Currency
*/
public function setCurrency(QUI\ERP\Currency\Currency $Currency)
{
$this->Currency = $Currency;
}
/**
* Returns the article quantity
*
*/
public function getQuantity()
{
if (isset($this->attributes['quantity'])) {
return $this->attributes['quantity'];
}
return 1;
}
/**
* Return the price from the article
*
* @return Price
*/
public function getPrice()
{
$this->calc();
return new Price($this->sum, $this->Currency);
/**
* @return bool
*/
public function displayPrice()
{
return $this->displayPrice;
}
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
* Set a discount to the article
*
* @param int $discount
* @param int $discountType - default = complement
*
* @todo überdenken, ganzer artikel ist eigentlich nicht änderbar
*/
public function setDiscount($discount, $discountType = Calc::CALCULATION_COMPLEMENT)
{
switch ($discountType) {
case Calc::CALCULATION_PERCENTAGE:
case Calc::CALCULATION_COMPLEMENT:
break;
default:
$discountType = Calc::CALCULATION_COMPLEMENT;
}
$this->Discount = new ArticleDiscount($discount, $discountType);
}
/**
* Return the current discount
*
* @return ArticleDiscount|null
*/
public function getDiscount()
{
return $this->Discount;
}
/**
* Has the article a discount
*
* @return bool
*/
public function hasDiscount()
{
return !!$this->getDiscount();
}
//endregion
/**
* @param null|Calc|QUI\ERP\User $Instance
* @return self
*/
{
if ($this->calculated) {
return $this;
}
$self = $this;
if ($Instance instanceof QUI\ERP\User) {
$Calc = Calc::getInstance($Instance);
} elseif ($Instance instanceof Calc) {
$Calc = $Instance;
} else {
$Calc = Calc::getInstance();
if ($this->getUser()) {
$Calc->setUser($this->getUser());
}
$Calc->calcArticlePrice($this, function ($data) use ($self) {
$self->price = $data['price'];
$self->basisPrice = $data['basisPrice'];
$self->sum = $data['sum'];
$self->nettoPrice = $data['nettoPrice'];
$self->nettoBasisPrice = $data['nettoBasisPrice'];
$self->nettoSubSum = $data['nettoSubSum'];
$self->nettoSum = $data['nettoSum'];
$self->vatArray = $data['vatArray'];
$self->isEuVat = $data['isEuVat'];
$self->isNetto = $data['isNetto'];
$self->calculated = true;
});
return $this;
}
/**
* Return the article as an array
*
* @return array
*/
public function toArray()
{
if (isset($this->attributes['vat']) && $this->attributes['vat'] !== '') {
$vat = (int)$this->attributes['vat'];
}
if ($this->hasDiscount()) {
$discount = $this->Discount->toJSON();
}
if (!empty($this->attributes['control'])) {
$class = $this->attributes['control'];
}

Henning Leutz
committed
'id' => $this->getId(),
'title' => $this->getTitle(),
'articleNo' => $this->getArticleNo(),
'description' => $this->getDescription(),
'unitPrice' => $this->getUnitPrice()->value(),
'displayPrice' => $this->displayPrice(),

Henning Leutz
committed
'quantity' => $this->getQuantity(),
'sum' => $this->getSum()->value(),
'vat' => $vat,
'discount' => $discount,
'control' => $this->attributes['control'],
'class' => $class,
'customFields' => $this->customFields,
'customData' => $this->customData,

Henning Leutz
committed
'calculated' => [
'price' => $this->price,
'basisPrice' => $this->basisPrice,
'sum' => $this->sum,
'nettoPrice' => $this->nettoPrice,
'nettoBasisPrice' => $this->nettoBasisPrice,
'nettoSubSum' => $this->nettoSubSum,
'nettoSum' => $this->nettoSum,
'vatArray' => $this->vatArray,
'isEuVat' => $this->isEuVat,
'isNetto' => $this->isNetto

Henning Leutz
committed
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
//region custom fields
/**
* Return a article custom field
*
* @param string $key
* @return mixed|null
*/
public function getCustomField($key)
{
if (isset($this->customFields[$key])) {
return $this->customFields[$key];
}
return null;
}
/**
* @return array
*/
public function getCustomFields()
{
return $this->customFields;
}
/**
* @return array
*/
public function getCustomData()
{
return $this->customData;
}

Henning Leutz
committed
//endregion