pour déploiement auto v2 via gitlab
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 

144 lines
3.3 KiB

<?php
class FamilleActes
{
/**
* @var Mention $codes
*/
private $mention;
/**
* @var string $texte
*/
private $texte;
/**
* @var array $listesCode
*/
private $listesCode;
/**z
* @var integer $seuil
*/
private $seuil;
public function __construct($mention, $texte,$listesCode, $seuil){
$this->mention = $mention;
$this->texte = $texte;
$this->listesCode = $listesCode;
$this->seuil = $seuil;
}
/**
* @return array
*/
public function getCodes(){
return $this->codes;
}
/**
* @return string
*/
public function getTexte()
{
return $this->texte;
}
/**
* @return integer
*/
public function getSeuil(){
return $this->seuil;
}
/**
* @return Mention
*/
public function getMention()
{
return $this->mention;
}
public function getFamillesActesOid($iCTI_connexion)
{
$famillesOid = array();
$famillesCodes = "'" . implode("', '", $this->codes) . "'";
$sql = <<<SQL
SELECT
t_etude_cardio_familles_actes.oid,
t_etude_cardio_familles_actes.code
FROM pmsi.t_etude_cardio_familles_actes
WHERE t_etude_cardio_familles_actes.code IN ($famillesCodes)
ORDER BY 1
;
SQL;
$result = $iCTI_connexion->query($sql);
while ($row = $iCTI_connexion->fetchAssoc($result)) {
$famillesOid[$row['code']] = $row['oid'];
}
return $famillesOid;
}
// public function getNbActes($iCTI_connexion, $year)
// {
//
// $count = 0;
// $famillesCodes = "'" . implode("', '", $this->codes) . "'";
//
// $sql = <<<SQL
// SELECT
// count(acte_id) AS count
// FROM pmsi.p_rss_cardio
// JOIN pmsi.t_etude_cardio_familles_actes ON p_rss_cardio.cardio_famille_acte_id = t_etude_cardio_familles_actes.oid
// WHERE t_etude_cardio_familles_actes.code IN ($famillesCodes)
// AND EXTRACT('Year' From date_acte) like $year;
//SQL;
//
// $result = $iCTI_connexion->query($sql);
// $record = $iCTI_connexion->fetchAssoc($result);
//
// if ($record) {
// $count = $record['count'];
// }
// return $count;
// }
public function getNbActes($iCTI_connexion, $year)
{
$count = 0;
$listesCodeSql = "'" . implode("', '", $this->listesCode) . "'";
$sql = <<<SQL
SELECT
count(acte_id) AS count
FROM pmsi.p_rss_cardio
JOIN pmsi.t_listes ON t_listes.oid = liste_id
WHERE t_listes.code IN($listesCodeSql)
AND EXTRACT('Year' From date_acte) like $year;
SQL;
$result = $iCTI_connexion->query($sql);
$record = $iCTI_connexion->fetchAssoc($result);
if ($record) {
$count = $record['count'];
}
return $count;
}
public function checkSeuilActes($iCTI_connexion, $year, $nbActes = null)
{
if ($nbActes == null) {
$nbActes = $this->getNbActes($iCTI_connexion, $year);
}
return $nbActes >= $this->seuil;
}
}