mirror of
https://github.com/OpenXE-org/OpenXE.git
synced 2025-01-15 16:21:14 +01:00
132 lines
4.5 KiB
PHP
132 lines
4.5 KiB
PHP
|
<?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();
|
||
|
}
|
||
|
}
|