Merge pull request #137 from exciler/matrixartikel

MatrixProdukt: Fix SQL and hide Table when no groups are defined
This commit is contained in:
OpenXE-ERP 2024-04-08 11:42:55 +02:00 committed by GitHub
commit 1f14f1829b
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 15 additions and 9 deletions

View File

@ -35,11 +35,11 @@ SPDX-License-Identifier: LicenseRef-EGPL-3.1
<div class="row-height"> <div class="row-height">
<div class="col-xs-12 col-md-10 col-md-height"> <div class="col-xs-12 col-md-10 col-md-height">
<div class="inside-white inside-full-height"> <div class="inside-white inside-full-height">
[MESSAGE] [MESSAGE2]
[TAB2] [TAB2]
</div> </div>
</div> </div>
<div class="col-xs-12 col-md-2 col-md-height"> <div class="col-xs-12 col-md-2 col-md-height" [TAB2HIDEACTIONS]>
<div class="inside inside-full-height"> <div class="inside inside-full-height">
<fieldset> <fieldset>
<legend>{|Aktionen|}</legend> <legend>{|Aktionen|}</legend>

View File

@ -135,7 +135,7 @@ class Matrixprodukt
} }
$heading[] = 'Men&uuml;'; $heading[] = 'Men&uuml;';
$width[] = '1%'; $width[] = '1%';
$findcols = array_merge($nameColumns, ['nummer']); $findcols = array_merge($nameColumns, ['nummer', 'id']);
$searchsql = $nameColumns; $searchsql = $nameColumns;
$menu = "<table><tr><td nowrap>" $menu = "<table><tr><td nowrap>"
. "<img class=\"vueAction\" data-action=\"variantEdit\" data-variant-id=\"%value%\" data-article-id=\"$id\" src=\"./themes/{$app->Conf->WFconf['defaulttheme']}/images/edit.svg\">&nbsp;" . "<img class=\"vueAction\" data-action=\"variantEdit\" data-variant-id=\"%value%\" data-article-id=\"$id\" src=\"./themes/{$app->Conf->WFconf['defaulttheme']}/images/edit.svg\">&nbsp;"
@ -150,10 +150,11 @@ class Matrixprodukt
$artsql = "SELECT a.id, a.nummer, group_concat(mota.option_id order by mota.option_id separator ',') idlist $artsql = "SELECT a.id, a.nummer, group_concat(mota.option_id order by mota.option_id separator ',') idlist
FROM matrixprodukt_optionen_zu_artikel mota FROM matrixprodukt_optionen_zu_artikel mota
JOIN artikel a ON mota.artikel = a.id WHERE a.variante_von = $id group by mota.artikel"; JOIN artikel a ON mota.artikel = a.id WHERE a.variante_von = $id group by mota.artikel";
$sqlNameCols = join(',', $nameColumns); $sqlNameCols = join(',', array_merge(['art.id', 'art.nummer'], $nameColumns, ['art.id']));
$sql = "SELECT SQL_CALC_FOUND_ROWS art.id, art.nummer, $sqlNameCols, art.id $sql = "SELECT SQL_CALC_FOUND_ROWS $sqlNameCols
FROM ($artsql) art FROM ($artsql) art ";
LEFT OUTER JOIN ($optsql) opts ON opts.idlist = art.idlist"; if (!empty($optsqlIdCols))
$sql .= " LEFT OUTER JOIN ($optsql) opts ON opts.idlist = art.idlist";
$where = "1"; $where = "1";
//$count = "SELECT count(DISTINCT moa.id) //$count = "SELECT count(DISTINCT moa.id)
// FROM matrixprodukt_eigenschaftengruppen_artikel mga // FROM matrixprodukt_eigenschaftengruppen_artikel mga
@ -362,18 +363,23 @@ class Matrixprodukt
return new JsonResponse($result); return new JsonResponse($result);
} }
$articleId = $this->app->Secure->GetGET('id');
$groupId = $this->app->Secure->GetGET('sid'); $groupId = $this->app->Secure->GetGET('sid');
if (empty($groupId)) { if (empty($groupId)) {
$this->app->YUI->TableSearch('TAB1', 'matrixprodukt_article_groups', "show", "", "", basename(__FILE__), __CLASS__); $this->app->YUI->TableSearch('TAB1', 'matrixprodukt_article_groups', "show", "", "", basename(__FILE__), __CLASS__);
$this->app->Tpl->Set('ADDEDITFUNCTION', 'groupEdit'); $this->app->Tpl->Set('ADDEDITFUNCTION', 'groupEdit');
} else { } else {
$articleId = $this->app->Secure->GetGET('id');
$this->app->erp->MenuEintrag("index.php?module=matrixprodukt&action=artikel&id=$articleId", 'Zur&uuml;ck zur Gruppen&uuml;bersicht'); $this->app->erp->MenuEintrag("index.php?module=matrixprodukt&action=artikel&id=$articleId", 'Zur&uuml;ck zur Gruppen&uuml;bersicht');
$this->app->YUI->TableSearch('TAB1', 'matrixprodukt_article_options', "show", "", "", basename(__FILE__), __CLASS__); $this->app->YUI->TableSearch('TAB1', 'matrixprodukt_article_options', "show", "", "", basename(__FILE__), __CLASS__);
$this->app->Tpl->Set('SID', $groupId); $this->app->Tpl->Set('SID', $groupId);
$this->app->Tpl->Set('ADDEDITFUNCTION', 'optionEdit'); $this->app->Tpl->Set('ADDEDITFUNCTION', 'optionEdit');
} }
$this->app->YUI->TableSearch('TAB2', 'matrixprodukt_variants', "show", "", "", basename(__FILE__), __CLASS__); if ($this->service->GetArticleGroupsByArticleId($articleId)) {
$this->app->YUI->TableSearch('TAB2', 'matrixprodukt_variants', "show", "", "", basename(__FILE__), __CLASS__);
} else {
$this->app->Tpl->Set('TAB2HIDEACTIONS', 'style="display: none;"');
$this->app->Tpl->Set('MESSAGE2', "<div class=\"error\">Es sind noch keine Gruppen angelegt!</div>");
}
$this->app->Tpl->Parse('PAGE', "matrixprodukt_article.tpl"); $this->app->Tpl->Parse('PAGE', "matrixprodukt_article.tpl");
} }