mirror of
https://github.com/OpenXE-org/OpenXE.git
synced 2025-01-07 20:40:28 +01:00
180 lines
4.8 KiB
PHP
180 lines
4.8 KiB
PHP
|
<?php
|
||
|
|
||
|
declare(strict_types=1);
|
||
|
|
||
|
namespace Xentral\Modules\PartialDelivery\Service;
|
||
|
|
||
|
use Xentral\Components\Database\Database;
|
||
|
|
||
|
class PartialDeliveryService
|
||
|
{
|
||
|
private const PARTIAL_DELIVERY_SETUP_FIELDS = [
|
||
|
'aktion',
|
||
|
'internet',
|
||
|
'internebezeichnung',
|
||
|
'art',
|
||
|
'ust_ok',
|
||
|
'keinsteuersatz',
|
||
|
'ustid',
|
||
|
'projekt',
|
||
|
'aktion',
|
||
|
'angebotid',
|
||
|
'angebot',
|
||
|
'ihrebestellnummer',
|
||
|
'standardlager',
|
||
|
'kommissionskonsignationslager',
|
||
|
'shopextid',
|
||
|
'shop',
|
||
|
'shopextstatus',
|
||
|
];
|
||
|
|
||
|
/** @var Database $database */
|
||
|
private $database;
|
||
|
|
||
|
/**
|
||
|
* @param Database $database
|
||
|
*/
|
||
|
public function __construct(Database $database)
|
||
|
{
|
||
|
$this->database = $database;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @param int $partialDeliveryId
|
||
|
*
|
||
|
* @return int
|
||
|
*/
|
||
|
public function getParentIdRecursive(int $partialDeliveryId): int
|
||
|
{
|
||
|
$timeout = 0;
|
||
|
$parentId = $partialDeliveryId;
|
||
|
$sql = 'SELECT `teillieferungvon` FROM `auftrag` WHERE `id`= :parent_id LIMIT 1';
|
||
|
while ($timeout < 100) {
|
||
|
$currentParentId = (int)$this->database->fetchValue($sql, ['parent_id' => $parentId]);
|
||
|
if ($currentParentId <= 0) {
|
||
|
break;
|
||
|
}
|
||
|
$parentId = $currentParentId;
|
||
|
$timeout++;
|
||
|
}
|
||
|
|
||
|
return $parentId;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @param int $deliveryNoteId
|
||
|
*
|
||
|
* @return array
|
||
|
*/
|
||
|
public function getOrderToDeliveryNotePositionsMap(int $deliveryNoteId): array
|
||
|
{
|
||
|
$sqlStatement = 'SELECT lp.auftrag_position_id, lp.id
|
||
|
FROM `lieferschein_position` AS `lp`
|
||
|
WHERE lp.lieferschein = :delivery_note_id AND lp.auftrag_position_id > 0
|
||
|
ORDER by lp.sort';
|
||
|
return $this->database->fetchPairs($sqlStatement, ['delivery_note_id' => $deliveryNoteId]);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @param array $deliveryNotePositionsDelta
|
||
|
* @param array $orderToDeliveryNotePositionMap
|
||
|
*
|
||
|
* @return array
|
||
|
*/
|
||
|
public function mapDeltaToOrderPositions(
|
||
|
array $deliveryNotePositionsDelta,
|
||
|
array $orderToDeliveryNotePositionMap
|
||
|
): array
|
||
|
{
|
||
|
$orderPositionsDelta = [];
|
||
|
$flippedMap = array_flip($orderToDeliveryNotePositionMap);
|
||
|
foreach ($deliveryNotePositionsDelta as $key => $value) {
|
||
|
if (in_array($key, $orderToDeliveryNotePositionMap, false)) {
|
||
|
$orderPositionsDelta[$flippedMap[$key]] = $value;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
return $orderPositionsDelta;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @param int $orderId
|
||
|
* @param array $data
|
||
|
*
|
||
|
* @return void
|
||
|
*/
|
||
|
private function updatePartialDelivery(int $orderId, array $data): void
|
||
|
{
|
||
|
$update = ($this->database->update())
|
||
|
->table('auftrag')
|
||
|
->cols($data)
|
||
|
->where('id = :order_id')
|
||
|
->getStatement();
|
||
|
$data['order_id'] = $orderId;
|
||
|
$this->database->perform($update, $data);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @param int $originalOrderId
|
||
|
* @param int $partialDeliveryId
|
||
|
*
|
||
|
* @return int
|
||
|
*/
|
||
|
public function setupPartialDeliveryAfterCreation(int $originalOrderId, int $partialDeliveryId): int
|
||
|
{
|
||
|
$setupValues = $this->getSetupValues($originalOrderId);
|
||
|
$this->updatePartialDelivery($partialDeliveryId, $setupValues);
|
||
|
|
||
|
return array_key_exists('projekt', $setupValues) ? (int)$setupValues['projekt'] : 0;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @param int $orderId
|
||
|
*
|
||
|
* @return array
|
||
|
*/
|
||
|
private function getSetupValues(int $orderId): array
|
||
|
{
|
||
|
$select = ($this->database->select())
|
||
|
->cols(self::PARTIAL_DELIVERY_SETUP_FIELDS)
|
||
|
->from('auftrag')
|
||
|
->where('id = :order_id')
|
||
|
->getStatement();
|
||
|
return $this->database->fetchRow($select, ['order_id' => $orderId]);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @param int $positionId
|
||
|
* @param array $fields
|
||
|
*
|
||
|
* @return void
|
||
|
*/
|
||
|
public function updateOrderPositionAttributes(int $positionId, array $fields): void
|
||
|
{
|
||
|
// these fields must not be overwritten
|
||
|
$restrictedFields = [
|
||
|
'id',
|
||
|
'menge',
|
||
|
'auftrag',
|
||
|
'sort',
|
||
|
'artikel',
|
||
|
'webid',
|
||
|
'explodiert',
|
||
|
'explodiert_parent',
|
||
|
];
|
||
|
foreach ($restrictedFields as $restrictedField) {
|
||
|
unset($fields[$restrictedField]);
|
||
|
}
|
||
|
if (!isset($fields['steuersatz'])) {
|
||
|
$fields['steuersatz'] = null;
|
||
|
}
|
||
|
$update = ($this->database->update())
|
||
|
->table('auftrag_position')
|
||
|
->cols($fields)
|
||
|
->where('id = :position_id')
|
||
|
->getStatement();
|
||
|
$fields['position_id'] = $positionId;
|
||
|
$this->database->perform($update, $fields);
|
||
|
}
|
||
|
}
|