OpenXE/www/pages/versandarten.php

837 lines
27 KiB
PHP
Raw Permalink Normal View History

<?php
2023-02-28 13:36:25 +01:00
/*
* SPDX-FileCopyrightText: 2022 Andreas Palm
* SPDX-FileCopyrightText: 2019 Xentral (c) Xentral ERP Software GmbH, Fuggerstrasse 11, D-86150 Augsburg, Germany
*
* SPDX-License-Identifier: LicenseRef-EGPL-3.1
*/
2021-05-21 08:49:41 +02:00
/*
**** COPYRIGHT & LICENSE NOTICE *** DO NOT REMOVE ****
*
2023-03-23 23:22:45 +01:00
* Xentral (c) Xentral ERP Software GmbH, Fuggerstrasse 11, D-86150 Augsburg, * Germany 2019
2021-05-21 08:49:41 +02:00
*
* This file is licensed under the Embedded Projects General Public License *Version 3.1.
*
* You should have received a copy of this license from your vendor and/or *along with this file; If not, please visit www.wawision.de/Lizenzhinweis
* to obtain the text of the corresponding license version.
*
**** END OF COPYRIGHT & LICENSE NOTICE *** DO NOT REMOVE ****
*/
?>
2021-05-21 08:49:41 +02:00
<?php
use Xentral\Components\Http\JsonResponse;
use Xentral\Components\Http\Response;
2021-05-21 08:49:41 +02:00
use Xentral\Widgets\ClickByClickAssistant\VueUtil;
class Versandarten {
const MODULE_NAME = 'ShippingMethod';
2023-01-29 23:33:33 +01:00
var ApplicationCore $app;
2021-05-21 08:49:41 +02:00
/** @var string[] $stylesheet */
public array $stylesheet = [
2021-05-21 08:49:41 +02:00
'./classes/Modules/Appstore/www/css/tilegrid.css',
];
/** @var string[] $javascript */
public array $javascript = [
2021-05-21 08:49:41 +02:00
'./classes/Modules/ShippingMethod/www/js/shipping_method_create.js',
];
/**
* Versandarten constructor.
*
2023-01-29 23:33:33 +01:00
* @param ApplicationCore $app
2021-05-21 08:49:41 +02:00
* @param bool $intern
*/
2023-01-29 23:33:33 +01:00
public function __construct(ApplicationCore $app, bool $intern = false)
2021-05-21 08:49:41 +02:00
{
$this->app=$app;
if($intern) {
return;
}
$this->app->ActionHandlerInit($this);
// ab hier alle Action Handler definieren die das Modul hat
$this->app->ActionHandler("create", "VersandartenCreate");
$this->app->ActionHandler("edit", "VersandartenEdit");
$this->app->ActionHandler("list", "VersandartenList");
$this->app->ActionHandler("delete", "VersandartenDelete");
$this->app->ActionHandler("copy", 'VersandartenCopy');
$this->app->ActionHandler('createShipment', 'CreateShipment');
2021-05-21 08:49:41 +02:00
$this->app->ActionHandlerListen($app);
}
public function Install(): void
{
$this->app->erp->GetVersandartAuftrag();
}
/** @noinspection PhpUnused */
public function VersandartenCopy():void
2021-05-21 08:49:41 +02:00
{
$id = (int)$this->app->Secure->GetGET('id');
$id = $this->app->DB->Select("SELECT `id` FROM `versandarten` WHERE `id` = $id LIMIT 1");
2021-05-21 08:49:41 +02:00
if(!$id) {
$this->app->Location->execute('index.php?module=versandarten&action=list');
}
$newId = $this->app->DB->MysqlCopyRow('versandarten', 'id', $id);
if($newId) {
2021-05-21 08:49:41 +02:00
$this->app->DB->Update(
"UPDATE `versandarten` set `aktiv` = 0, `ausprojekt` = 0 WHERE `id` = $newId LIMIT 1"
2021-05-21 08:49:41 +02:00
);
}
$this->app->Location->execute('index.php?module=versandarten&action=edit&id='.$newId);
2021-05-21 08:49:41 +02:00
}
/** @noinspection PhpUnused */
2021-05-21 08:49:41 +02:00
public function VersandartenList(): void
{
$this->app->erp->MenuEintrag('index.php?module=versandarten&action=create','Neue Versandart anlegen');
$this->app->erp->MenuEintrag('index.php?module=versandarten&action=list','&Uuml;bersicht');
$this->app->YUI->TableSearch('TAB1','versandarten_list', 'show','','',basename(__FILE__), __CLASS__);
$this->app->Tpl->Parse('PAGE','versandarten_list.tpl');
}
public static function TableSearch(Application $app, string $name, array $erlaubtevars): array
2021-05-21 08:49:41 +02:00
{
// in dieses switch alle lokalen Tabellen (diese Live Tabellen mit Suche etc.) für dieses Modul
switch($name) {
case 'versandarten_list':
$allowed['versandarten'] = array('list');
$allowed['einstellungen'] = array('category');
$isSettingAction = $app->Secure->GetGET('module') === 'einstellungen'
|| $app->Secure->GetGET('smodule') === 'einstellungen';
if($isSettingAction) {
$maxrows = 10;
2021-05-21 08:49:41 +02:00
}
$heading = array('Bezeichnung', 'Typ','Modul', 'Projekt', 'Men&uuml;');
$width = array('39%', '20%', '20%','20%','5%');
2021-05-21 08:49:41 +02:00
$findcols = array('v.bezeichnung', 'v.type','v.modul', "if(v.projekt, (SELECT `abkuerzung` FROM `projekt` WHERE `id` = v.projekt), '')",'v.id');
$searchsql = array('v.bezeichnung', 'v.type','v.modul', 'v.projekt');
2021-05-21 08:49:41 +02:00
$defaultorder = 1;
$defaultorderdesc = 0;
$menu = "<table style=\"border-collapse: collapse\"><tr><td nowrap>"
."<a href=\"index.php?module=versandarten&action=edit&id=%value%\">"
."<img src=\"themes/{$app->Conf->WFconf['defaulttheme']}/images/edit.svg\" alt=\"edit\" style=\"border: 0\"></a>";
$menu .= "&nbsp;"
."<a href=\"index.php?module=versandarten&action=copy&id=%value%\">"
."<img src=\"themes/{$app->Conf->WFconf['defaulttheme']}/images/copy.svg\" alt=\"copy\" style=\"border: 0\"></a>";
if(!$isSettingAction) {
$menu .= "&nbsp;"
. "<a href=\"#\" onclick=DeleteDialog(\"index.php?module=versandarten&action=delete&id=%value%\")>"
. "<img src=\"themes/{$app->Conf->WFconf['defaulttheme']}/images/delete.svg\" alt=\"delete\" style=\"border: 0\"></a>";
}
$menu .= "</td></tr></table>";
$where = " v.id > 0 ";
$sql = "SELECT SQL_CALC_FOUND_ROWS v.id, if(v.aktiv, v.bezeichnung, CONCAT('<s>',v.bezeichnung,'</s>')),
if(v.aktiv, v.type, CONCAT('<s>',v.type,'</s>')),
if(v.aktiv, v.modul, CONCAT('<s>',v.modul,'</s>')),
if(v.projekt, (SELECT `abkuerzung` FROM `projekt` WHERE `id` = v.projekt), ''), v.id
FROM `versandarten` AS `v`";
$count = "SELECT count(v.id) FROM `versandarten` AS `v` WHERE $where";
break;
2021-05-21 08:49:41 +02:00
}
$erg = [];
foreach($erlaubtevars as $k => $v) {
if(isset($$v)) {
$erg[$v] = $$v;
}
2021-05-21 08:49:41 +02:00
}
return $erg;
2021-05-21 08:49:41 +02:00
}
/** @noinspection PhpUnused */
public function VersandartenEdit(): void
2021-05-21 08:49:41 +02:00
{
$id = (int)$this->app->Secure->GetGET('id');
$submit = $this->app->Secure->GetPOST('speichern');
if (!$id)
return;
2021-05-21 08:49:41 +02:00
$this->app->erp->MenuEintrag('index.php?module=versandarten&action=edit&id='.$id,'Details');
$this->app->erp->MenuEintrag('index.php?module=versandarten&action=list','Zur&uuml;ck zur &Uuml;bersicht');
$error = [];
if($submit != '') { // handle form submit
$form = $this->GetInput();
$obj = $this->loadModule($form['modul'], $id);
if ($obj === null)
$error[] = sprintf('Versandart "%s" existiert nicht.', $form['selmodul']);
if(trim($form['bezeichnung']) == '')
$error[] = 'Bitte eine Bezeichnung angeben!';
if(trim($form['type']) == '')
$error[] = 'Bitte einen Typ angeben!';
$projektId = 0;
if(!empty($form['projekt'])){
$projektId = $this->app->DB->Select(
"SELECT `id` FROM `projekt` WHERE `abkuerzung` = '{$form['projekt']}' LIMIT 1"
);
2021-05-21 08:49:41 +02:00
}
if ($this->app->DB->Select(
"SELECT `id` FROM `versandarten` WHERE `type` = '{$form['type']}' AND `id` <> $id LIMIT 1"
))
$error[] = 'Typ ist bereits für eine andere Versandart vergeben';
2023-03-23 23:22:45 +01:00
if ($obj !== null) {
foreach ($obj->AdditionalSettings() as $k => $v) {
$form[$k] = $this->app->Secure->GetPOST($k);
}
$error = array_merge($error, $obj->ValidateSettings($form));
foreach ($obj->AdditionalSettings() as $k => $v) {
$json[$k] = $form[$k];
}
}
$json = json_encode($json ?? null);
2021-05-21 08:49:41 +02:00
foreach ($error as $e) {
$this->app->Tpl->addMessage('error', $e);
}
2021-05-21 08:49:41 +02:00
if (empty($error)) {
$this->app->DB->Update(
"UPDATE `versandarten`
SET `bezeichnung`='{$form['bezeichnung']}', `type` ='{$form['type']}',
`projekt`=$projektId, `aktiv`={$form['aktiv']}, `modul`='{$form['modul']}',
`export_drucker` = {$form['export_drucker']},
`paketmarke_drucker` = {$form['paketmarke_drucker']},
`ausprojekt` = {$form['ausprojekt']}, `versandmail` = {$form['versandmail']},
`geschaeftsbrief_vorlage` = {$form['geschaeftsbrief_vorlage']},
`keinportocheck`={$form['keinportocheck']},
einstellungen_json='$json'
WHERE `id` = $id LIMIT 1"
);
2021-05-21 08:49:41 +02:00
2022-11-02 22:37:04 +01:00
$this->app->Tpl->Set('MESSAGE', '');
$this->app->Tpl->addMessage('success', "Die Daten wurden erfolgreich gespeichert!");
2021-05-21 08:49:41 +02:00
}
}
$daten = $this->app->DB->SelectRow("SELECT * FROM `versandarten` WHERE `id` = $id LIMIT 1");
if (empty($daten))
$this->app->Location->execute('index.php?module=versandarten&action=list');
$this->app->erp->Headlines('', $daten['bezeichnung']);
$this->app->Tpl->Set('AKTMODUL', $daten['modul']);
$obj = $this->loadModule($daten['modul'], $daten['id']);
if (empty($error) || !isset($form)) { //overwrite form data from database if no validation error is present
$form = json_decode($daten['einstellungen_json'],true);
$form['bezeichnung'] = $daten['bezeichnung'];
$form['type'] = $daten['type'];
$form['projekt'] = $this->app->erp->Projektdaten($daten['projekt'], 'abkuerzung');
$form['aktiv'] = $daten['aktiv'];
$form['keinportocheck'] = $daten['keinportocheck'];
$form['modul'] = $daten['modul'];
$form['export_drucker'] = $daten['export_drucker'];
$form['paketmarke_drucker'] = $daten['paketmarke_drucker'];
}
2023-03-23 23:22:45 +01:00
$obj?->RenderAdditionalSettings('MODULESETTINGS', $form);
2021-05-21 08:49:41 +02:00
$this->app->Tpl->addSelect('EXPORT_DRUCKER', 'export_drucker', 'export_drucker',
2022-10-29 21:38:28 +02:00
$this->getPrinterByModule($obj, false), $form['export_drucker']);
2021-05-21 08:49:41 +02:00
$this->app->Tpl->addSelect('PAKETMARKE_DRUCKER', 'paketmarke_drucker', 'paketmarke_drucker',
2022-10-29 21:38:28 +02:00
$this->getPrinterByModule($obj), $form['paketmarke_drucker']);
2021-05-21 08:49:41 +02:00
$this->app->YUI->HideFormular('versandmail', array('0'=>'versandbetreff','1'=>'dummy'));
$this->app->Tpl->addSelect('SELVERSANDMAIL', 'versandmail', 'versandmail', [
0 => 'Standardverhalten',
-1 => 'Keine Versandmail',
1 => 'Eigene Textvorlage'
], $daten['versandmail']);
$geschaeftsbrief_vorlagen = $this->app->DB->SelectPairs(
"SELECT gv.id, CONCAT_WS(' - ', gv.subjekt, p.abkuerzung) as val
2021-05-21 08:49:41 +02:00
FROM `geschaeftsbrief_vorlagen` AS `gv`
LEFT JOIN `projekt` AS `p` ON gv.projekt = p.id
ORDER by gv.subjekt"
);
$this->app->Tpl->addSelect('SELGESCHAEFTSBRIEF_VORLAGE', 'geschaeftsbrief_vorlage',
'geschaeftsbrief_vorlage', $geschaeftsbrief_vorlagen, $daten['geschaeftsbrief_vorlage']);
$this->app->Tpl->addSelect('SELMODUL', 'modul', 'modul',
$this->VersandartenSelModul(true), $form['modul']);
$this->app->Tpl->Set('BEZEICHNUNG', $form['bezeichnung']);
$this->app->Tpl->Set('TYPE', $form['type']);
$this->app->Tpl->Set('PROJEKT', $form['projekt']);
2021-05-21 08:49:41 +02:00
$this->app->YUI->AutoComplete('projekt', 'projektname', 1);
if($form['aktiv']) $this->app->Tpl->Set('AKTIV', 'checked');
if($form['keinportocheck']) $this->app->Tpl->Set('KEINPORTOCHECK', 'checked');
if ($obj->Beta ?? false)
$this->app->Tpl->addMessage('warning','Dieses Modul ist noch im Beta Stadium');
2021-05-21 08:49:41 +02:00
$this->app->Tpl->Parse('PAGE', 'versandarten_edit.tpl');
}
2023-03-23 23:22:45 +01:00
protected function getPrinterByModule(?Versanddienstleister $obj, bool $includeLabelPrinter = true): array
2021-05-21 08:49:41 +02:00
{
$printer = $this->app->erp->GetDrucker();
2023-03-23 23:22:45 +01:00
if ($includeLabelPrinter && $obj?->isEtikettenDrucker()) {
$labelPrinter = $this->app->erp->GetEtikettendrucker();
$printer = array_merge($printer ?? [], $labelPrinter ?? []);
2021-05-21 08:49:41 +02:00
}
natcasesort($printer);
2021-05-21 08:49:41 +02:00
return $printer;
}
/**
* @param string $shippingModule
*
* @return array
*/
protected function getVuePrinterOptions(string $shippingModule = ''): array
2021-05-21 08:49:41 +02:00
{
try{
$obj = $this->loadModule($shippingModule);
return VueUtil::keyValueArrayToVueOptions($this->getPrinterByModule($obj));
2021-05-21 08:49:41 +02:00
}
catch(Exception) {
2021-05-21 08:49:41 +02:00
return [];
}
}
public function getVueExportPrinterOptions(): array
2021-05-21 08:49:41 +02:00
{
$printer = $this->app->erp->GetDrucker();
try{
return VueUtil::keyValueArrayToVueOptions($printer ?? []);
2021-05-21 08:49:41 +02:00
}
catch(Exception) {
2021-05-21 08:49:41 +02:00
return [];
}
}
public function getVueProjects(): array
{
$projects = array_merge(
[ 0 => '', ],
$this->app->DB->SelectPairs(
"SELECT p.id, p.abkuerzung
2021-05-21 08:49:41 +02:00
FROM `projekt` AS `p`
WHERE p.geloescht = 0 {$this->app->erp->ProjektRechte()}
ORDER BY p.abkuerzung"
2021-05-21 08:49:41 +02:00
)
);
try{
return VueUtil::keyValueArrayToVueOptions($projects);
}
catch(Exception) {
2021-05-21 08:49:41 +02:00
return [];
}
}
/**
* @var string $shippingModule
* @var string $shippingModuleName
* @var null|array $requiredForSubmit
*
* @return JsonResponse
*/
public function getStep2Page(string $shippingModule, string $shippingModuleName, ?array $requiredForSubmit = null): JsonResponse
2021-05-21 08:49:41 +02:00
{
if($requiredForSubmit === null) {
$requiredForSubmit = $this->app->Secure->POST;
$requiredForSubmit['step'] = 2;
}
$page = [
'type' => 'form',
'submitType' => 'submit',
'icon'=> 'password-icon',
'headline' => $shippingModuleName,
'subHeadline' => 'Welche Drucker möchtest Du nutzen?',
'submitUrl' => 'index.php?module=versandarten&action=create&cmd=saveAssistant&shippingmodule='.
$shippingModule,
'form' => $this->getFeatureForm($shippingModule),
'ctaButtons' => [
[
'title' => 'Weiter',
'type' => 'submit',
'action' => 'submit',
],
]
];
return new JsonResponse(
[
'page' => $page,
'dataRequiredForSubmit' => $requiredForSubmit,
]
);
}
public function getFeatureForm(string $shippingModule): array
2021-05-21 08:49:41 +02:00
{
return [
2021-05-21 08:49:41 +02:00
[
'id' => 0,
'name' => 'projectGroup',
'inputs' => [
[
'label' => 'Projekt Filter',
'type' => 'select',
'name' => 'projekt',
'validation' => false,
'options' => $this->getVueProjects(),
],
],
],
[
'id' => 1,
'name' => 'printerGroup',
'inputs' => [
[
'label' => 'Drucker',
'type' => 'select',
'name' => 'paketmarke_drucker',
'validation' => false,
'options' => $this->getVuePrinterOptions($shippingModule),
],
],
],
[
'id' => 2,
'name' => 'exportprinterGroup',
'inputs' => [
[
'label' => 'Export-Drucker',
'type' => 'select',
'name' => 'export_drucker',
'validation' => false,
'options' => $this->getVueExportPrinterOptions(),
],
],
],
];
}
/** @noinspection PhpUnused */
2021-05-21 08:49:41 +02:00
public function VersandartenDelete(): void
{
$id = (int)$this->app->Secure->GetGET('id');
$this->app->DB->Delete("DELETE FROM `versandarten` WHERE `id` = $id LIMIT 1");
2021-05-21 08:49:41 +02:00
$msg = $this->app->erp->base64_url_encode("<div class=\"success\">Die Versandart wurde gelöscht!</div>");
$this->app->Location->execute("index.php?module=versandarten&action=list&msg=$msg");
}
public function getApps(): ?array
2021-05-21 08:49:41 +02:00
{
$module = [];
$modularr = $this->VersandartenSelModul();
foreach($modularr as $k => $v) {
$module['installiert'][$k] = [
'md5'=>md5($v),
'Bezeichnung'=>$v,
'key'=> $k,
'Icon'=>'Icons_dunkel_9.gif'
];
2021-05-21 08:49:41 +02:00
}
if(!empty($module['installiert']) && count($module['installiert']) > 0) {
$sort = null;
foreach($module['installiert'] as $k => $v) {
$sort[$k] = $v['Bezeichnung'];
}
array_multisort($sort, SORT_ASC, $module['installiert']);
}
return $module;
}
public function getVueShippingMethodSuccessPage(int $shippingMethodId): JsonResponse
2021-05-21 08:49:41 +02:00
{
$successpage = [
2021-05-21 08:49:41 +02:00
'type' => 'defaultPage',
'icon' => 'add-person-icon',
'headline'=> 'Versandart angelegt',
'subHeadline'=> 'Die Versandart wurde angelegt',
'ctaButtons' => [
[
'title' => 'Klasse',
'action' => 'close',
'link' => 'index.php?module=versandarten&action=edit&id='.$shippingMethodId
]
]
];
return new JsonResponse(
['page'=>$successpage]
2021-05-21 08:49:41 +02:00
);
}
/**
* @return JsonResponse
*/
public function HandleGetAssistantAjaxAction(): JsonResponse
{
$module = $this->app->Secure->GetPOST('shippingmodule');
$obj = $this->loadModule($module);
if($obj === null || !method_exists($obj, 'getCreateForm')) {
return new JsonResponse(['location' => 'index.php?module=versandarten&action=create&auswahl='.$module]);
}
$form = $obj->getCreateForm();
if(!empty($form)) {
$form[(count($form)) - 1]['link'] = [
2021-05-21 08:49:41 +02:00
'link' => 'index.php?module=versandarten&action=create&auswahl=' . $module,
'title' => 'Expertenmodus',
];
}
$name = ucfirst(substr($module, 13));
if(method_exists($obj, 'GetBezeichnung')){
$name = $obj->GetBezeichnung();
}
$page = [
'type' => 'form',
'dataRequiredForSubmit' =>
[
'shippingmodule' => $module,
'id' => 'NEW',
],
'submitType' => 'submit',
'icon'=> 'password-icon',
'headline' => $name,
'subHeadline' => method_exists($obj, 'getClickByClickHeadline')
?$obj->getClickByClickHeadline():'Bitte Zugangsdaten eingeben',
'submitUrl' => 'index.php?module=versandarten&action=create&cmd=saveAssistant&shippingmodule='.$module,
'form' => $form,
'ctaButtons' => [
[
'title' => 'Weiter',
'type' => 'submit',
'action' => 'submit',
],
]
];
$ret = [
'pages'=>
[
$page
],
];
return new JsonResponse($ret);
}
/**
* @return JsonResponse
*/
public function HandleSaveAssistantAjaxAction(): JsonResponse
{
$data = ['error' => 'Unknown error'];
$shippingMethodId = $this->app->Secure->GetPOST('id','','',true);
$step = (int)$this->app->Secure->GetPOST('step');
$shippingModule = $this->app->Secure->GetGET('shippingmodule');
if(empty($shippingModule)) {
$shippingModule = $this->app->Secure->GetPOST('shippingmodule');
}
if($shippingMethodId === 'NEW') {
$postData = $this->app->Secure->POST;
/** @var Versanddienstleister $obj */
$obj = $this->loadModule($shippingModule);
if($obj !== null && method_exists($obj, 'AuthByAssistent')){
$json = $obj->AuthByAssistent();
if($json instanceof JsonResponse){
return $json;
}
}
if($obj !== null && method_exists($obj, 'updatePostDataForAssistent')) {
$postData = $obj->updatePostDataForAssistent($postData);
}
if($step < 2) {
$shippingModuleName = $shippingModule;
if(str_starts_with($shippingModuleName, 'versandarten_')) {
2021-05-21 08:49:41 +02:00
$shippingModuleName = substr($shippingModuleName, 13);
}
$shippingModuleName = str_replace('_', ' ', ucfirst($shippingModuleName));
if($obj !== null && method_exists($obj, 'GetBezeichnung')) {
$shippingModuleName = $obj->GetBezeichnung();
}
$postData['step'] = 2;
return $this->getStep2Page($shippingModule, $shippingModuleName, $postData);
}
$printer = (int)$this->app->Secure->GetPOST('paketmarke_drucker');
$exportPrinter = (int)$this->app->Secure->GetPOST('export_drucker');
$projektId = (int)$this->app->Secure->GetPOST('projekt');
$createShippingResult = $this->createShippingMethodFromModuleName($shippingModule);
if(!empty($createShippingResult['id'])) {
$shippingMethodId = $createShippingResult['id'];
if(method_exists($obj, 'getStructureDataForClickByClickSave')) {
$structureData = $obj->getStructureDataForClickByClickSave();
if(!empty($structureData)) {
$this->saveCreateData($shippingMethodId, $structureData);
}
}
$this->saveCreateData($shippingMethodId, $postData);
$this->app->DB->UpdateArr(
'versandarten',
$shippingMethodId,
'id',
[
'paketmarke_drucker' => $printer,
'export_drucker' => $exportPrinter,
'projekt' => $projektId,
], true
);
}
elseif(!empty($createShippingResult['error'])) {
return new JsonResponse($createShippingResult, Response::HTTP_BAD_REQUEST);
2021-05-21 08:49:41 +02:00
}
}
if((int)$shippingMethodId > 0) {
return $this->getVueShippingMethodSuccessPage((int)$shippingMethodId);
}
return new JsonResponse($data, Response::HTTP_BAD_REQUEST);
2021-05-21 08:49:41 +02:00
}
/**
* @param int $shippingMethodId
* @param null|array $post
*/
public function saveCreateData(int $shippingMethodId, ?array $post = null): void
2021-05-21 08:49:41 +02:00
{
$shippingMethod = $this->app->DB->SelectRow(
sprintf('SELECT * FROM `versandarten` WHERE `id` = %d', $shippingMethodId)
);
/** @var Versanddienstleister $obj */
$obj = $this->loadModule($shippingMethod['modul'], $shippingMethodId);
if($obj === null) {
return;
}
$form = $obj->getCreateForm();
$data = json_decode($shippingMethod['einstellungen_json'], true);
if(empty($data) || !is_array($data)) {
$data = [];
}
if($post === null) {
try {
$vueFields = VueUtil::getInputNamesFromVuePages($form);
}
catch(Exception) {
2021-05-21 08:49:41 +02:00
$vueFields = [];
}
foreach($vueFields as $input) {
$post[$input] = !isset($this->app->Secure->POST[$input])
?null:$this->app->Secure->POST[$input];
}
}
if(empty($post)) {
return;
}
foreach($post as $key => $value) {
$data[$key] = $value;
}
$this->app->DB->Update(
sprintf(
"UPDATE `versandarten` SET `einstellungen_json` = '%s' WHERE `id` = %d",
$this->app->DB->real_escape_string(json_encode($data)), $shippingMethodId
)
);
}
/**
* @param string $shippingMethodModule
*
* @return array
*/
public function createShippingMethodFromModuleName(string $shippingMethodModule): array
2021-05-21 08:49:41 +02:00
{
$obj = $this->loadModule($shippingMethodModule);
if ($obj === null)
return ['success' => false, 'error' => 'Modul nicht vorhanden'];
$name = $obj->name ?? ucfirst($shippingMethodModule);
$type = $shippingMethodModule;
2021-05-21 08:49:41 +02:00
$i = 1;
$originalName = $name;
while(
$this->app->DB->Select(
sprintf(
"SELECT `id` FROM `versandarten` WHERE `type` = '%s' OR `bezeichnung` = '%s' LIMIT 1",
$this->app->DB->real_escape_string($type), $this->app->DB->real_escape_string($name)
)
)
) {
$i++;
$type = $shippingMethodModule.'_'.$i;
2021-05-21 08:49:41 +02:00
$name = $originalName.' '.$i;
}
$versandmail = 0;
if($shippingMethodModule === 'versandarten_selbstabholer'){
$versandmail = 1;
}
$this->app->DB->Insert(
"INSERT INTO `versandarten`
(`bezeichnung`, `type`,`aktiv`, `geloescht`, `modul`,`ausprojekt`, `versandmail`, `einstellungen_json`)
VALUES ('$name','$type','1','0','$shippingMethodModule','0', $versandmail,'')"
2021-05-21 08:49:41 +02:00
);
$id = $this->app->DB->GetInsertID();
$this->app->erp->RunHook('versandarten_create', 1, $id);
return ['id'=>$id];
}
/**
* @return JsonResponse|void
* @noinspection PhpUnused
2021-05-21 08:49:41 +02:00
*/
public function VersandartenCreate()
{
$cmd = $this->app->Secure->GetGET('cmd');
if($cmd === 'getAssistant') {
return $this->HandleGetAssistantAjaxAction();
}
if($cmd === 'saveAssistant') {
return $this->HandleSaveAssistantAjaxAction();
}
$modulelist = $this->VersandartenSelModul(true);
$auswahlmodul = $this->app->Secure->GetGET('auswahl');
2021-05-21 08:49:41 +02:00
if($auswahlmodul && isset($modulelist[$auswahlmodul])) {
$ret = $this->createShippingMethodFromModuleName($auswahlmodul);
if(!empty($ret['id'])) {
$this->app->Location->execute('index.php?module=versandarten&action=edit&id='.$ret['id']);
2021-05-21 08:49:41 +02:00
}
$this->app->Location->execute('index.php?module=versandarten&action=create');
2021-05-21 08:49:41 +02:00
}
2021-05-21 08:49:41 +02:00
/** @var Appstore $appstore */
$appstore = $this->app->loadModule('appstore');
$modulelist = $this->GetApps();
2021-05-21 08:49:41 +02:00
$appstore->AddModuleHtml(
$modulelist, '', 'index.php?module=versandarten&action=create&get='
2021-05-21 08:49:41 +02:00
);
$this->app->ModuleScriptCache->IncludeWidgetNew('ClickByClickAssistant');
$this->app->Tpl->Parse('PAGE', 'versandarten_neu.tpl');
}
/**
* @return array
*/
public function GetInput(): array
{
$input = [];
$input['bezeichnung'] = $this->app->Secure->GetPOST('bezeichnung');
$input['type'] = $this->app->Secure->GetPOST('type');
2021-05-21 08:49:41 +02:00
$input['projekt'] = $this->app->Secure->GetPOST('projekt');
$input['modul'] = $this->app->Secure->GetPOST('modul');
2021-05-21 08:49:41 +02:00
$input['aktiv'] = (int)$this->app->Secure->GetPOST('aktiv');
$input['keinportocheck'] = (int)$this->app->Secure->GetPOST('keinportocheck');
$input['ausprojekt'] = (int)$this->app->Secure->GetPOST('ausprojekt');
$input['export_drucker'] = (int)$this->app->Secure->GetPOST('export_drucker');
$input['paketmarke_drucker'] = (int)$this->app->Secure->GetPOST('paketmarke_drucker');
$input['geschaeftsbrief_vorlage'] = (int)$this->app->Secure->GetPOST('geschaeftsbrief_vorlage');
$input['versandmail'] = (int)$this->app->Secure->GetPOST('versandmail');
return $input;
}
/**
* @param string $module
* @param int $moduleId
*
2023-03-23 23:22:45 +01:00
* @return ?Versanddienstleister
2021-05-21 08:49:41 +02:00
*/
public function loadModule(string $module, int $moduleId = 0) : ?Versanddienstleister
2021-05-21 08:49:41 +02:00
{
if(str_starts_with($module, 'versandarten_')) {
$module = substr($module, 13);
2021-05-21 08:49:41 +02:00
}
if(empty($module)) {
return null;
}
if(str_contains($module, '.') || str_contains($module, '/') || str_contains($module, '\\')) {
return null;
}
$path = dirname(__DIR__).'/lib/versandarten/'.$module.'.php';
if(!is_file($path)) {
return null;
2021-05-21 08:49:41 +02:00
}
include_once $path ;
$classname = 'Versandart_'.$module;
if(!class_exists($classname)) {
return null;
2021-05-21 08:49:41 +02:00
}
return new $classname($this->app, $moduleId);
2021-05-21 08:49:41 +02:00
}
/**
* Retrieve all Versandarten from lib/versandarten/
* @return array
*/
function VersandartenSelModul(bool $addEmpty = false) : array
{
$result = [];
if ($addEmpty)
$result[''] = '';
$pfad = dirname(__DIR__).'/lib/versandarten';
if(!is_dir($pfad))
return $result;
$handle = opendir($pfad);
$files = [];
if($handle) {
while (($file = readdir($handle)) !== false) {
$files[] = $file;
}
}
closedir($handle);
foreach($files as $file) {
if(str_starts_with($file, '.') || !str_ends_with($file, '.php') || !is_file($pfad.'/'.$file)
|| str_ends_with($file, '.src.php'))
continue;
$modul = str_replace('.php','',$file);
if(str_ends_with($modul, '_custom')
&& !$this->app->DB->Select(
"SELECT `id` FROM `versandarten` WHERE `modul` = '".$this->app->DB->real_escape_string($modul)."' LIMIT 1"
)
)
continue;
if($modul == '' || $modul=='rocketshipit')
continue;
$obj = $this->loadModule($modul);
2023-03-23 23:22:45 +01:00
if ($obj === null)
continue;
$result[$modul] = $obj->name ?? ucfirst($modul);
unset($obj);
}
return $result;
}
}