Rev 15545 | Rev 15941 | Ir a la última revisión | Autoría | Comparar con el anterior | Ultima modificación | Ver Log |
<?php
declare(strict_types=1);
namespace LeadersLinked\Controller;
use Laminas\Db\Adapter\AdapterInterface;
use Laminas\Cache\Storage\Adapter\AbstractAdapter;
use Laminas\Mvc\Controller\AbstractActionController;
use Laminas\Log\LoggerInterface;
use Laminas\View\Model\ViewModel;
use Laminas\View\Model\JsonModel;
use LeadersLinked\Library\Functions;
use LeadersLinked\Hydrator\ObjectPropertyHydrator;
use LeadersLinked\Mapper\CompanyMapper;
use LeadersLinked\Mapper\DailyPulseEmojiMapper;
use LeadersLinked\Form\DailyPulse\DailyPulseAddEmojiForm;
use LeadersLinked\Form\DailyPulse\DailyPulseEditEmojiForm;
use LeadersLinked\Model\DailyPulseEmoji;
use LeadersLinked\Library\Image;
use LeadersLinked\Mapper\DailyPulseRecordMapper;
use LeadersLinked\Model\DailyPulseRecord;
use PhpOffice\PhpSpreadsheet\IOFactory;
use PhpOffice\PhpSpreadsheet\Spreadsheet;
class DailyPulseReportsController extends AbstractActionController
{
/**
*
* @var AdapterInterface
*/
private $adapter;
/**
*
* @var AbstractAdapter
*/
private $cache;
/**
*
* @var LoggerInterface
*/
private $logger;
/**
*
* @var array
*/
private $config;
/**
*
* @param AdapterInterface $adapter
* @param AbstractAdapter $cache
* @param LoggerInterface $logger
* @param array $config
*/
public function __construct($adapter, $cache , $logger, $config)
{
$this->adapter = $adapter;
$this->cache = $cache;
$this->logger = $logger;
$this->config = $config;
}
public function indexAction()
{
return new JsonModel([
'success' => false,
'data' => 'ERROR_METHOD_NOT_ALLOWED'
]);
}
public function overviewAction()
{
$currentUserPlugin = $this->plugin('currentUserPlugin');
$currentUser = $currentUserPlugin->getUser();
$currentNetworkPlugin = $this->plugin('currentNetworkPlugin');
$currentNetwork = $currentNetworkPlugin->getNetwork();
$companyMapper = CompanyMapper::getInstance($this->adapter);
$company = $companyMapper->fetchDefaultForNetworkByNetworkId($currentNetwork->id);
$request = $this->getRequest();
if($request->isGet()) {
$headers = $request->getHeaders();
$isJson = false;
if($headers->has('Accept')) {
$accept = $headers->get('Accept');
$prioritized = $accept->getPrioritized();
foreach($prioritized as $key => $value) {
$raw = trim($value->getRaw());
if(!$isJson) {
$isJson = strpos($raw, 'json');
}
}
}
if($isJson) {
$startDate = $this->params()->fromQuery('startDate');
if(empty($startDate)) {
$startDate = date('Y-m-d');
}
$endDate = $this->params()->fromQuery('endDate');
if(empty($endDate)) {
$endDate = date('Y-m-d');
}
$startDate = '2023-03-01';
$endDate = '2023-03-19';
$dtStartDate = \DateTime::createFromFormat('Y-n-d', $startDate);
$dtEndDate = \DateTime::createFromFormat('Y-n-d', $endDate);
if(!$dtStartDate || !$dtEndDate) {
$startDate = date('Y-m-d');
$endDate = date('Y-m-d');
} else {
if($dtStartDate->getTimestamp() > $dtEndDate->getTimestamp()) {
$startDate = date('Y-m-d');
$endDate = date('Y-m-d');
}
}
$dailyPulseRecordMapper = DailyPulseRecordMapper::getInstance($this->adapter);
$how_are_you_feel = $dailyPulseRecordMapper->fetchAllDataChartOrExcelByCompanyIdAndTypeAndDateRange($company->id, DailyPulseRecord::TYPE_HOW_ARE_YOU_FEEL, $startDate, $endDate);
$climate_on_your_organization = $dailyPulseRecordMapper->fetchAllDataChartOrExcelByCompanyIdAndTypeAndDateRange($company->id, DailyPulseRecord::TYPE_CLIMATE_ON_YOUR_ORGANIZATION, $startDate, $endDate);
$data = [
'labels' => [],
'users' => [
'how_are_you_feel' => [],
'climate_on_your_organization' => [],
],
'points' => [
'how_are_you_feel' => [],
'climate_on_your_organization' => [],
],
'average' => [
'how_are_you_feel' => [],
'climate_on_your_organization' => [],
],
'how_are_you_feel' => [
'average_points' => 0,
'average_users' => 0,
],
'climate_on_your_organization' => [
'average_points' => 0,
'average_users' => 0,
]
];
$how_are_you_feel_points = 0;
$how_are_you_feel_users = 0;
$climate_on_your_organization_points = 0;
$climate_on_your_organization_users = 0;
$count = 0;
$dt = \DateTime::createFromFormat('Y-m-d', $startDate);
do {
$count++;
$date = $dt->format('Y-m-d');
$label = $dt->format('d/m/Y');
array_push($data['labels'], $label);
$points = 0;
$users = 0;
foreach($how_are_you_feel as $record)
{
if($date == $record['date']) {
$points = $record['points'];
$users = $record['users'];
}
}
array_push($data['points']['how_are_you_feel'], $points);
array_push($data['users']['how_are_you_feel'], $users);
array_push($data['average']['how_are_you_feel'], $users ? $points / $users : 0);
$how_are_you_feel_points += $points;
$how_are_you_feel_users += $users;
$points = 0;
$users = 0;
foreach($climate_on_your_organization as $record)
{
if($date == $record['date']) {
$points = $record['points'];
$users = $record['users'];
}
}
array_push($data['points']['climate_on_your_organization'], $points);
array_push($data['users']['climate_on_your_organization'], $users);
array_push($data['average']['climate_on_your_organization'], $users ? $points / $users : 0);
$climate_on_your_organization_points += $points;
$climate_on_your_organization_users += $users;
$dt->add(new \DateInterval('P1D'));
} while($date < $endDate);
$data['how_are_you_feel']['average_points'] = number_format($how_are_you_feel_points / $count, 2);
$data['how_are_you_feel']['average_users'] = number_format($how_are_you_feel_users / $count, 2);
$data['climate_on_your_organization']['average_points'] = number_format($climate_on_your_organization_points / $count, 2);
$data['climate_on_your_organization']['average_users'] = number_format($climate_on_your_organization_users / $count, 2);
return new JsonModel([
'success' => true,
'data' => $data,
]);
} else {
$this->layout()->setTemplate('layout/layout-backend');
$viewModel = new ViewModel();
$viewModel->setTemplate('leaders-linked/daily-pulse-reports/overview.phtml');
return $viewModel ;
}
} else {
return new JsonModel([
'success' => false,
'data' => 'ERROR_METHOD_NOT_ALLOWED'
]);
}
}
public function overviewDownloadAction()
{
$currentUserPlugin = $this->plugin('currentUserPlugin');
$currentUser = $currentUserPlugin->getUser();
$currentNetworkPlugin = $this->plugin('currentNetworkPlugin');
$currentNetwork = $currentNetworkPlugin->getNetwork();
$companyMapper = CompanyMapper::getInstance($this->adapter);
$company = $companyMapper->fetchDefaultForNetworkByNetworkId($currentNetwork->id);
$request = $this->getRequest();
if($request->isGet())
{
$startDate = $this->params()->fromQuery('startDate');
if(empty($startDate)) {
$startDate = date('Y-m-d');
}
$endDate = $this->params()->fromQuery('endDate');
if(empty($startDate)) {
$endDate = date('Y-m-d');
}
//$startDate = '2023-03-01';
//$endDate = '2023-03-19';
$dtStartDate = \DateTime::createFromFormat('Y-n-d', $startDate);
$dtEndDate = \DateTime::createFromFormat('Y-n-d', $endDate);
if(!$dtStartDate || !$dtEndDate) {
$startDate = date('Y-m-d');
$endDate = date('Y-m-d');
} else {
if($dtStartDate->getTimestamp() > $dtEndDate->getTimestamp()) {
$startDate = date('Y-m-d');
$endDate = date('Y-m-d');
}
}
$dailyPulseRecordMapper = DailyPulseRecordMapper::getInstance($this->adapter);
$how_are_you_feel = $dailyPulseRecordMapper->fetchAllDataChartOrExcelByCompanyIdAndTypeAndDateRange($company->id, DailyPulseRecord::TYPE_HOW_ARE_YOU_FEEL, $startDate, $endDate);
$climate_on_your_organization = $dailyPulseRecordMapper->fetchAllDataChartOrExcelByCompanyIdAndTypeAndDateRange($company->id, DailyPulseRecord::TYPE_CLIMATE_ON_YOUR_ORGANIZATION, $startDate, $endDate);
$data = [
'labels' => [],
'average' => [
'how_are_you_feel' => [],
'climate_on_your_organization' => [],
],
'users' => [
'how_are_you_feel' => [],
'climate_on_your_organization' => [],
],
'points' => [
'how_are_you_feel' => [],
'climate_on_your_organization' => [],
],
'how_are_you_feel' => [
'average_points' => 0,
'average_users' => 0,
],
'climate_on_your_organization' => [
'average_points' => 0,
'average_users' => 0,
]
];
$how_are_you_feel_points = 0;
$how_are_you_feel_users = 0;
$climate_on_your_organization_points = 0;
$climate_on_your_organization_users = 0;
$count = 0;
$dt = \DateTime::createFromFormat('Y-m-d', $startDate);
do {
$count++;
$date = $dt->format('Y-m-d');
$label = $dt->format('d/m/Y');
array_push($data['labels'], $label);
$points = 0;
$users = 0;
foreach($how_are_you_feel as $record)
{
if($date == $record['date']) {
$points = $record['points'];
$users = $record['users'];
}
}
array_push($data['points']['how_are_you_feel'], $points);
array_push($data['users']['how_are_you_feel'], $users);
array_push($data['average']['how_are_you_feel'], $users ? $points / $users : 0);
$how_are_you_feel_points += $points;
$how_are_you_feel_users += $users;
$points = 0;
$users = 0;
foreach($climate_on_your_organization as $record)
{
if($date == $record['date']) {
$points = $record['points'];
$users = $record['users'];
}
}
array_push($data['points']['climate_on_your_organization'], $points);
array_push($data['users']['climate_on_your_organization'], $users);
array_push($data['average']['climate_on_your_organization'], $users ? $points / $users : 0);
$climate_on_your_organization_points += $points;
$climate_on_your_organization_users += $users;
$dt->add(new \DateInterval('P1D'));
} while($date < $endDate);
$data['how_are_you_feel']['average_points'] = number_format($how_are_you_feel_points / $count, 2);
$data['how_are_you_feel']['average_users'] = number_format($how_are_you_feel_users / $count, 2);
$data['climate_on_your_organization']['average_points'] = number_format($climate_on_your_organization_points / $count, 2);
$data['climate_on_your_organization']['average_users'] = number_format($climate_on_your_organization_users / $count, 2);
$spreadsheet = new Spreadsheet();
$spreadsheet->getProperties()->setTitle('Pulso Diario');
$spreadsheet->setActiveSheetIndex(0);
$dt = \DateTime::createFromFormat('Y-m-d', $startDate);
$spreadsheet->getActiveSheet()->SetCellValue('A1', 'Desde:');
$spreadsheet->getActiveSheet()->SetCellValue('B1', $dt->format('d/m/Y'));
$dt = \DateTime::createFromFormat('Y-m-d', $startDate);
$spreadsheet->getActiveSheet()->SetCellValue('C1', 'Hasta:');
$spreadsheet->getActiveSheet()->SetCellValue('D1', $dt->format('d/m/Y'));
$spreadsheet->getActiveSheet()->SetCellValue('A3', 'Como te sientes hoy');
$spreadsheet->getActiveSheet()->setMergeCells(['A3', 'B3', 'C3', 'D3']);
$spreadsheet->getActiveSheet()->SetCellValue('A4', 'Puntos promedios');
$spreadsheet->getActiveSheet()->SetCellValue('B4', $data['how_are_you_feel']['average_points']);
$spreadsheet->getActiveSheet()->SetCellValue('C4', 'Usuarios promedios');
$spreadsheet->getActiveSheet()->SetCellValue('D4', $data['how_are_you_feel']['average_users']);
$spreadsheet->getActiveSheet()->SetCellValue('F3', 'Clima en su organización');
$spreadsheet->getActiveSheet()->setMergeCells(['F3', 'G3', 'H3', 'I3']);
$spreadsheet->getActiveSheet()->SetCellValue('F4', 'Puntos promedios');
$spreadsheet->getActiveSheet()->SetCellValue('G4', $data['climate_on_your_organization']['average_points']);
$spreadsheet->getActiveSheet()->SetCellValue('H4', 'Usuarios promedios');
$spreadsheet->getActiveSheet()->SetCellValue('I4', $data['climate_on_your_organization']['average_users']);
$spreadsheet->getActiveSheet()->SetCellValue('A6', 'Usuarios');
$spreadsheet->getActiveSheet()->setMergeCells(['A6', 'B6', 'C6']);
$spreadsheet->getActiveSheet()->SetCellValue('A7', 'Fecha');
$spreadsheet->getActiveSheet()->SetCellValue('B7', 'Puntos promedios');
$spreadsheet->getActiveSheet()->SetCellValue('C7', 'Cantidad de usuarios');
$row = 8;
$max = count($data['labels']);
for($i = 0; $i< $max; $i++)
{
$spreadsheet->getActiveSheet()->SetCellValue('A' . $row, $data['labels'][$i]);
$spreadsheet->getActiveSheet()->SetCellValue('B' . $row, $data['users']['how_are_you_feel'][$i]);
$spreadsheet->getActiveSheet()->SetCellValue('C' . $row, $data['users']['climate_on_your_organization'][$i]);
$row++;
}
$spreadsheet->getActiveSheet()->SetCellValue('F6', 'Puntos');
$spreadsheet->getActiveSheet()->setMergeCells(['F6', 'G6', 'H6']);
$spreadsheet->getActiveSheet()->SetCellValue('F7', 'Fecha');
$spreadsheet->getActiveSheet()->SetCellValue('G7', 'Puntos promedios');
$spreadsheet->getActiveSheet()->SetCellValue('H7', 'Cantidad de usuarios');
$row = 8;
$max = count($data['labels']);
for($i = 0; $i< $max; $i++)
{
$spreadsheet->getActiveSheet()->SetCellValue('F' . $row, $data['labels'][$i]);
$spreadsheet->getActiveSheet()->SetCellValue('G' . $row, $data['points']['how_are_you_feel'][$i]);
$spreadsheet->getActiveSheet()->SetCellValue('H' . $row, $data['points']['climate_on_your_organization'][$i]);
$row++;
}
$spreadsheet->getActiveSheet()->SetCellValue('J6', 'Puntos promedios ( puntos / usuarios ) ');
$spreadsheet->getActiveSheet()->setMergeCells(['J6', 'K6', 'L6']);
$spreadsheet->getActiveSheet()->SetCellValue('J7', 'Fecha');
$spreadsheet->getActiveSheet()->SetCellValue('K7', 'Puntos promedios');
$spreadsheet->getActiveSheet()->SetCellValue('L7', 'Cantidad de usuarios');
$row = 8;
$max = count($data['labels']);
for($i = 0; $i< $max; $i++)
{
$spreadsheet->getActiveSheet()->SetCellValue('J' . $row, $data['labels'][$i]);
$spreadsheet->getActiveSheet()->SetCellValue('K' . $row, number_format($data['average']['how_are_you_feel'][$i], 2));
$spreadsheet->getActiveSheet()->SetCellValue('L' . $row, number_format($data['average']['climate_on_your_organization'][$i], 2));
$row++;
}
$fileName = 'reporte_pulso_diario_' . date('d-m-Y-h-i-a', time()) . '.xls';
$tempFilename = tempnam(sys_get_temp_dir(), 'reporte_pulso_diario_' . time());
$writer = IOFactory::createWriter($spreadsheet, 'Xlsx');
$writer->save($tempFilename);
$content = file_get_contents($tempFilename);
@unlink($tempFilename);
return new JsonModel([
'success' => true,
'data' => [
'content' => base64_encode($content),
'basename' => $fileName
]
]);
} else {
return new JsonModel([
'success' => false,
'data' => 'ERROR_METHOD_NOT_ALLOWED'
]);
}
}
}