From 2a3ddf9a9288f7386b82c65f69bffd5ca8d2e029 Mon Sep 17 00:00:00 2001 From: Luca Haid Date: Mon, 23 Dec 2024 09:33:42 +0100 Subject: [PATCH] added new orderrequest module --- .../WarehouseOrderRequest.php | 9 +++ .../WarehouseOrderRequestController.php | 58 +++++++++++++++++++ .../WarehouseOrderRequestModel.php | 15 +++++ .../20241223090000_warehouse_modify_7.php | 33 +++++++++++ 4 files changed, 115 insertions(+) create mode 100644 application/WarehouseOrderRequest/WarehouseOrderRequest.php create mode 100644 application/WarehouseOrderRequest/WarehouseOrderRequestController.php create mode 100644 application/WarehouseOrderRequest/WarehouseOrderRequestModel.php create mode 100644 db/migrations/20241223090000_warehouse_modify_7.php diff --git a/application/WarehouseOrderRequest/WarehouseOrderRequest.php b/application/WarehouseOrderRequest/WarehouseOrderRequest.php new file mode 100644 index 000000000..01379d254 --- /dev/null +++ b/application/WarehouseOrderRequest/WarehouseOrderRequest.php @@ -0,0 +1,9 @@ + 'id', 'text' => 'ID', 'modal' => false], + ['key' => 'anzahl', 'text' => 'Anzahl', 'required' => true, 'type' => 'number'], + ['key' => 'ware', 'text' => 'Ware', 'required' => true], + ['key' => 'verwendungszweck', 'text' => 'Verwendungszweck', 'required' => true], + ['key' => 'create', 'text' => 'Erstellt am', 'required' => true, 'modal' => false, 'filter' => 'datetime'], + ['key' => 'createBy', 'text' => 'Beauftragt von', 'required' => true, 'table' => ['filter' => 'select'], 'modal' => ['visible' => false, 'type' => 'select', 'items' => []]], + ['key' => 'distributorId', 'text' => 'Lieferant', 'required' => true, 'type' => 'autocomplete', 'table' => ['class' => 'text-nowrap', 'filter' => 'autocomplete'], 'modal' => [ + 'apiUrl' => 'WarehouseDistributor/autocomplete', 'items' => 'WarehouseDistributor/autocomplete', 'type' => 'autocomplete']], + ['key' => 'order', 'text' => 'Bestellt am', 'required' => false, 'filter' => 'datetime'], + ['key' => 'orderBy', 'text' => 'Bestellt von', 'required' => false, 'table' => ['filter' => 'select'], 'modal' => ['type' => 'select', 'items' => []]], + ['key' => 'takeOver', 'text' => 'Übernommen am', 'required' => false, 'filter' => 'datetime'], + ['key' => 'takeOverBy', 'text' => 'Übernommen von', 'required' => false, 'table' => ['filter' => 'select'], 'modal' => ['type' => 'select', 'items' => []]], + ['key' => 'warehouseLocation', 'text' => 'Lagerort', 'required' => false, 'type' => 'varchar'], + ['key' => 'note', 'text' => 'Notiz', 'required' => false, 'type' => 'text'], + ['key' => 'actions', 'text' => 'Aktionen', 'required' => false, 'modal' => false, 'table' => ['filter' => false, 'sortable' => false, 'class' => 'text-center']], + ]; + + protected array $additionalActions = [['key' => 'openHistory', 'title' => 'Historie', 'class' => 'fas fa-history text-primary']]; + + protected array $infoMessages = ['create' => 'Bestellwunsch wurde erstellt.', + 'update' => 'Bestellwunsch wurde aktualisiert', + 'delete' => 'Bestellwunsch wurde gelöscht', + 'noChanges' => 'Keine Änderungen',]; + + public function permissionCheck(): bool { + return $this->user->can(["WarehouseUser"]); + } + + protected function prepareCrudConfig() { + // Fill Users in createBy column + $userArray = array_map(function ($user) { + return ['value' => intval($user->id), 'text' => $user->name]; + }, UserModel::search()); + $createByColumn = array_search('createBy', array_column($this->columns, 'key')); + $this->columns[$createByColumn]['modal']['items'] = $userArray; + $orderByColumn = array_search('orderBy', array_column($this->columns, 'key')); + $this->columns[$orderByColumn]['modal']['items'] = $userArray; + $takeOverByColumn = array_search('takeOverBy', array_column($this->columns, 'key')); + $this->columns[$takeOverByColumn]['modal']['items'] = $userArray; + } + + protected function beforeUpdate($postData): bool { + (new WarehouseHistoryController)->create($postData, $this->mod); + return true; + } + + protected function getHistoryAction() { + self::returnJson((new WarehouseHistoryController)->getHistory($this->request->id, $this->mod, $this->columns)); + } +} \ No newline at end of file diff --git a/application/WarehouseOrderRequest/WarehouseOrderRequestModel.php b/application/WarehouseOrderRequest/WarehouseOrderRequestModel.php new file mode 100644 index 000000000..84e4926cb --- /dev/null +++ b/application/WarehouseOrderRequest/WarehouseOrderRequestModel.php @@ -0,0 +1,15 @@ +getEnvironment() == "thetool") { + $table = $this->table("WarehouseOrderRequest"); + $table->addColumn("anzahl", "integer", ["null" => false]) + ->addColumn("ware", "string", ["null" => false, "limit" => 255]) + ->addColumn("verwendungszweck", "text", ["null" => false]) + ->addColumn("create", "integer", ["null" => false]) + ->addColumn("createBy", "integer", ["null" => false]) + ->addColumn("distributorId", "integer", ["null" => false]) + ->addColumn("order", "integer", ["null" => true]) + ->addColumn("orderBy", "integer", ["null" => true]) + ->addColumn("takeOver", "integer", ["null" => true]) + ->addColumn("takeOverBy", "integer", ["null" => true]) + ->addColumn("warehouseLocation", "string", ["null" => true, "limit" => 255]) + ->addColumn("note", "text", ["null" => true]) + ->create(); + } + } + + public function down(): void + { + if ($this->getEnvironment() == "thetool") { + $this->table("WarehouseOrderRequest")->drop()->save(); + } + } +}