OpenXE/classes/Modules/SubscriptionCycle/Service/SubscriptionCycleArticleService.php

132 lines
4.5 KiB
PHP
Raw Permalink Normal View History

2021-05-21 08:49:41 +02:00
<?php
declare(strict_types=1);
namespace Xentral\Modules\SubscriptionCycle\Service;
use Xentral\Components\Database\Database;
use Xentral\Modules\SubscriptionCycle\Data\SubscriptionCycleArticleData;
final class SubscriptionCycleArticleService
{
/** @var Database */
private $db;
/**
* @param Database $db
*/
public function __construct(Database $db)
{
$this->db = $db;
}
/**
* @param SubscriptionCycleArticleData $article
*
* @return int
*/
public function create(SubscriptionCycleArticleData $article): int
{
$sql =
'INSERT INTO `abrechnungsartikel` (
`sort`,
`artikel`,
`bezeichnung`,
`nummer`,
`menge`,
`preis`,
`steuerklasse`,
`rabatt`,
`abgerechnet`,
`startdatum`,
`lieferdatum`,
`abgerechnetbis`,
`wiederholend`,
`zahlzyklus`,
`abgrechnetam`,
`rechnung`,
`projekt`,
`adresse`,
`status`,
`bemerkung`,
`beschreibung`,
`dokument`,
`preisart`,
`enddatum`,
`angelegtvon`,
`angelegtam`,
`experte`,
`waehrung`,
`beschreibungersetzten`,
`gruppe`
) VALUES (
:sort,
:articleId,
:articleName,
:articleNumber,
:amount,
:price,
:taxClass,
:discount,
:cleared,
:startDate,
:deliveranceDate,
:clearedTill,
:repeating,
:payCycle,
:clearedOn,
:invoiceId,
:projectId,
:adressId,
:status,
:text,
:description,
:document,
:priceType,
:endDate,
:createdBy,
:createdDate,
:expert,
:currency,
:replaceDescription,
:subscriptionCycleGroupId
)';
$values = [
'sort' => $article->getSort(),
'articleId' => $article->getArticleId(),
'articleName' => $article->getArticleName(),
'articleNumber' => $article->getArticleNumber(),
'amount' => $article->getAmount(),
'price' => $article->getPrice(),
'taxClass' => $article->getTaxClass(),
'discount' => $article->getDiscount(),
'cleared' => $article->isCleared(),
'startDate' => $article->getStartDate(),
'deliveranceDate' => $article->getDeliveranceDate(),
'clearedTill' => $article->getClearedTill(),
'repeating' => $article->isRepeating(),
'payCycle' => $article->getPayCycle(),
'clearedOn' => $article->getClearedOn(),
'invoiceId' => $article->getInvoiceId(),
'projectId' => $article->getProjectId(),
'adressId' => $article->getAdressId(),
'status' => $article->getStatus(),
'text' => $article->getText(),
'description' => $article->getDescription(),
'document' => $article->getDocument(),
'priceType' => $article->getPriceType(),
'endDate' => $article->getEndDate(),
'createdBy' => $article->getCreatedBy(),
'createdDate' => $article->getCreatedDate(),
'expert' => $article->isExpert(),
'currency' => $article->getCurrency(),
'replaceDescription' => $article->isReplaceDescription(),
'subscriptionCycleGroupId' => $article->getSubscriptionCycleGroupId(),
];
$this->db->perform($sql, $values);
return $this->db->lastInsertId();
}
}