fixed bug in eShop
This commit is contained in:
@@ -4,70 +4,57 @@ class WarehouseEShopController extends TTCrud {
|
|||||||
protected string $headerTitle = 'Energie Steiermark Shop';
|
protected string $headerTitle = 'Energie Steiermark Shop';
|
||||||
protected bool $createText = false;
|
protected bool $createText = false;
|
||||||
//@formatter:off
|
//@formatter:off
|
||||||
|
|
||||||
protected array $columns = [
|
protected array $columns = [
|
||||||
['key' => 'title', 'text' => 'Artikel', 'priority' => 11],
|
['key' => 'title', 'text' => 'Artikel', 'priority' => 11],
|
||||||
['key' => 'category', 'text' => 'Kategorie', 'table' => false],
|
['key' => 'category', 'text' => 'Kategorie', 'table' => false],
|
||||||
['key' => 'price', 'text' => 'Preis', 'table' => ['filter' => false, 'sortable' => false, 'class' => 'text-right']],
|
['key' => 'price', 'text' => 'Preis', 'table' => false],
|
||||||
['key' => 'amount', 'text' => 'Menge', 'table' => ['filter' => false, 'sortable' => false, 'class' => 'p-0 width-80'], 'priority' => 9],
|
['key' => 'amount', 'text' => 'Menge', 'table' => ['filter' => false, 'sortable' => false, 'class' => 'p-0 width-80'], 'priority' => 9],
|
||||||
['key' => 'add', 'text' => 'Hinzufügen', 'table' => ['filter' => false, 'sortable' => false, 'class' => 'width-120 text-center'], 'priority' => 5000]
|
['key' => 'add', 'text' => 'Hinzufügen', 'table' => ['filter' => false, 'sortable' => false, 'class' => 'width-120 text-center'], 'priority' => 5000]
|
||||||
];
|
];
|
||||||
//@formatter:on
|
//@formatter:on
|
||||||
protected array $permissionCheck = ['WarehouseEShop'];
|
protected array $permissionCheck = ['WarehouseEShop'];
|
||||||
protected array $additionalJSVariables = [];
|
|
||||||
|
|
||||||
protected function afterInit() {
|
protected function afterInit() {
|
||||||
if ($this->user->isAdmin()) {
|
if (!$this->user->isAdmin()) return;
|
||||||
if (isset($_GET['shop']) && in_array($_GET['shop'], ['e', 'sbidi'])) {
|
if (!$this->user->getFlag('WarehouseSelectedShop') && !isset($_GET['shop'])) self::sendError("Bitte wählen Sie einen Shop aus.");
|
||||||
$flag = new WorkerFlag($this->user->id, 'WarehouseSelectedShop');
|
|
||||||
$flag->value($_GET['shop']);
|
if (in_array($_GET['shop'], ['e', 'sbidi'])) {
|
||||||
$flag->save();
|
$flag = new WorkerFlag($this->user->id, 'WarehouseSelectedShop');
|
||||||
$this->user->address_id = ($_GET['shop'] === 'e') ? '209' : '9633';
|
$flag->value($_GET['shop']);
|
||||||
} elseif (!$this->user->getFlag('WarehouseSelectedShop')) self::sendError("Bitte wählen Sie einen Shop aus.");
|
$flag->save();
|
||||||
} else {
|
$this->user->address_id = ($_GET['shop'] === 'e') ? '209' : '9633';
|
||||||
$selectedShop = $this->user->getFlag('WarehouseSelectedShop')->value();
|
return;
|
||||||
if ($selectedShop) $this->user->address_id = ($selectedShop === 'e') ? '209' : '9633';
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$this->user->address_id = ($this->user->getFlag('WarehouseSelectedShop')->value() === 'e') ? '209' : '9633';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
protected function prepareCrudConfig() {
|
protected function prepareCrudConfig() {
|
||||||
if (!$this->user->can('WarehouseAdmin')) $this->columns[2]['table'] = false;
|
if (!in_array(intval($this->user->address_id), [209, 9633])) self::sendError("Keine Berechtigung für diesen Shop");
|
||||||
|
|
||||||
$this->additionalJSVariables['userAddressId'] = $this->user->address_id ?? null;
|
$this->additionalJSVariables['userAddressId'] = $this->user->address_id ?? null;
|
||||||
|
$this->headerTitle = $this->user->address_id == 209 ? 'Energie Steiermark Shop' : 'SBIDI Shop';
|
||||||
if ($this->user->address_id == 209) $this->headerTitle = 'Energie Steiermark Shop';
|
|
||||||
elseif ($this->user->address_id == 9633) $this->headerTitle = 'SBIDI Shop';
|
|
||||||
else self::sendError("Keine Berechtigung für diesen Shop");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getAction() {
|
public function getAction() {
|
||||||
|
if (!in_array(intval($this->user->address_id), [209, 9633])) self::sendError("Keine Berechtigung für diesen Shop");
|
||||||
|
|
||||||
$filter = $this->postData['filters'] ?? [];
|
$filter = $this->postData['filters'] ?? [];
|
||||||
$order = $this->postData['order'] ?? ['key' => null, 'order' => 'ASC'];
|
$order = $this->postData['order'] ?? ['key' => null, 'order' => 'ASC'];
|
||||||
$page = $this->postData['pagination']['page'] ?? 1;
|
$page = $this->postData['pagination']['page'] ?? 1;
|
||||||
$perPage = $this->postData['pagination']['per_page'] ?? 10;
|
$perPage = $this->postData['pagination']['per_page'] ?? 10;
|
||||||
|
|
||||||
$warehouseArticleFilter = $filter;
|
$shopType = (intval($this->user->address_id) === 209) ? 'EShop' : 'SbidiShop';
|
||||||
$warehousePacketFilter = $filter;
|
$filter["is{$shopType}"] = 1;
|
||||||
|
$filter["is{$shopType}Hide"] = 0;
|
||||||
|
|
||||||
if (!in_array(intval($this->user->address_id), [209, 9633])) self::sendError("Keine Berechtigung für diesen Shop");
|
$warehouseArticles = WarehouseArticleModel::getAll($filter, null, 0, $order);
|
||||||
|
$warehousePackets = WarehouseArticlePacketModel::getAll($filter, null, 0, $order);
|
||||||
|
|
||||||
$shopType = (intval($this->user->address_id) === 209) ? 'eShop' : 'sbidiShop';
|
$filteredAvailable = WarehouseArticlePacketModel::count($filter) + WarehouseArticleModel::count($filter);
|
||||||
$this->headerTitle = (intval($this->user->address_id) === 209) ? 'Energie Steiermark Shop' : 'SBIDI Shop';
|
|
||||||
|
|
||||||
$warehouseArticleFilter["is{$shopType}"] = 1;
|
|
||||||
$warehouseArticleFilter["is{$shopType}Hide"] = 0;
|
|
||||||
$warehousePacketFilter["is{$shopType}"] = 1;
|
|
||||||
$warehousePacketFilter["is{$shopType}Hide"] = 0;
|
|
||||||
|
|
||||||
$warehouseArticles = WarehouseArticleModel::getAll($warehouseArticleFilter, null, 0, $order);
|
|
||||||
$warehouseArticlesTotal = WarehouseArticleModel::count($warehouseArticleFilter);
|
|
||||||
$warehouseArticlesAvailable = WarehouseArticleModel::count($warehouseArticleFilter);
|
|
||||||
|
|
||||||
$warehousePackets = WarehouseArticlePacketModel::getAll($warehousePacketFilter, null, 0, $order);
|
|
||||||
$warehousePacketsTotal = WarehouseArticlePacketModel::count($warehousePacketFilter);
|
|
||||||
$warehousePacketsAvailable = WarehouseArticlePacketModel::count($warehousePacketFilter);
|
|
||||||
|
|
||||||
$filteredAvailable = $warehouseArticlesAvailable + $warehousePacketsAvailable;
|
|
||||||
$totalRows = $warehouseArticlesTotal + $warehousePacketsTotal;
|
|
||||||
$rows = [...$warehouseArticles, ...$warehousePackets];
|
$rows = [...$warehouseArticles, ...$warehousePackets];
|
||||||
|
|
||||||
usort($rows, function($a, $b) { return strcmp($a->title, $b->title); });
|
usort($rows, function($a, $b) { return strcmp($a->title, $b->title); });
|
||||||
@@ -79,8 +66,8 @@ class WarehouseEShopController extends TTCrud {
|
|||||||
"total_pages" => ceil($filteredAvailable / $perPage),
|
"total_pages" => ceil($filteredAvailable / $perPage),
|
||||||
"per_page" => $perPage,
|
"per_page" => $perPage,
|
||||||
"filtered_available" => $filteredAvailable,
|
"filtered_available" => $filteredAvailable,
|
||||||
"total_rows" => $totalRows
|
"total_rows" => $filteredAvailable
|
||||||
]
|
]
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Reference in New Issue
Block a user