Files
crm.clientright.ru/modules/Workflow2/extends/interfaceFiles/Sqlreports.inc.php

107 lines
3.5 KiB
PHP
Raw Normal View History

<?php
/**
* Created by JetBrains PhpStorm.
* User: Stefan Warnat <support@stefanwarnat.de>
* Date: 01.06.14 12:04
* You must not use this file without permission.
*/
namespace Workflow\Plugins\InterfaceFiles;
class SQLReports extends \Workflow\InterfaceFiles {
protected $title = 'SQL Reports';
protected $key = 'sqlreport';
public function __construct() {
if(!$this->isModuleActive()) {
return;
}
}
protected function _getFile($id, $moduleName, $crmid) {
if(!$this->isModuleActive()) {
return false;
}
$adb = \PearDatabase::getInstance();
$parts = explode('#', $id);
$tmpFilename = $this->_getTmpFilename();
if($parts[0] == 'pdf') {
}
$sql = 'SELECT * FROM vtiger_sqlreports WHERE sqlreportsid = '.$parts[1];
$result = $adb->query($sql);
$row = $adb->fetchByAssoc($result);
switch($parts[0]) {
case 'pdf':
$file_name = "Report_".preg_replace('/[^A-Za-z0-9-_]/', '_', $row['reportname']).".pdf";
$this->_createPDF($tmpFilename, $parts[1]);
$type = 'application/pdf';
break;
case 'xls':
$file_name = "Report_".preg_replace('/[^A-Za-z0-9-_]/', '_', $row['reportname']).".xls";
$this->_createXLS($tmpFilename, $parts[1]);
$type = 'application/x-msexcel';
break;
case 'csv':
$file_name = "Report_".preg_replace('/[^A-Za-z0-9-_]/', '_', $row['reportname']).".csv";
$this->_createCSV($tmpFilename, $parts[1]);
$type = 'application/csv';
break;
}
return array(
'path' => $tmpFilename,
'type' => $type,
'name' => $file_name
);
}
private function _createPDF($tmpFile, $reportId) {
$reportModel = \SQLReports_Record_Model::getInstanceById($reportId);
$pdf = $reportModel->getReportPDF();
$pdf->Output($tmpFile, 'F');
}
private function _createCSV($tmpFile, $reportId) {
vimport('~~/modules/SQLReports/ReportRunSQL.php');
$reportRun = \ReportRunSQL::getInstance($reportId);
$reportRun->writeReportToCSVFile($tmpFile, false);
}
private function _createXLS($tmpFile, $reportId) {
vimport('~~/modules/SQLReports/ReportRunSQL.php');
/**
* @var $reportRun \ReportRunSQL
*/
$reportRun = \ReportRunSQL::getInstance($reportId);
$reportRun->writeReportToExcelFile($tmpFile, false);
}
protected function _getAvailableFiles($moduleName) {
$return = array();
if(!$this->isModuleActive()) {
return $return;
}
$adb = \PearDatabase::getInstance();
$sql = 'SELECT * FROM vtiger_sqlreports ORDER BY reportname';
$result = $adb->query($sql);
$reports = array();
while($row = $adb->fetchByAssoc($result)) {
$return['pdf#'.$row['sqlreportsid']] = 'SQLReport - '.$row["reportname"]. ' PDF';
$return['xls#'.$row['sqlreportsid']] = 'SQLReport - '.$row["reportname"]. ' XLS';
$return['csv#'.$row['sqlreportsid']] = 'SQLReport - '.$row["reportname"]. ' CSV';
}
return $return;
}
public function isModuleActive() {
return getTabid('SQLReports') && vtlib_isModuleActive('SQLReports');
}
}
\Workflow\InterfaceFiles::register('sqlreport', '\Workflow\Plugins\InterfaceFiles\SQLReports');