'id', 'text' => 'ID', 'modal' => false, 'table' => false], ['key' => 'ware', 'text' => 'Ware', 'required' => true, 'type' => 'autocomplete', 'table' => ['class' => 'text-nowrap', 'filter' => 'autocomplete'], 'modal' => [ 'apiUrl' => 'WarehouseArticle/autocomplete', 'type' => 'autocomplete', 'returnText' => true]], ['key' => 'anzahl', 'text' => 'Anzahl', 'required' => true, 'type' => 'number'], ['key' => 'verwendungszweck', 'text' => 'Verwendungszweck', 'required' => true], ['key' => 'create', 'text' => 'Beauftragt am', 'required' => true, 'modal' => false, 'table' => ['filter' => 'datepicker']], ['key' => 'createBy', 'text' => 'Beauftragt von', 'required' => true, 'table' => ['filter' => 'select'], 'modal' => ['visible' => false, 'type' => 'select', 'items' => []]], ['key' => 'distributorId', 'text' => 'Lieferant', 'required' => false, 'type' => 'autocomplete', 'table' => ['class' => 'text-nowrap', 'filter' => 'autocomplete'], 'modal' => [ 'apiUrl' => 'WarehouseDistributor/autocomplete', 'type' => 'autocomplete']], ['key' => 'order', 'text' => 'Bestellt am', 'required' => false, 'type' => 'datepicker', 'table' => ['filter' => 'datepicker']], ['key' => 'orderBy', 'text' => 'Bestellt von', 'required' => false, 'table' => ['filter' => 'select'], 'modal' => ['type' => 'select', 'items' => []]], ['key' => 'takeOver', 'text' => 'Übernommen am', 'required' => false, 'type' => 'datepicker', 'table' => ['filter' => 'datepicker']], ['key' => 'takeOverBy', 'text' => 'Übernommen von', 'required' => false, 'table' => ['filter' => 'select'], 'modal' => ['type' => 'select', 'items' => []]], ['key' => 'warehouseLocation', 'text' => 'Lagerort', 'required' => false, 'type' => 'varchar'], ['key' => 'canceled', 'text' => 'Storniert', 'required' => false, 'modal' => ['visible' => false, 'type' => 'select', 'items' => [['value' => 0, 'text' => 'Nein'], ['value' => 1, 'text' => 'Ja']]], 'table' => ['filter' => 'select']], ['key' => 'note', 'text' => 'Notiz', 'required' => false, 'type' => 'textarea'], ['key' => 'actions', 'text' => 'Aktionen', 'required' => false, 'modal' => false, 'table' => ['filter' => false, 'sortable' => false, 'class' => 'text-center']], ]; protected array $permissionCheck = ['WarehouseUser']; 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',]; protected array $additionalJSVariables = ['BASE_URL' => '/WarehouseOrderRequest', 'WAREHOUSE_ADMIN' => true]; protected function prepareCrudConfig() { // Fill Users in createBy column $userArray = array_map(function ($user) { return ['value' => intval($user->id), 'text' => $user->name]; }, UserModel::search(['employee' => true])); $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; // if this user can WarehouseAdmin is false then set modal false to warehouselocation, takeOverBy, takeOver, orderBy, order if (!$this->user->can(["WarehouseAdmin"])) { $warehouselocationColumn = array_search('warehouseLocation', array_column($this->columns, 'key')); $this->columns[$warehouselocationColumn]['modal']['visible'] = false; $takeOverByColumn = array_search('takeOverBy', array_column($this->columns, 'key')); $this->columns[$takeOverByColumn]['modal']['visible'] = false; $takeOverColumn = array_search('takeOver', array_column($this->columns, 'key')); $this->columns[$takeOverColumn]['modal']['visible'] = false; $orderByColumn = array_search('orderBy', array_column($this->columns, 'key')); $this->columns[$orderByColumn]['modal']['visible'] = false; $orderColumn = array_search('order', array_column($this->columns, 'key')); $this->columns[$orderColumn]['modal']['visible'] = false; } $this->additionalJSVariables['user_id'] = $this->user->id; if (!$this->user->can('WarehouseAdmin')) { $this->additionalJSVariables['WAREHOUSE_ADMIN'] = false; } } protected function customAutoCompleteWare($value) { if (!is_numeric($value)) return ['id' => $value, 'title' => $value]; $article = WarehouseArticleModel::get(intval($value)); return ['id' => $article->id, 'title' => $article->title]; } protected function beforeUpdate($postData): bool { (new WarehouseHistoryController)->create($postData, $this->mod); return true; } protected function afterCreate($postData): void { if ($_SERVER['HTTP_HOST'] == 'localhost') return; if (is_numeric($postData['ware'])) { $article = WarehouseArticleModel::get(intval($postData['ware'])); $postData['ware'] = $article->title; } $email = new Emailnotification(); $paddedId = str_pad($postData['id'], 5, '0', STR_PAD_LEFT); $email->setSubject("TheTool: Neue Interne Bestellung #$paddedId"); $body = "Hallo,\n\nes wurde eine neue interne Bestellung erstellt.\n\n"; $body .= "Bestellnummer: #$paddedId\n"; $body .= "Ware: " . $postData['ware'] . "\n"; $body .= "Anzahl: " . $postData['anzahl'] . "\n"; $body .= "Verwendungszweck: " . $postData['verwendungszweck'] . "\n"; $body .= "Beauftragt von: " . $this->user->name . "\n"; $body .= "Beauftragt am: " . date('d.m.Y H:i') . "\n"; $body .= "Notiz: " . $postData['note'] . "\n\n"; $email->setBody($body); $email->setFrom(TT_OUTGOING_EMAIL_2FA, TT_OUTGOING_EMAIL_2FA); $email->setTo("einkauf@xinon.at", "Einkauf"); $email->send(); } protected function cancelAction() { $id = $this->request->id; $cancel = $this->request->cancel; if (!is_numeric($id) || !is_numeric($cancel)) { self::returnJson(['error' => 'Invalid request']); } $order = (array) WarehouseOrderRequestModel::get($id); if (empty($order)) { self::returnJson(['error' => 'Order not found']); } // $cancel is either 0 for uncancelling or 1 for cancelling if ($cancel == 1) { $order['canceled'] = 1; } else { $order['canceled'] = 0; } $order['id'] = $id; if (!WarehouseOrderRequestModel::update($order)) { self::returnJson(['error' => 'Error updating order']); } self::returnJson(['success' => true, 'message' => 'Order updated']); } protected function getHistoryAction() { $this->prepareCrudConfig(); self::returnJson((new WarehouseHistoryController)->getHistory($this->request->id, $this->mod, $this->columns)); } }