From fa317f15a59e40915410853df6d9fc85875bacf3 Mon Sep 17 00:00:00 2001 From: Nicolas Domenech Date: Tue, 10 Sep 2024 14:17:47 +0200 Subject: [PATCH] #4082 [Dashboard] fix: rework getRisksByDigiriskElement and missing type on getRisksByCotation --- class/digiriskelement.class.php | 28 +++++++--------------------- class/riskanalysis/risk.class.php | 6 ++++-- 2 files changed, 11 insertions(+), 23 deletions(-) diff --git a/class/digiriskelement.class.php b/class/digiriskelement.class.php index b1bfa04bd..58ea6f99d 100644 --- a/class/digiriskelement.class.php +++ b/class/digiriskelement.class.php @@ -570,30 +570,16 @@ public function getRisksByDigiriskElement(string $riskType = 'risk'): array $array['showlegend'] = $conf->browser->layout == 'phone' ? 1 : 2; $array['dataset'] = 1; - $digiriskElements = $this->fetchDigiriskElementFlat(GETPOSTISSET('id') ? GETPOST('id') : 0); - - // Get current digirisk element and add data in $digiriskElements array - if (GETPOSTISSET('id')) { - $currentDigiriskElement = $this->fetchAll('', '', 0, 0, ['customsql' => 't.rowid = ' . GETPOST('id')]); - if (is_array($currentDigiriskElement) && !empty($currentDigiriskElement)) { - $currentDigiriskElement = array_shift($currentDigiriskElement); - - $array['title'] = $langs->transnoentities('RisksRepartitionByDigiriskElement', ': ' . $currentDigiriskElement->ref . ' - ' . $currentDigiriskElement->label); - - $digiriskElement[$currentDigiriskElement->id]['object'] = $currentDigiriskElement; - $digiriskElements = array_merge($digiriskElement, $digiriskElements); - } - } - - if (!empty($digiriskElements)) { + $digiriskElements = $this->getActiveDigiriskElements(0, ['filter' => GETPOSTISSET('id') ? ' AND t.rowid = ' . GETPOST('id') : '']); + if (is_array($digiriskElements) && !empty($digiriskElements)) { foreach ($digiriskElements as $digiriskElement) { - $risks = saturne_fetch_all_object_type('Risk', '', '', 0, 0, ['customsql' => 't.status = ' . Risk::STATUS_VALIDATED . ' AND t.entity = ' . $conf->entity . ' AND t.type = "' . $riskType . '" AND t.fk_element = ' . $digiriskElement['object']->id]); + $risks = saturne_fetch_all_object_type('Risk', '', '', 0, 0, ['customsql' => 't.status = ' . Risk::STATUS_VALIDATED . ' AND t.entity = ' . $conf->entity . ' AND t.type = "' . $riskType . '" AND t.fk_element = ' . $digiriskElement->id]); if (is_array($risks) && !empty($risks)) { - $array['labels'][$digiriskElement['object']->id] = [ - 'label' => $digiriskElement['object']->ref . ' - ' . $digiriskElement['object']->label, - 'color' => SaturneDashboard::getColorRange($digiriskElement['object']->id) + $array['labels'][$digiriskElement->id] = [ + 'label' => $digiriskElement->ref . ' - ' . $digiriskElement->label, + 'color' => SaturneDashboard::getColorRange($digiriskElement->id) ]; - $array['data'][$digiriskElement['object']->id] = count($risks); + $array['data'][$digiriskElement->id] = count($risks); } } } diff --git a/class/riskanalysis/risk.class.php b/class/riskanalysis/risk.class.php index 59bbb54ec..db8011383 100644 --- a/class/riskanalysis/risk.class.php +++ b/class/riskanalysis/risk.class.php @@ -635,10 +635,12 @@ public function load_dashboard(): array /** * Get risks by cotation * + * @param string $type Risk type (risk, riskenvironmental or ...) + * * @return array * @throws Exception */ - public function getRisksByCotation(): array + public function getRisksByCotation(string $type = 'risk'): array { global $conf, $langs; @@ -671,7 +673,7 @@ public function getRisksByCotation(): array $digiriskElementSqlFilter = rtrim($digiriskElementSqlFilter, ', '); } $digiriskElementSqlFilter .= ')'; - $filter = ' AND r.fk_element NOT IN ' . $digiriskElementSqlFilter; + $filter = ' AND r.fk_element NOT IN ' . $digiriskElementSqlFilter . ' AND r.type = "' . $type . '"'; } $riskAssessments = saturne_fetch_all_object_type('RiskAssessment', '', '', 0, 0, ['customsql' => 't.status = ' . RiskAssessment::STATUS_VALIDATED . $filter], 'AND', false, true, false, $join);