2021-02-18 14:54:00 +01:00
|
|
|
<?php
|
|
|
|
|
|
|
|
declare(strict_types=1);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Copyright (C) 2021 Daniel Siepmann <coding@daniel-siepmann.de>
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public License
|
|
|
|
* as published by the Free Software Foundation; either version 2
|
|
|
|
* of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program; if not, write to the Free Software
|
|
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
|
|
|
|
* 02110-1301, USA.
|
|
|
|
*/
|
|
|
|
|
2021-08-10 09:38:59 +02:00
|
|
|
namespace WerkraumMedia\ThueCat\Domain\Model\Frontend;
|
|
|
|
|
2021-08-23 16:23:23 +02:00
|
|
|
use TYPO3\CMS\Core\Utility\ArrayUtility;
|
|
|
|
|
2021-02-18 14:54:00 +01:00
|
|
|
class Offer
|
|
|
|
{
|
2022-09-29 14:33:19 +02:00
|
|
|
/**
|
|
|
|
* @param string[] $types
|
2023-12-04 15:37:57 +01:00
|
|
|
* @param mixed[] $prices
|
2022-09-29 14:33:19 +02:00
|
|
|
*/
|
2021-02-18 14:54:00 +01:00
|
|
|
private function __construct(
|
2023-12-04 15:37:57 +01:00
|
|
|
private readonly string $title,
|
|
|
|
private array $types,
|
|
|
|
private readonly string $description,
|
|
|
|
private readonly array $prices
|
2021-02-18 14:54:00 +01:00
|
|
|
) {
|
|
|
|
}
|
|
|
|
|
2023-12-04 15:37:57 +01:00
|
|
|
public static function createFromArray(array $rawData): Offer
|
2021-02-18 14:54:00 +01:00
|
|
|
{
|
|
|
|
$prices = [];
|
2021-08-23 16:23:23 +02:00
|
|
|
|
|
|
|
foreach (ArrayUtility::sortArraysByKey($rawData['prices'], 'title') as $price) {
|
2021-02-18 14:54:00 +01:00
|
|
|
$prices[] = Price::createFromArray($price);
|
|
|
|
}
|
|
|
|
|
2022-09-29 14:33:19 +02:00
|
|
|
$types = $rawData['types'] ?? $rawData['type'] ?? [];
|
|
|
|
// Handle old legacy saved values which were a single string saves as 'type' instead of 'types'.
|
|
|
|
if (is_string($types)) {
|
|
|
|
$types = [$types];
|
|
|
|
}
|
|
|
|
|
2021-02-18 14:54:00 +01:00
|
|
|
return new self(
|
|
|
|
$rawData['title'],
|
2022-09-29 14:33:19 +02:00
|
|
|
$types,
|
2021-02-18 14:54:00 +01:00
|
|
|
$rawData['description'],
|
|
|
|
$prices
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getTitle(): string
|
|
|
|
{
|
|
|
|
return $this->title;
|
|
|
|
}
|
|
|
|
|
2021-09-13 10:32:12 +02:00
|
|
|
public function getType(): string
|
|
|
|
{
|
2022-09-29 14:33:19 +02:00
|
|
|
$offerTypes = array_filter($this->types, function (string $type) {
|
2023-11-30 13:52:23 +01:00
|
|
|
return str_contains($type, 'Offer');
|
2022-09-29 14:33:19 +02:00
|
|
|
});
|
|
|
|
// Ensure clean index
|
|
|
|
$offerTypes = array_values($offerTypes);
|
|
|
|
|
|
|
|
if ($offerTypes !== []) {
|
|
|
|
return $offerTypes[0];
|
|
|
|
}
|
|
|
|
|
|
|
|
return $this->types[0] ?? '';
|
2021-09-13 10:32:12 +02:00
|
|
|
}
|
|
|
|
|
2021-02-18 14:54:00 +01:00
|
|
|
public function getDescription(): string
|
|
|
|
{
|
|
|
|
return $this->description;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getPrices(): array
|
|
|
|
{
|
|
|
|
return $this->prices;
|
|
|
|
}
|
|
|
|
}
|