mirror of
https://github.com/werkraum-media/thuecat.git
synced 2024-12-27 06:16:11 +01:00
Daniel Siepmann
2fd4b1bc2f
The import resulted in an exception if there was an array of types instead of a string. Both situations are now handled and API of models is kept. Existing imported data is also kept.
119 lines
2.8 KiB
PHP
119 lines
2.8 KiB
PHP
<?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.
|
|
*/
|
|
|
|
namespace WerkraumMedia\ThueCat\Domain\Model\Frontend;
|
|
|
|
use TYPO3\CMS\Core\Utility\ArrayUtility;
|
|
|
|
class Offer
|
|
{
|
|
/**
|
|
* @var string
|
|
*/
|
|
private $title;
|
|
|
|
/**
|
|
* @var string[]
|
|
*/
|
|
private $types;
|
|
|
|
/**
|
|
* @var string
|
|
*/
|
|
private $description;
|
|
|
|
/**
|
|
* @var mixed[]
|
|
*/
|
|
private $prices;
|
|
|
|
/**
|
|
* @param string[] $types
|
|
*/
|
|
private function __construct(
|
|
string $title,
|
|
array $types,
|
|
string $description,
|
|
array $prices
|
|
) {
|
|
$this->title = $title;
|
|
$this->types = $types;
|
|
$this->description = $description;
|
|
$this->prices = $prices;
|
|
}
|
|
|
|
/**
|
|
* @return Offer
|
|
*/
|
|
public static function createFromArray(array $rawData)
|
|
{
|
|
$prices = [];
|
|
|
|
foreach (ArrayUtility::sortArraysByKey($rawData['prices'], 'title') as $price) {
|
|
$prices[] = Price::createFromArray($price);
|
|
}
|
|
|
|
$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];
|
|
}
|
|
|
|
return new self(
|
|
$rawData['title'],
|
|
$types,
|
|
$rawData['description'],
|
|
$prices
|
|
);
|
|
}
|
|
|
|
public function getTitle(): string
|
|
{
|
|
return $this->title;
|
|
}
|
|
|
|
public function getType(): string
|
|
{
|
|
$offerTypes = array_filter($this->types, function (string $type) {
|
|
return strpos($type, 'Offer') !== false;
|
|
});
|
|
// Ensure clean index
|
|
$offerTypes = array_values($offerTypes);
|
|
|
|
if ($offerTypes !== []) {
|
|
return $offerTypes[0];
|
|
}
|
|
|
|
return $this->types[0] ?? '';
|
|
}
|
|
|
|
public function getDescription(): string
|
|
{
|
|
return $this->description;
|
|
}
|
|
|
|
public function getPrices(): array
|
|
{
|
|
return $this->prices;
|
|
}
|
|
}
|