Files
luos/workflow/engine/classes/model/DashboardIndicator.php

219 lines
9.7 KiB
PHP
Raw Normal View History

2015-03-26 17:37:32 -04:00
<?php
require_once 'classes/model/om/BaseDashboardIndicator.php';
/**
* Skeleton subclass for representing a row from the 'DASHBOARD_INDICATOR' table.
*
2017-12-04 13:25:35 +00:00
*
2015-03-26 17:37:32 -04:00
*
* You should add additional methods to this class to meet the
* application requirements. This class will only be generated as
* long as it does not already exist in the output directory.
*
* @package classes.model
*/
class DashboardIndicator extends BaseDashboardIndicator
{
2017-12-04 13:25:35 +00:00
public function load($dasIndUid)
2015-03-26 17:37:32 -04:00
{
try {
$dashboardIndicator = DashboardIndicatorPeer::retrieveByPK($dasIndUid);
$fields = $dashboardIndicator->toArray(BasePeer::TYPE_FIELDNAME);
2017-12-04 13:25:35 +00:00
$dashboardIndicator->fromArray($fields, BasePeer::TYPE_FIELDNAME);
2015-03-26 17:37:32 -04:00
return $fields;
} catch (Exception $error) {
throw $error;
}
}
2017-12-04 13:25:35 +00:00
public function loadbyDasUid($dasUid, $vcompareDate, $vmeasureDate, $userUid)
{
2015-03-26 17:37:32 -04:00
$calculator = new \IndicatorsCalculator();
try {
2017-12-04 13:25:35 +00:00
$connection = Propel::getConnection('workflow');
$qryString = "select * from CONFIGURATION where CFG_UID = 'DASHBOARDS_SETTINGS' and USR_UID = '$userUid'";
$qry = $connection->PrepareStatement($qryString);
$dataSet = $qry->executeQuery();
$dashConfig = array();
while ($dataSet->next()) {
$row = $dataSet->getRow();
$dashConfig = unserialize($row['CFG_VALUE']);
}
2015-03-26 17:37:32 -04:00
2017-12-04 13:25:35 +00:00
$criteria = new Criteria('workflow');
2015-03-26 17:37:32 -04:00
$criteria->clearSelectColumns()->clearOrderByColumns();
2017-12-04 13:25:35 +00:00
$criteria->add(DashboardIndicatorPeer::DAS_UID, $dasUid, criteria::EQUAL);
2015-03-26 17:37:32 -04:00
2017-12-04 13:25:35 +00:00
$rs = DashboardIndicatorPeer::doSelectRS($criteria);
$rs->setFetchmode(ResultSet::FETCHMODE_ASSOC);
2015-03-26 17:37:32 -04:00
$dashboardIndicator = array();
2015-04-30 17:32:21 -04:00
2015-03-26 17:37:32 -04:00
while ($rs->next()) {
$row = $rs->getRow();
2017-12-04 13:25:35 +00:00
$measureDate = new DateTime($vmeasureDate);
$compareDate = new DateTime($vcompareDate);
$uid = ($row['DAS_UID_PROCESS'] == '0' ? null : $row['DAS_UID_PROCESS']);
switch ($row['DAS_IND_TYPE']) {
case '1010':
$value = $calculator->peiHistoric($uid, $measureDate, $measureDate, \ReportingPeriodicityEnum::NONE);
$value = reset($value);
$value = current($value);
$oldValue = $calculator->peiHistoric($uid, $compareDate, $compareDate, \ReportingPeriodicityEnum::NONE);
$oldValue = reset($oldValue);
$oldValue = current($oldValue);
$row['DAS_IND_VARIATION'] = $value - $oldValue;
$row['DAS_IND_OLD_VALUE'] = $oldValue;
$row['DAS_IND_PERCENT_VARIATION'] = $oldValue != 0
? round(($value - $oldValue) * 100 / $oldValue)
: "--";
break;
case '1030':
$value = $calculator->ueiHistoric(null, $measureDate, $measureDate, \ReportingPeriodicityEnum::NONE);
$value = reset($value);
$value = current($value);
$oldValue = $calculator->ueiHistoric($uid, $compareDate, $compareDate, \ReportingPeriodicityEnum::NONE);
$oldValue = reset($oldValue);
$oldValue = current($oldValue);
$row['DAS_IND_VARIATION'] = $value - $oldValue;
$row['DAS_IND_OLD_VALUE'] = $oldValue;
$row['DAS_IND_PERCENT_VARIATION'] = $oldValue != 0
? round(($value - $oldValue) * 100 / $oldValue)
: "--";
break;
2015-04-15 14:46:54 -04:00
case '1050':
$value = $calculator->statusIndicatorGeneral($userUid);
$row['OVERDUE'] = 0;
$row['ON_TIME'] = 0;
$row['AT_RISK'] = 0;
$row['PERCENTAGE_OVERDUE'] = 0;
$row['PERCENTAGE_AT_RISK'] = 0;
$row['PERCENTAGE_ON_TIME'] = 0;
if (is_array($value) && isset($value[0])) {
$row['OVERDUE'] = $value[0]['OVERDUE'];
$row['ON_TIME'] = $value[0]['ONTIME'];
$row['AT_RISK'] = $value[0]['ATRISK'];
$total = $row['OVERDUE'] + $row['AT_RISK'] + $row['ON_TIME'];
if ($total != 0) {
2017-12-04 13:25:35 +00:00
$row['PERCENTAGE_OVERDUE'] = ($row['OVERDUE'] * 100) / $total;
$row['PERCENTAGE_AT_RISK'] = ($row['AT_RISK'] * 100) / $total;
$row['PERCENTAGE_ON_TIME'] = ($row['ON_TIME'] * 100) / $total;
2015-04-15 14:46:54 -04:00
}
}
break;
2017-12-04 13:25:35 +00:00
default:
$arrResult = $calculator->generalIndicatorData($row['DAS_IND_UID'], $measureDate, $measureDate, \ReportingPeriodicityEnum::NONE);
$value = $arrResult[0]['value'];
$row['DAS_IND_VARIATION'] = $row['DAS_IND_GOAL'];
break;
}
$row['DAS_IND_VALUE'] = $value;
$indId = $row['DAS_IND_UID'];
$row['DAS_IND_X'] = 0;
$row['DAS_IND_Y'] = 0;
$row['DAS_IND_WIDTH'] = 0;
$row['DAS_IND_HEIGHT'] = 0;
$row['DAS_IND_FAVORITE'] = 0;
foreach ($dashConfig as $dashId => $oneDash) {
if ($dashId == $dasUid && is_array($oneDash['dashData'])) {
foreach ($oneDash['dashData'] as $graphConfig) {
if ($graphConfig['indicatorId'] == $indId) {
$row['DAS_IND_X'] = $graphConfig['x'];
$row['DAS_IND_Y'] = $graphConfig['y'];
$row['DAS_IND_WIDTH'] = $graphConfig['width'];
$row['DAS_IND_HEIGHT'] = $graphConfig['height'];
}
}
}
}
$dashboardIndicator[] = $row;
2015-03-26 17:37:32 -04:00
}
return $dashboardIndicator;
} catch (Exception $error) {
throw $error;
}
}
public function createOrUpdate($data)
{
$connection = Propel::getConnection(DashboardIndicatorPeer::DATABASE_NAME);
try {
if (!isset($data['DAS_IND_UID'])) {
$data['DAS_IND_UID'] = G::generateUniqueID();
$data['DAS_IND_CREATE_DATE'] = date('Y-m-d H:i:s');
$dashboardIndicator = new DashboardIndicator();
$msg = 'Create';
} else {
$msg = 'Update';
$dashboardIndicator = DashboardIndicatorPeer::retrieveByPK($data['DAS_IND_UID']);
}
$data['DAS_IND_UPDATE_DATE'] = date('Y-m-d H:i:s');
$dashboardIndicator->fromArray($data, BasePeer::TYPE_FIELDNAME);
if ($dashboardIndicator->validate()) {
$connection->begin();
$result = $dashboardIndicator->save();
$connection->commit();
2017-12-04 13:25:35 +00:00
if ((!isset($_SESSION['USER_LOGGED']) || $_SESSION['USER_LOGGED'] == '') && isset($data['USR_UID']) && $data['USR_UID'] != '') {
$this->setUser($data['USR_UID']);
}
2017-12-04 13:25:35 +00:00
G::auditLog($msg, "Dashboard Indicator Name: " . $dashboardIndicator->getDasIndTitle() . " Dashboard indicator ID: (" . $dashboardIndicator->getDasIndUid() . ") ");
2015-03-26 17:37:32 -04:00
return $dashboardIndicator->getDasIndUid();
} else {
$message = '';
$validationFailures = $dashboardIndicator->getValidationFailures();
foreach ($validationFailures as $validationFailure) {
$message .= $validationFailure->getMessage() . '. ';
}
throw(new Exception(G::LoadTranslation("ID_RECORD_CANNOT_BE_CREATED", SYS_LANG) . ' ' . $message));
}
} catch (Exception $error) {
$connection->rollback();
throw $error;
}
}
2017-12-04 13:25:35 +00:00
public function remove($dasIndUid, $userLogged = '')
2015-03-26 17:37:32 -04:00
{
$connection = Propel::getConnection(DashboardIndicatorPeer::DATABASE_NAME);
try {
$dashboardIndicator = DashboardIndicatorPeer::retrieveByPK($dasIndUid);
if (!is_null($dashboardIndicator)) {
$connection->begin();
$dashboardIndicatorData = $this->load($dasIndUid);
$result = $dashboardIndicator->delete();
$connection->commit();
if ((!isset($_SESSION['USER_LOGGED']) || $_SESSION['USER_LOGGED'] == '') && $userLogged != '') {
$this->setUser($userLogged);
}
2017-12-04 13:25:35 +00:00
G::auditLog("Delete", "Dashboard Indicator Name: " . $dashboardIndicatorData['DAS_IND_TITLE'] . " Dashboard Instance ID: (" . $dasIndUid . ") ");
2015-03-26 17:37:32 -04:00
return $result;
} else {
2017-12-04 13:25:35 +00:00
throw new Exception('Error trying to delete: The row "' . $dasIndUid . '" does not exist.');
2015-03-26 17:37:32 -04:00
}
} catch (Exception $error) {
$connection->rollback();
throw $error;
}
}
2017-12-04 13:25:35 +00:00
public function setUser($usrId)
{
$user = new Users();
$user = $user->loadDetails($usrId);
$_SESSION['USER_LOGGED'] = $user['USR_UID'];
$_SESSION['USR_FULLNAME'] = $user['USR_FULLNAME'];
}
2015-03-26 17:37:32 -04:00
}