1617 lines
51 KiB
PHP
1617 lines
51 KiB
PHP
<?php
|
||
|
||
require_once("class.enka.rtf.php");
|
||
require_once('../../vendor/autoload.php');
|
||
include_once('../exportclases/class.rtfIzvozAnalizaFunctions.php');
|
||
include_once('../../function.php');
|
||
include_once('../survey/definition.php');
|
||
|
||
|
||
define("FNT_TIMES", "Times New Roman", true);
|
||
define("FNT_ARIAL", "Arial", true);
|
||
|
||
define("FNT_MAIN_TEXT", FNT_TIMES, true);
|
||
define("FNT_QUESTION_TEXT", FNT_TIMES, true);
|
||
define("FNT_HEADER_TEXT", FNT_TIMES, true);
|
||
|
||
define("FNT_MAIN_SIZE", 12, true);
|
||
define("FNT_QUESTION_SIZE", 10, true);
|
||
define("FNT_HEADER_SIZE", 10, true);
|
||
|
||
|
||
class RtfIzvozAnalizaCReport {
|
||
|
||
var $ank_id; // trenutna anketa
|
||
var $usr_id; // trenutni user
|
||
|
||
var $printPreview = false; // ali kli?e konstruktor
|
||
var $pi=array('canCreate'=>false); // za shrambo parametrov in sporocil
|
||
var $rtf;
|
||
|
||
private $headFileName = null; # pot do header fajla
|
||
private $dataFileName = null; # pot do data fajla
|
||
private $dataFileStatus = null; # status data datoteke
|
||
|
||
var $creportProfile = 0; // Izbran profil porocila
|
||
|
||
var $sessionData; // podatki ki so bili prej v sessionu - za nastavitve, ki se prenasajo v izvoze...
|
||
|
||
|
||
/**
|
||
* @desc konstruktor
|
||
*/
|
||
function __construct ($anketa = null)
|
||
{
|
||
global $site_path;
|
||
global $global_user_id;
|
||
|
||
// preverimo ali imamo stevilko ankete
|
||
if ( is_numeric($anketa) )
|
||
{
|
||
$this->ank_id = $anketa;
|
||
|
||
SurveyAnalysis::Init($this->ank_id);
|
||
SurveyAnalysis::$setUpJSAnaliza = false;
|
||
|
||
// Nastavimo pravi profil porocila
|
||
$this->creportProfile = SurveyUserSetting :: getInstance()->getSettings('default_creport_profile');
|
||
$this->creportProfile = isset($this->creportProfile) ? $this->creportProfile : 0;
|
||
|
||
// Testiramo kako je obrnjen dokument (ce vsebuje crosstabe, means ali ttest je lanscape)
|
||
$orientation = ($this->landscapeTest()) ? true : false;
|
||
|
||
// create new RTF document
|
||
$this->rtf = new enka_RTF($orientation);
|
||
|
||
// Poskrbimo za datoteko s podatki
|
||
$SDF = SurveyDataFile::get_instance();
|
||
$SDF->init($this->ank_id);
|
||
$SDF->prepareFiles();
|
||
|
||
$this->headFileName = $SDF->getHeaderFileName();
|
||
$this->dataFileName = $SDF->getDataFileName();
|
||
$this->dataFileStatus = $SDF->getStatus();
|
||
|
||
// Inicializiramo in polovimo nastavitve missing profila
|
||
SurveyStatusProfiles::Init($this->ank_id);
|
||
|
||
SurveyMissingProfiles :: Init($this->ank_id,$global_user_id);
|
||
SurveyConditionProfiles :: Init($this->ank_id, $global_user_id);
|
||
SurveyZankaProfiles :: Init($this->ank_id, $global_user_id);
|
||
SurveyTimeProfiles :: Init($this->ank_id, $global_user_id);
|
||
|
||
SurveyDataSettingProfiles :: Init($this->ank_id);
|
||
|
||
//polovimo podatke o nastavitvah trenutnega profila (missingi..)
|
||
SurveyAnalysis::$missingProfileData = SurveyMissingProfiles::getProfile(SurveyAnalysis::$currentMissingProfile);
|
||
#preberemo HEADERS iz datoteke
|
||
SurveyAnalysis::$_HEADERS = unserialize(file_get_contents($this->headFileName));
|
||
# odstranimo sistemske variable tipa email, ime, priimek, geslo
|
||
SurveyAnalysis::removeSystemVariables();
|
||
# polovimo frekvence
|
||
SurveyAnalysis::getFrequencys();
|
||
|
||
// preberemo nastavitve iz baze (prej v sessionu)
|
||
SurveyUserSession::Init($this->ank_id);
|
||
$this->sessionData = SurveyUserSession::getData();
|
||
}
|
||
else
|
||
{
|
||
$this->pi['msg'] = "Anketa ni izbrana!";
|
||
$this->pi['canCreate'] = false;
|
||
return false;
|
||
}
|
||
if ( SurveyInfo::getInstance()->SurveyInit($this->ank_id) && $this->init())
|
||
{
|
||
$this->usr_id = $global_user_id;
|
||
SurveyUserSetting::getInstance()->Init($this->ank_id, $this->usr_id);
|
||
}
|
||
else
|
||
return false;
|
||
|
||
// ce smo prisli do tu je vse ok
|
||
$this->pi['canCreate'] = true;
|
||
|
||
return true;
|
||
}
|
||
|
||
function checkCreate()
|
||
{
|
||
return $this->pi['canCreate'];
|
||
}
|
||
|
||
function getFile($fileName)
|
||
{
|
||
//Close and output rtf document
|
||
// $this->rtf->Output($fileName, 'I');
|
||
$this->rtf->display($fileName = "analiza.rtf",true);
|
||
}
|
||
|
||
|
||
function init()
|
||
{
|
||
global $lang;
|
||
|
||
// dodamo avtorja in naslov
|
||
$this->rtf->WriteTitle();
|
||
$this->rtf->WriteHeader($this->encodeText(SurveyInfo::getInstance()->getSurveyAkronim()), 'left');
|
||
$this->rtf->WriteHeader($this->encodeText(SurveyInfo::getInstance()->getSurveyAkronim()), 'right');
|
||
$this->rtf->WriteFooter($lang['page']." {PAGE} / {NUMPAGES}", 'right');
|
||
$this->rtf->set_default_font(FNT_TIMES, FNT_MAIN_SIZE);
|
||
return true;
|
||
}
|
||
|
||
function createRtf()
|
||
{
|
||
global $site_path;
|
||
global $lang;
|
||
|
||
// izpisemo prvo stran
|
||
//$this->createFrontPage();
|
||
|
||
$what = 'creport_title_profile_'.$this->creportProfile;
|
||
$sql = sisplet_query("SELECT value FROM srv_user_setting_for_survey WHERE sid='$this->ank_id' AND uid='$this->usr_id' AND what='$what'");
|
||
|
||
if(mysqli_num_rows($sql) == 0){
|
||
$titleString = $lang['export_analisys_creport'].': '.SurveyInfo::getInstance()->getSurveyTitle();
|
||
}
|
||
else{
|
||
$row = mysqli_fetch_array($sql);
|
||
$titleString = $row['value'];
|
||
}
|
||
|
||
$this->rtf->draw_title($this->encodeText($titleString));
|
||
|
||
$this->rtf->MyRTF .= $this->rtf->_font_size(16);
|
||
|
||
$sql = sisplet_query("SELECT * FROM srv_custom_report WHERE ank_id='$this->ank_id' AND usr_id='$this->usr_id' AND profile='$this->creportProfile' ORDER BY vrstni_red ASC");
|
||
if(mysqli_num_rows($sql) > 0){
|
||
|
||
// Loop po vseh dodanih elementih porocila
|
||
while($row = mysqli_fetch_array($sql)){
|
||
|
||
switch($row['type']){
|
||
|
||
// sumarnik
|
||
case '1':
|
||
// naslov elementa
|
||
$this->displayTitle($row);
|
||
|
||
$this->displaySum($row);
|
||
|
||
// Komentar elementa
|
||
$this->displayComment($row['text']);
|
||
|
||
break;
|
||
|
||
// frekvence
|
||
case '2':
|
||
// naslov elementa
|
||
$this->displayTitle($row);
|
||
|
||
$this->displayFreq($row);
|
||
|
||
// Komentar elementa
|
||
$this->displayComment($row['text']);
|
||
|
||
break;
|
||
|
||
// opisne
|
||
case '3':
|
||
// naslov elementa
|
||
$this->displayTitle($row);
|
||
|
||
$this->displayDesc($row);
|
||
|
||
// Komentar elementa
|
||
$this->displayComment($row['text']);
|
||
|
||
break;
|
||
|
||
// grafi
|
||
case '4':
|
||
// naslov elementa
|
||
$this->displayTitle($row);
|
||
|
||
$this->displayChart($row);
|
||
|
||
// Komentar elementa
|
||
$this->displayComment($row['text']);
|
||
|
||
break;
|
||
|
||
// crosstab
|
||
case '5':
|
||
// naslov elementa
|
||
$this->displayTitle($row);
|
||
|
||
// tabela
|
||
if($row['sub_type'] == '0')
|
||
$this->displayCrosstab($row);
|
||
// graf
|
||
else
|
||
$this->displayCrosstabChart($row);
|
||
|
||
// Komentar elementa
|
||
$this->displayComment($row['text']);
|
||
|
||
break;
|
||
|
||
// mean
|
||
case '6':
|
||
// naslov elementa
|
||
$this->displayTitle($row);
|
||
|
||
// tabela
|
||
if($row['sub_type'] == '0')
|
||
$this->displayMean($row);
|
||
// graf
|
||
else
|
||
$this->displayMeanChart($row);
|
||
|
||
// Komentar elementa
|
||
$this->displayComment($row['text']);
|
||
|
||
break;
|
||
|
||
// ttest
|
||
case '7':
|
||
// naslov elementa
|
||
$this->displayTitle($row);
|
||
|
||
// tabela
|
||
if($row['sub_type'] == '0')
|
||
$this->displayTTest($row);
|
||
// graf
|
||
else
|
||
$this->displayTTestChart($row);
|
||
|
||
// Komentar elementa
|
||
$this->displayComment($row['text']);
|
||
|
||
break;
|
||
|
||
// text
|
||
case '8':
|
||
$this->displayText($row['text']);
|
||
|
||
break;
|
||
|
||
// break
|
||
case '9':
|
||
// naslov elementa
|
||
$this->displayTitle($row);
|
||
|
||
// tabela
|
||
if($row['sub_type'] == '0')
|
||
$this->displayBreak($row);
|
||
// graf
|
||
else
|
||
$this->displayBreakChart($row);
|
||
|
||
// Komentar elementa
|
||
$this->displayComment($row['text']);
|
||
|
||
break;
|
||
|
||
// page break
|
||
case '-1':
|
||
$this->rtf->new_page();
|
||
|
||
break;
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
|
||
// Izpisemo sumarnik element
|
||
function displaySum($element){
|
||
|
||
$spid = $element['spr1'];
|
||
$spremenljivka = SurveyAnalysis::$_HEADERS[$spid];
|
||
|
||
# preverjamo ali je meta
|
||
if (($spremenljivka['tip'] != 'm')
|
||
&& (!isset($_spid) || (isset($_spid) && $_spid == $spid))
|
||
&& (($global_user_id === 0 || $global_user_id === null) || in_array($spremenljivka['tip'], SurveyAnalysis::$_FILTRED_TYPES ) )) {
|
||
|
||
# ali imamo sfiltrirano spremenljivko
|
||
//if (isset(SurveyAnalysis::$_FILTRED_VARIABLES[$spid])) {
|
||
|
||
rtfIzvozAnalizaFunctions::init($this->ank_id, $this, $from='sums');
|
||
|
||
# prikazujemo v odvisnosti od kategorije spremenljivke
|
||
switch ($spremenljivka['tip']) {
|
||
case 1:
|
||
# radio - prikaže navpično
|
||
rtfIzvozAnalizaFunctions::sumVertical($spid,'sums');
|
||
break;
|
||
|
||
case 2:
|
||
#checkbox če je dihotomna:
|
||
rtfIzvozAnalizaFunctions::sumVerticalCheckbox($spid,'sums');
|
||
break;
|
||
|
||
case 3:
|
||
# dropdown - prikjaže navpično
|
||
rtfIzvozAnalizaFunctions::sumVertical($spid,'sums');
|
||
break;
|
||
|
||
case 6:
|
||
# multigrid
|
||
rtfIzvozAnalizaFunctions::sumHorizontal($spid,'sums');
|
||
break;
|
||
|
||
case 16:
|
||
#multicheckbox če je dihotomna:
|
||
rtfIzvozAnalizaFunctions::sumMultiHorizontalCheckbox($spid,'sums');
|
||
break;
|
||
|
||
case 17:
|
||
#razvrščanje če je ordinalna
|
||
rtfIzvozAnalizaFunctions::sumHorizontal($spid,'sums');
|
||
break;
|
||
|
||
case 4: # text
|
||
case 8: # datum
|
||
rtfIzvozAnalizaFunctions::sumTextVertical($spid,'sums');
|
||
break;
|
||
|
||
case 21: # besedilo*
|
||
# varabla tipa »besedilo« je v sumarniku IDENTIČNA kot v FREKVENCAH.
|
||
if ($spremenljivka['cnt_all'] == 1) {
|
||
// če je enodimenzionalna prikažemo kot frekvence
|
||
// predvsem zaradi vprašanj tipa: language, email...
|
||
rtfIzvozAnalizaFunctions::sumTextVertical($spid,'sums');
|
||
} else {
|
||
rtfIzvozAnalizaFunctions::sumMultiText($spid,'sums');
|
||
}
|
||
break;
|
||
|
||
case 19: # multitext
|
||
rtfIzvozAnalizaFunctions::sumMultiText($spid,'sums');
|
||
break;
|
||
|
||
case 7:
|
||
case 18:
|
||
case 22:
|
||
# variabla tipa »število« je v sumarniku identična kot v DESCRIPTIVES.
|
||
rtfIzvozAnalizaFunctions::sumNumberVertical($spid,'sums');
|
||
break;
|
||
|
||
case 20:
|
||
# variabla tipa »število« je v sumarniku identična kot v DESCRIPTIVES.
|
||
rtfIzvozAnalizaFunctions::sumMultiNumber($spid,'sums');
|
||
break;
|
||
|
||
case 5:
|
||
# nagovor
|
||
rtfIzvozAnalizaFunctions::sumNagovor($spid,'sums');
|
||
break;
|
||
}
|
||
|
||
//}
|
||
|
||
} // end if $spremenljivka['tip'] != 'm'
|
||
}
|
||
|
||
// Izpisemo frekvence element
|
||
function displayFreq($element){
|
||
|
||
$spid = $element['spr1'];
|
||
$spremenljivka = SurveyAnalysis::$_HEADERS[$spid];
|
||
|
||
# preverjamo ali je meta
|
||
if (($spremenljivka['tip'] != 'm')
|
||
&& (!isset($_spid) || (isset($_spid) && $_spid == $spid))
|
||
&& (($global_user_id === 0 || $global_user_id === null) || in_array($spremenljivka['tip'], SurveyAnalysis::$_FILTRED_TYPES ) )) {
|
||
|
||
# ali imamo sfiltrirano spremenljivko
|
||
//if (isset(SurveyAnalysis::$_FILTRED_VARIABLES[$spid])) {
|
||
|
||
rtfIzvozAnalizaFunctions::init($this->ank_id, $this, $from='freq');
|
||
|
||
# prikazujemo v odvisnosti od kategorije spremenljivke
|
||
switch ($spremenljivka['tip']) {
|
||
case 1: # radio - prikjaže navpično
|
||
case 2: #checkbox če je dihotomna:
|
||
case 3: # dropdown - prikjaže navpično
|
||
case 6: # multigrid
|
||
case 4: # text
|
||
case 7:# variabla tipa »število«
|
||
case 8: # datum
|
||
case 16: #multicheckbox če je dihotomna:
|
||
case 17: #razvrščanje če je ordinalna
|
||
case 18: # vsota
|
||
case 19: # multitext
|
||
case 20: # multi number
|
||
case 21: # besedilo*
|
||
case 22: # kalkulacija
|
||
rtfIzvozAnalizaFunctions::frequencyVertical($spid);
|
||
break;
|
||
case 5:
|
||
# nagovor
|
||
rtfIzvozAnalizaFunctions::sumNagovor($spid,'freq');
|
||
break;
|
||
}
|
||
//}
|
||
|
||
} // end if $spremenljivka['tip'] != 'm'
|
||
}
|
||
|
||
// Izpisemo opisne stat element
|
||
function displayDesc($element){
|
||
global $lang;
|
||
|
||
# polovimo frekvence
|
||
SurveyAnalysis::getDescriptives();
|
||
|
||
$spid = $element['spr1'];
|
||
$spremenljivka = SurveyAnalysis::$_HEADERS[$spid];
|
||
|
||
rtfIzvozAnalizaFunctions::init($this->ank_id, $this, $from='desc');
|
||
|
||
rtfIzvozAnalizaFunctions::descTableHeader();
|
||
|
||
# preverjamo ali je meta
|
||
if ($spremenljivka['tip'] != 'm'
|
||
&& ( count(SurveyAnalysis::$_FILTRED_VARIABLES) == 0 || (count(SurveyAnalysis::$_FILTRED_VARIABLES) > 0 && isset(SurveyAnalysis::$_FILTRED_VARIABLES[$spid]) ))
|
||
&& in_array($spremenljivka['tip'], SurveyAnalysis::$_FILTRED_TYPES)) {
|
||
|
||
$show_enota = false;
|
||
# preverimo ali imamo samo eno variablo in če iammo enoto
|
||
if ((int)$spremenljivka['enota'] != 0 || $spremenljivka['cnt_all'] > 1 ) {
|
||
$show_enota = true;
|
||
}
|
||
|
||
# izpišemo glavno vrstico z podatki
|
||
$_sequence = null;
|
||
# za enodimenzijske tipe izpišemo podatke kar v osnovni vrstici
|
||
if (!$show_enota) {
|
||
// if ($spremenljivka['tip'] == 1 || $spremenljivka['tip'] == 3
|
||
// || $spremenljivka['tip'] == 4 || $spremenljivka['tip'] == 7 || $spremenljivka['tip'] == 8) {
|
||
$variable = $spremenljivka['grids'][0]['variables'][0];
|
||
$_sequence = $variable['sequence']; # id kolone z podatki
|
||
rtfIzvozAnalizaFunctions::displayDescriptivesSpremenljivkaRow($spid, $spremenljivka,$show_enota,$_sequence);
|
||
} else {
|
||
if ($spremenljivka['tip'] == 1 || $spremenljivka['tip'] == 3) {
|
||
$variable = $spremenljivka['grids'][0]['variables'][0];
|
||
$_sequence = $variable['sequence']; # id kolone z podatki
|
||
$show_enota = false;
|
||
}
|
||
rtfIzvozAnalizaFunctions::displayDescriptivesSpremenljivkaRow($spid, $spremenljivka,$show_enota,$_sequence);
|
||
#zloopamo skozi variable
|
||
$_sequence = null;
|
||
$grd_cnt=0;
|
||
if (count($spremenljivka['grids']) > 0)
|
||
foreach ($spremenljivka['grids'] AS $gid => $grid) {
|
||
|
||
if (count($spremenljivka['grids']) > 1 && $grd_cnt !== 0 && $spremenljivka['tip'] != 6) {
|
||
$grid['new_grid'] = true;
|
||
}
|
||
$grd_cnt++;
|
||
# dodamo dodatne vrstice z albelami grida
|
||
if (count ($grid['variables']) > 0)
|
||
foreach ($grid['variables'] AS $vid => $variable ){
|
||
# dodamo ostale vrstice
|
||
$do_show = ($variable['other'] !=1 && ($spremenljivka['tip'] == 1 || $spremenljivka['tip'] == 3 || $spremenljivka['tip'] == 5 || $spremenljivka['tip'] == 8 ))
|
||
? false
|
||
: true;
|
||
if ($do_show) {
|
||
rtfIzvozAnalizaFunctions::displayDescriptivesVariablaRow($spremenljivka,$grid,$variable);
|
||
|
||
}
|
||
$grid['new_grid'] = false;
|
||
|
||
}
|
||
}
|
||
} //else: if (!$show_enota)
|
||
|
||
rtfIzvozAnalizaFunctions::tableEnd();
|
||
|
||
} // end if $spremenljivka['tip'] != 'm'
|
||
}
|
||
|
||
// Izpisemo graf element
|
||
function displayChart($element){
|
||
|
||
$spid = $element['spr1'];
|
||
$spremenljivka = SurveyAnalysis::$_HEADERS[$spid];
|
||
|
||
# preverjamo ali je meta
|
||
if (($spremenljivka['tip'] != 'm'
|
||
&& in_array($spremenljivka['tip'], SurveyAnalysis::$_FILTRED_TYPES ))
|
||
&& (!isset($_spid) || (isset($_spid) && $_spid == $spid))) {
|
||
# ali imamo sfiltrirano spremenljivko
|
||
//if ($vars_count == 0 || ($vars_count > 0 && isset(SurveyAnalysis::$_FILTRED_VARIABLES[$spid]) ) ) {
|
||
|
||
// Ce imamo radio tip in manj kot 5 variabel po defaultu prikazemo piechart
|
||
$vars = count($spremenljivka['options']);
|
||
$type = 0;
|
||
if( ($spremenljivka['tip'] == 1 || $spremenljivka['tip'] == 3) && $vars < 5 )
|
||
$type = 2;
|
||
|
||
//ce imamo nominalno spremenljivko ali ce je samo 1 variabla nimamo povprecij
|
||
if($spremenljivka['tip'] == 6 && ($spremenljivka['cnt_all'] == 1 || $spremenljivka['skala'] == 1) && $type == 0 )
|
||
$type = 2;
|
||
|
||
rtfIzvozAnalizaFunctions::init($this->ank_id, $this, $from='charts');
|
||
|
||
if($spremenljivka['tip'] == 4 || $spremenljivka['tip'] == 19 || $spremenljivka['tip'] == 21 || $spremenljivka['tip'] == 22){
|
||
// ce imamo vklopljeno nastavitev prikaz tabel med grafi (default)
|
||
if($spremenljivka['tip'] == 19)
|
||
rtfIzvozAnalizaFunctions::sumMultiText($spid, 'sums');
|
||
else
|
||
rtfIzvozAnalizaFunctions::frequencyVertical($spid);
|
||
}
|
||
elseif( in_array($spremenljivka['tip'],array(1,2,3,6,7,8,16,17,18,20)) ){
|
||
// Prikazemo posamezen graf
|
||
rtfIzvozAnalizaFunctions::displayChart($spid, $type);
|
||
}
|
||
//}
|
||
|
||
} // end if $spremenljivka['tip'] != 'm'
|
||
}
|
||
|
||
// Izpisemo crosstab tabelo
|
||
function displayCrosstab($element){
|
||
global $lang;
|
||
|
||
// Napolnimo podatke crosstabu
|
||
$crossData1 = explode("-", $element['spr1']);
|
||
$crossData2 = explode("-", $element['spr2']);
|
||
|
||
$crosstabClass = new SurveyCrosstabs();
|
||
$crosstabClass->Init($this->ank_id);
|
||
|
||
$crosstabClass->setVariables($crossData1[0],$crossData1[1],$crossData1[2],$crossData2[0],$crossData2[1],$crossData2[2]);
|
||
|
||
// Naslov
|
||
if($element['spr1'] == '' || $element['spr2'] == '')
|
||
$title = $lang['srv_select_spr'];
|
||
else{
|
||
$show_variables_values = true;
|
||
|
||
$spr1 = $crosstabClass->_HEADERS[$crossData1[1]];
|
||
$spr2 = $crosstabClass->_HEADERS[$crossData2[1]];
|
||
|
||
# za multicheckboxe popravimo naslov, na podtip
|
||
$sub_q1 = null;
|
||
$sub_q2 = null;
|
||
if ($spr1['tip'] == '6' || $spr1['tip'] == '7' || $spr1['tip'] == '16' || $spr1['tip'] == '17' || $spr1['tip'] == '18' || $spr1['tip'] == '19' || $spr1['tip'] == '20' || $spr1['tip'] == '21' ) {
|
||
foreach ($spr1['grids'] AS $grid) {
|
||
foreach ($grid['variables'] AS $variable) {
|
||
if ($variable['sequence'] == $v_first['seq']) {
|
||
$sub_q1 .= strip_tags($spr1['naslov']);
|
||
if ($show_variables_values == true ) {
|
||
$sub_q1 .= ' ('.strip_tags($spr1['variable']).')';
|
||
}
|
||
if ($spr1['tip'] == '16') {
|
||
$sub_q1 .= strip_tags($grid1['naslov']) . ($show_variables_values == true ? ' (' . strip_tags($grid1['variable']) . ')' : '');
|
||
} else {
|
||
$sub_q1 .= strip_tags($variable['naslov']) . ($show_variables_values == true ? ' (' . strip_tags($variable['variable']) . ')' : '');
|
||
}
|
||
}
|
||
}
|
||
}
|
||
}
|
||
if ($sub_q1 == null) {
|
||
$sub_q1 .= strip_tags($spr1['naslov']);
|
||
$sub_q1 .= ($show_variables_values == true ? ' ('.strip_tags($spr1['variable']).')' : '');
|
||
}
|
||
if ($spr2['tip'] == '6' || $spr2['tip'] == '7' || $spr2['tip'] == '16' || $spr2['tip'] == '17' || $spr2['tip'] == '18' || $spr2['tip'] == '19' || $spr2['tip'] == '20' || $spr2['tip'] == '21') {
|
||
foreach ($spr2['grids'] AS $grid) {
|
||
foreach ($grid['variables'] AS $variable) {
|
||
if ($variable['sequence'] == $v_second['seq']) {
|
||
$sub_q2 .= strip_tags($spr2['naslov']);
|
||
if ($show_variables_values == true) {
|
||
$sub_q2 .= ' ('.strip_tags($spr2['variable']).')';
|
||
}
|
||
if ($spr2['tip'] == '16') {
|
||
$sub_q2.= strip_tags($grid2['naslov']) . ($show_variables_values == true ? ' (' . strip_tags($grid2['variable']) . ')' : '');
|
||
} else {
|
||
$sub_q2.= strip_tags($variable['naslov']) . ($show_variables_values == true ? ' (' . strip_tags($variable['variable']) . ')' : '');
|
||
}
|
||
}
|
||
}
|
||
}
|
||
}
|
||
if ($sub_q2 == null) {
|
||
$sub_q2 .= strip_tags($spr2['naslov']);
|
||
$sub_q2 .= ($show_variables_values == true ? ' ('.strip_tags($spr2['variable']).')' : '');
|
||
}
|
||
|
||
$title = $sub_q1 . ' / ' . $sub_q2;
|
||
}
|
||
|
||
$subtitle = '('.$lang['srv_crosstabs']. ($element['sub_type'] == 1 ? ' - '.$lang['srv_chart'] : '') .')';
|
||
|
||
$title .= ' <span class="anl_ita">'.$subtitle.'</span>';
|
||
|
||
rtfIzvozAnalizaFunctions::init($this->ank_id, $this, $from='crosstab', $crosstabClass);
|
||
rtfIzvozAnalizaFunctions::displayCrosstabsTable();
|
||
}
|
||
|
||
// Izpisemo crosstab graf
|
||
function displayCrosstabChart($element){
|
||
// Napolnimo podatke crosstabu
|
||
$crossData1 = explode("-", $element['spr2']);
|
||
$crossData2 = explode("-", $element['spr1']);
|
||
|
||
$crosstabClass = new SurveyCrosstabs();
|
||
$crosstabClass->Init($this->ank_id);
|
||
|
||
|
||
// Ce iz breaka klicemo graf za crosstab tabelo moramo popravit grid
|
||
if($element['type'] == '9'){
|
||
foreach ($crosstabClass->_HEADERS[$crossData1[1]]['grids'] AS $gid => $grid) {
|
||
foreach ($grid['variables'] AS $vkey => $vrednost) {
|
||
if ($vrednost['sequence'] == $crossData1[0]) {
|
||
$crossData1[2] = $gid;
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
$crosstabClass->setVariables($crossData1[0],$crossData1[1],$crossData1[2],$crossData2[0],$crossData2[1],$crossData2[2]);
|
||
|
||
// Naslov
|
||
if($element['spr1'] == '' || $element['spr2'] == '')
|
||
$title = $lang['srv_select_spr'];
|
||
else{
|
||
$show_variables_values = true;
|
||
|
||
$spr1 = $crosstabClass->_HEADERS[$crossData1[1]];
|
||
$spr2 = $crosstabClass->_HEADERS[$crossData2[1]];
|
||
|
||
# za multicheckboxe popravimo naslov, na podtip
|
||
$sub_q1 = null;
|
||
$sub_q2 = null;
|
||
if ($spr1['tip'] == '6' || $spr1['tip'] == '7' || $spr1['tip'] == '16' || $spr1['tip'] == '17' || $spr1['tip'] == '18' || $spr1['tip'] == '19' || $spr1['tip'] == '20' || $spr1['tip'] == '21' ) {
|
||
foreach ($spr1['grids'] AS $grid) {
|
||
foreach ($grid['variables'] AS $variable) {
|
||
if ($variable['sequence'] == $v_first['seq']) {
|
||
$sub_q1 .= strip_tags($spr1['naslov']);
|
||
if ($show_variables_values == true ) {
|
||
$sub_q1 .= ' ('.strip_tags($spr1['variable']).')';
|
||
}
|
||
if ($spr1['tip'] == '16') {
|
||
$sub_q1 .= strip_tags($grid1['naslov']) . ($show_variables_values == true ? ' (' . strip_tags($grid1['variable']) . ')' : '');
|
||
} else {
|
||
$sub_q1 .= strip_tags($variable['naslov']) . ($show_variables_values == true ? ' (' . strip_tags($variable['variable']) . ')' : '');
|
||
}
|
||
}
|
||
}
|
||
}
|
||
}
|
||
if ($sub_q1 == null) {
|
||
$sub_q1 .= strip_tags($spr1['naslov']);
|
||
$sub_q1 .= ($show_variables_values == true ? ' ('.strip_tags($spr1['variable']).')' : '');
|
||
}
|
||
if ($spr2['tip'] == '6' || $spr2['tip'] == '7' || $spr2['tip'] == '16' || $spr2['tip'] == '17' || $spr2['tip'] == '18' || $spr2['tip'] == '19' || $spr2['tip'] == '20' || $spr2['tip'] == '21') {
|
||
foreach ($spr2['grids'] AS $grid) {
|
||
foreach ($grid['variables'] AS $variable) {
|
||
if ($variable['sequence'] == $v_second['seq']) {
|
||
$sub_q2 .= strip_tags($spr2['naslov']);
|
||
if ($show_variables_values == true) {
|
||
$sub_q2 .= ' ('.strip_tags($spr2['variable']).')';
|
||
}
|
||
if ($spr2['tip'] == '16') {
|
||
$sub_q2.= strip_tags($grid2['naslov']) . ($show_variables_values == true ? ' (' . strip_tags($grid2['variable']) . ')' : '');
|
||
} else {
|
||
$sub_q2.= strip_tags($variable['naslov']) . ($show_variables_values == true ? ' (' . strip_tags($variable['variable']) . ')' : '');
|
||
}
|
||
}
|
||
}
|
||
}
|
||
}
|
||
if ($sub_q2 == null) {
|
||
$sub_q2 .= strip_tags($spr2['naslov']);
|
||
$sub_q2 .= ($show_variables_values == true ? ' ('.strip_tags($spr2['variable']).')' : '');
|
||
}
|
||
|
||
$title = $sub_q1 . ' / ' . $sub_q2;
|
||
}
|
||
|
||
$subtitle = '('.$lang['srv_crosstabs']. ($element['sub_type'] == 1 ? ' - '.$lang['srv_chart'] : '') .')';
|
||
|
||
$title .= ' <span class="anl_ita">'.$subtitle.'</span>';
|
||
|
||
$this->crosstabVars = array($sub_q1, $sub_q2);
|
||
|
||
rtfIzvozAnalizaFunctions::init($this->ank_id, $this, $from='crosstab_chart', $crosstabClass);
|
||
rtfIzvozAnalizaFunctions::displayCrosstabChart();
|
||
}
|
||
|
||
// Izpisemo mean tabelo
|
||
function displayMean($element){
|
||
|
||
// ustvarimo means objekt
|
||
$meansClass = new SurveyMeans($this->ank_id);
|
||
|
||
// Napolnimo podatke crosstabu
|
||
$meanData1 = explode("-", $element['spr2']);
|
||
$meanData2 = explode("-", $element['spr1']);
|
||
|
||
$v_first = array('seq' => $meanData1[0], 'spr' => $meanData1[1], 'grd' => $meanData1[2]);
|
||
$v_second = array('seq' => $meanData2[0], 'spr' => $meanData2[1], 'grd' => $meanData2[2]);
|
||
|
||
$_means[0] = $meansClass->createMeans($v_first, $v_second);
|
||
|
||
rtfIzvozAnalizaFunctions::init($this->ank_id, $this, $from='mean', $meansClass);
|
||
rtfIzvozAnalizaFunctions::displayMeansTable($_means);
|
||
}
|
||
|
||
// Izpisemo mean graf
|
||
function displayMeanChart($element){
|
||
|
||
// ustvarimo means objekt
|
||
$meansClass = new SurveyMeans($this->ank_id);
|
||
|
||
// Napolnimo podatke crosstabu
|
||
$meanData1 = explode("-", $element['spr2']);
|
||
$meanData2 = explode("-", $element['spr1']);
|
||
|
||
$v_first = array('seq' => $meanData1[0], 'spr' => $meanData1[1], 'grd' => $meanData1[2]);
|
||
$v_second = array('seq' => $meanData2[0], 'spr' => $meanData2[1], 'grd' => $meanData2[2]);
|
||
|
||
$this->meanData2[0] = $v_first;
|
||
$this->meanData1[0] = $v_second;
|
||
|
||
$_means[0] = $meansClass->createMeans($v_first, $v_second);
|
||
|
||
rtfIzvozAnalizaFunctions::init($this->ank_id, $this, $from='mean_chart', $meansClass);
|
||
rtfIzvozAnalizaFunctions::displayMeanChart(0);
|
||
}
|
||
|
||
// Izpisemo ttest tabelo
|
||
function displayTTest($element){
|
||
|
||
// ustvarimo ttest objekt
|
||
$ttestClass = new SurveyTTest($this->ank_id);
|
||
|
||
// Nastavimo session da lahko pravilno izrisemo tabelo/graf
|
||
$ttestData1 = explode("-", $element['spr1']);
|
||
$ttestData2 = explode("-", $element['spr2']);
|
||
|
||
$dataArray = array();
|
||
|
||
$dataArray['spr2'] = $ttestData1[1];
|
||
$dataArray['grid2'] = $ttestData1[2];
|
||
$dataArray['seq2'] = $ttestData1[0];
|
||
$dataArray['label2'] = strip_tags($this->getTTestLabel($element['spr1'], $ttestClass));
|
||
|
||
$dataArray['sub_conditions'][0] = $ttestData1[3];
|
||
$dataArray['sub_conditions'][1] = $ttestData1[4];
|
||
|
||
$dataArray['variabla'][0]['seq'] = $ttestData2[0];
|
||
$dataArray['variabla'][0]['spr'] = $ttestData2[1];
|
||
$dataArray['variabla'][0]['grd'] = $ttestData2[2];
|
||
|
||
// Shranimo spremenjene nastavitve v bazo
|
||
SurveyUserSession::Init($this->ank_id);
|
||
$sessionData = SurveyUserSession::getData('ttest');
|
||
$sessionData = $dataArray;
|
||
SurveyUserSession::saveData($sessionData, 'ttest');
|
||
|
||
// ustvarimo ttest objekt
|
||
$ttestClass = new SurveyTTest($this->ank_id);
|
||
|
||
if (count($this->sessionData['ttest']['sub_conditions']) > 1 ) {
|
||
$variables1 = $ttestClass->getSelectedVariables();
|
||
if (count($variables1) > 0) {
|
||
foreach ($variables1 AS $v_first) {
|
||
$ttest = null;
|
||
$ttest = $ttestClass->createTTest($v_first, $this->sessionData['ttest']['sub_conditions']);
|
||
|
||
rtfIzvozAnalizaFunctions::init($this->ank_id, $this, $from='ttest', $ttestClass);
|
||
rtfIzvozAnalizaFunctions::displayTTestTable($ttest);
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
// Izpisemo ttest graf
|
||
function displayTTestChart($element){
|
||
|
||
// ustvarimo ttest objekt
|
||
$ttestClass = new SurveyTTest($this->ank_id);
|
||
|
||
// Nastavimo session da lahko pravilno izrisemo tabelo/graf
|
||
$ttestData1 = explode("-", $element['spr1']);
|
||
$ttestData2 = explode("-", $element['spr2']);
|
||
|
||
$dataArray = array();
|
||
|
||
$dataArray['spr2'] = $ttestData1[1];
|
||
$dataArray['grid2'] = $ttestData1[2];
|
||
$dataArray['seq2'] = $ttestData1[0];
|
||
$dataArray['label2'] = strip_tags($this->getTTestLabel($element['spr1'], $ttestClass));
|
||
|
||
$dataArray['sub_conditions'][0] = $ttestData1[3];
|
||
$dataArray['sub_conditions'][1] = $ttestData1[4];
|
||
|
||
$dataArray['variabla'][0]['seq'] = $ttestData2[0];
|
||
$dataArray['variabla'][0]['spr'] = $ttestData2[1];
|
||
$dataArray['variabla'][0]['grd'] = $ttestData2[2];
|
||
|
||
// Shranimo spremenjene nastavitve v bazo
|
||
SurveyUserSession::Init($this->ank_id);
|
||
$sessionData = SurveyUserSession::getData('ttest');
|
||
$sessionData = $dataArray;
|
||
SurveyUserSession::saveData($sessionData, 'ttest');
|
||
|
||
// ustvarimo ttest objekt
|
||
$ttestClass = new SurveyTTest($this->ank_id);
|
||
|
||
if (count($this->sessionData['ttest']['sub_conditions']) > 1 ) {
|
||
$variables1 = $ttestClass->getSelectedVariables();
|
||
if (count($variables1) > 0) {
|
||
foreach ($variables1 AS $v_first) {
|
||
|
||
rtfIzvozAnalizaFunctions::init($this->ank_id, $this, $from='ttest_chart', $ttestClass);
|
||
rtfIzvozAnalizaFunctions::displayTTestChart();
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
// Izpisemo crosstab tabelo
|
||
function displayBreak($element){
|
||
global $lang;
|
||
|
||
// Napolnimo podatke breaku
|
||
$breakData1 = explode("-", $element['spr1']);
|
||
$breakData2 = explode("-", $element['spr2']);
|
||
|
||
$breakClass = new SurveyBreak($this->ank_id);
|
||
|
||
$forSpr = $breakData1[1];
|
||
$_spr_data = $breakClass->_HEADERS[$forSpr];
|
||
|
||
# poiščemo sekvenco
|
||
$sekvenca = $breakData1[0];
|
||
|
||
# poiščemo opcije
|
||
$opcije = $_spr_data['options'];
|
||
|
||
if ((int)$_spr_data['tip'] != 2) {
|
||
$seqences[] = $sekvenca;
|
||
$options = $opcije;
|
||
} else {
|
||
# za checkboxe imamo več sekvenc
|
||
$seqences = explode('_',$_spr_data['sequences']);
|
||
$options[1] = $opcije[1];
|
||
}
|
||
|
||
# za vsako opcijo posebej izračunamo povprečja za vse spremenljivke
|
||
/*$frequencys = array();
|
||
if (count($seqences) > 0) {
|
||
foreach ($seqences as $seq) {
|
||
|
||
if (count($options) > 0) {
|
||
foreach ($options as $oKey => $option) {
|
||
# zloopamo skozi variable
|
||
$oKeyfrequencys = $breakClass->getAllFrequencys($oKey, $seq, $forSpr);
|
||
if ($oKeyfrequencys != null) {
|
||
$frequencys[$seq][$oKey] = $oKeyfrequencys;
|
||
}
|
||
}
|
||
}
|
||
}
|
||
}*/
|
||
$frequencys = null;
|
||
if (count($options) > 0) {
|
||
foreach ($options as $okey => $option) {
|
||
|
||
# zloopamo skozi variable
|
||
$okeyfrequencys = $breakClass->getAllFrequencys($okey, $sekvenca, $forSpr);
|
||
if ($okeyfrequencys != null) {
|
||
if ($frequencys == null) {
|
||
$frequencys = array();
|
||
}
|
||
$frequencys[$okey] = $okeyfrequencys;
|
||
}
|
||
}
|
||
}
|
||
|
||
$spremenljivka = $breakClass->_HEADERS[$breakData2[1]];
|
||
$spremenljivka['id'] = $breakData2[1];
|
||
|
||
$tip = $spremenljivka['tip'];
|
||
$skala = $spremenljivka['skala'];
|
||
|
||
|
||
// Izrisujemo tabelo ki ni crosstab
|
||
if( ($tip == 6 && $skala == 0) || in_array($tip, array(4,7,17,18,19,20,21)) ){
|
||
|
||
rtfIzvozAnalizaFunctions::init($this->ank_id, $this, $from='break', $breakClass);
|
||
|
||
if($tip == 6 && $skala == 0)
|
||
rtfIzvozAnalizaFunctions::displayBreakTableMgrid($forSpr,$frequencys,$spremenljivka);
|
||
|
||
elseif($tip == 4 || $tip == 19 || $tip == 21){
|
||
// Nastavimo se katero podtabelo izrisemo (sekvenca odvisne spr)
|
||
$spremenljivka['break_sub_table']['sequence'] = $breakData2[0];
|
||
foreach ($spremenljivka['grids'] AS $gkey => $grid) {
|
||
if($spremenljivka['break_sub_table']['sequence'] == $grid['variables'][0]['sequence']){
|
||
$spremenljivka['break_sub_table']['key'] = $gkey;
|
||
break;
|
||
}
|
||
}
|
||
|
||
rtfIzvozAnalizaFunctions::displayBreakTableText($forSpr,$frequencys,$spremenljivka);
|
||
}
|
||
|
||
else{
|
||
// Nastavimo se katero podtabelo izrisemo (sekvenca odvisne spr)
|
||
$spremenljivka['break_sub_table']['sequence'] = $breakData2[0];
|
||
foreach ($spremenljivka['grids'] AS $gkey => $grid) {
|
||
if($spremenljivka['break_sub_table']['sequence'] == $grid['variables'][0]['sequence']){
|
||
$spremenljivka['break_sub_table']['key'] = $gkey;
|
||
break;
|
||
}
|
||
}
|
||
|
||
rtfIzvozAnalizaFunctions::displayBreakTableNumber($forSpr,$frequencys,$spremenljivka);
|
||
}
|
||
}
|
||
|
||
// Izrisujemo crosstab
|
||
else{
|
||
$this->displayCrosstab($element);
|
||
}
|
||
}
|
||
|
||
// Izpisemo crosstab graf
|
||
function displayBreakChart($element){
|
||
// Napolnimo podatke breaku
|
||
$breakData1 = explode("-", $element['spr1']);
|
||
$breakData2 = explode("-", $element['spr2']);
|
||
|
||
$breakClass = new SurveyBreak($this->ank_id);
|
||
|
||
$forSpr = $breakData1[1];
|
||
$_spr_data = $breakClass->_HEADERS[$forSpr];
|
||
|
||
# poiščemo sekvenco
|
||
$sekvenca = $breakData1[0];
|
||
|
||
# poiščemo opcije
|
||
$opcije = $_spr_data['options'];
|
||
|
||
if ((int)$_spr_data['tip'] != 2) {
|
||
$seqences[] = $sekvenca;
|
||
$options = $opcije;
|
||
} else {
|
||
# za checkboxe imamo več sekvenc
|
||
$seqences = explode('_',$_spr_data['sequences']);
|
||
$options[1] = $opcije[1];
|
||
}
|
||
|
||
$frequencys = null;
|
||
if (count($options) > 0) {
|
||
foreach ($options as $okey => $option) {
|
||
|
||
# zloopamo skozi variable
|
||
$okeyfrequencys = $breakClass->getAllFrequencys($okey, $sekvenca, $forSpr);
|
||
if ($okeyfrequencys != null) {
|
||
if ($frequencys == null) {
|
||
$frequencys = array();
|
||
}
|
||
$frequencys[$okey] = $okeyfrequencys;
|
||
}
|
||
}
|
||
}
|
||
|
||
$spremenljivka = $breakClass->_HEADERS[$breakData2[1]];
|
||
$spremenljivka['id'] = $breakData2[1];
|
||
|
||
$tip = $spremenljivka['tip'];
|
||
$skala = $spremenljivka['skala'];
|
||
|
||
|
||
// Pri textovnih tipih vedno izrisemo tabelo
|
||
if($tip == 4 || $tip == 21 || $tip == 19){
|
||
// Nastavimo se katero podtabelo izrisemo (sekvenca odvisne spr)
|
||
$spremenljivka['break_sub_table']['sequence'] = $breakData2[0];
|
||
foreach ($spremenljivka['grids'] AS $gkey => $grid) {
|
||
if($spremenljivka['break_sub_table']['sequence'] == $grid['variables'][0]['sequence']){
|
||
$spremenljivka['break_sub_table']['key'] = $gkey;
|
||
break;
|
||
}
|
||
}
|
||
|
||
rtfIzvozAnalizaFunctions::init($this->ank_id, $this, $from='break', $breakClass);
|
||
rtfIzvozAnalizaFunctions::displayBreakTableText($forSpr,$frequencys,$spremenljivka);
|
||
}
|
||
|
||
// Izrisujemo graf ki ni crosstab
|
||
elseif( ($tip == 6 && $skala == 0) || in_array($tip, array(7,17,18,20)) ){
|
||
|
||
rtfIzvozAnalizaFunctions::init($this->ank_id, $this, $from='break', $breakClass);
|
||
|
||
if($tip == 6 && $skala == 0)
|
||
rtfIzvozAnalizaFunctions::displayBreakChart($forSpr,$frequencys,$spremenljivka);
|
||
|
||
else{
|
||
// Nastavimo se katero podtabelo izrisemo (sekvenca odvisne spr)
|
||
$spremenljivka['break_sub_table']['sequence'] = $breakData2[0];
|
||
foreach ($spremenljivka['grids'] AS $gkey => $grid) {
|
||
if($spremenljivka['break_sub_table']['sequence'] == $grid['variables'][0]['sequence']){
|
||
$spremenljivka['break_sub_table']['key'] = $gkey;
|
||
break;
|
||
}
|
||
}
|
||
|
||
rtfIzvozAnalizaFunctions::displayBreakChart($forSpr,$frequencys,$spremenljivka);
|
||
}
|
||
}
|
||
|
||
// Izrisujemo crosstab
|
||
else{
|
||
$this->displayCrosstabChart($element);
|
||
}
|
||
}
|
||
|
||
// Izpisemo element z besedilom elementa
|
||
function displayText($text){
|
||
global $lang;
|
||
|
||
// pretvorimo html text v rtf
|
||
$text = $this->rtf->HTMLtoRTF($text);
|
||
|
||
$this->rtf->TextCell($this->enkaEncode($text), array('width' => 10000, 'height' => 1,
|
||
'align' => 'justify', 'valign' => 'bottom' , 'border' => '','colorF' => "0" ) );
|
||
|
||
$this->rtf->new_line(1);
|
||
}
|
||
|
||
|
||
// Izpisemo naslov elementa
|
||
function displayTitle($element){
|
||
global $lang;
|
||
|
||
// sumarnik
|
||
if($element['type'] == '1'){
|
||
$spr = SurveyAnalysis::$_HEADERS[$element['spr1']];
|
||
|
||
if($element['spr1'] == '')
|
||
$title = $lang['srv_select_spr'];
|
||
else
|
||
$title = $spr['variable'].' - '.$spr['naslov'];
|
||
|
||
$subtitle = ' ('.$lang['srv_sumarnik'].')';
|
||
}
|
||
|
||
// freq
|
||
elseif($element['type'] == '2'){
|
||
$spr = SurveyAnalysis::$_HEADERS[$element['spr1']];
|
||
|
||
if($element['spr1'] == '')
|
||
$title = $lang['srv_select_spr'];
|
||
else
|
||
$title = $spr['variable'].' - '.$spr['naslov'];
|
||
|
||
$subtitle = ' ('.$lang['srv_frequency'].')';
|
||
}
|
||
|
||
// desc
|
||
elseif($element['type'] == '3'){
|
||
$spr = SurveyAnalysis::$_HEADERS[$element['spr1']];
|
||
|
||
if($element['spr1'] == '')
|
||
$title = $lang['srv_select_spr'];
|
||
else
|
||
$title = $spr['variable'].' - '.$spr['naslov'];
|
||
|
||
$subtitle = ' ('.$lang['srv_descriptor'].')';
|
||
}
|
||
|
||
// chart
|
||
elseif($element['type'] == '4'){
|
||
$spr = SurveyAnalysis::$_HEADERS[$element['spr1']];
|
||
|
||
if($element['spr1'] == '')
|
||
$title = $lang['srv_select_spr'];
|
||
else
|
||
$title = $spr['variable'].' - '.$spr['naslov'];
|
||
|
||
$subtitle = ' ('.$lang['srv_chart'].')';
|
||
}
|
||
|
||
// crosstab
|
||
elseif($element['type'] == '5'){
|
||
|
||
// Napolnimo podatke crosstabu
|
||
$crossData1 = explode("-", $element['spr1']);
|
||
$crossData2 = explode("-", $element['spr2']);
|
||
|
||
$crosstabClass = new SurveyCrosstabs();
|
||
$crosstabClass->Init($this->ank_id);
|
||
|
||
$crosstabClass->setVariables($crossData1[0],$crossData1[1],$crossData1[2],$crossData2[0],$crossData2[1],$crossData2[2]);
|
||
|
||
// Naslov
|
||
if($element['spr1'] == '' || $element['spr2'] == '')
|
||
$title = $lang['srv_select_spr'];
|
||
else{
|
||
$show_variables_values = true;
|
||
|
||
$spr1 = $crosstabClass->_HEADERS[$crossData1[1]];
|
||
$spr2 = $crosstabClass->_HEADERS[$crossData2[1]];
|
||
|
||
# za multicheckboxe popravimo naslov, na podtip
|
||
$sub_q1 = null;
|
||
$sub_q2 = null;
|
||
if ($spr1['tip'] == '6' || $spr1['tip'] == '7' || $spr1['tip'] == '16' || $spr1['tip'] == '17' || $spr1['tip'] == '18' || $spr1['tip'] == '19' || $spr1['tip'] == '20' || $spr1['tip'] == '21' ) {
|
||
foreach ($spr1['grids'] AS $grid) {
|
||
foreach ($grid['variables'] AS $variable) {
|
||
if ($variable['sequence'] == $v_first['seq']) {
|
||
$sub_q1 .= strip_tags($spr1['naslov']);
|
||
if ($show_variables_values == true ) {
|
||
$sub_q1 .= ' ('.strip_tags($spr1['variable']).')';
|
||
}
|
||
if ($spr1['tip'] == '16') {
|
||
$sub_q1 .= '<br />'. strip_tags($grid1['naslov']) . ($show_variables_values == true ? ' (' . strip_tags($grid1['variable']) . ')' : '');
|
||
} else {
|
||
$sub_q1 .= '<br />' . strip_tags($variable['naslov']) . ($show_variables_values == true ? ' (' . strip_tags($variable['variable']) . ')' : '');
|
||
}
|
||
}
|
||
}
|
||
}
|
||
}
|
||
if ($sub_q1 == null) {
|
||
$sub_q1 .= strip_tags($spr1['naslov']);
|
||
$sub_q1 .= ($show_variables_values == true ? ' ('.strip_tags($spr1['variable']).')' : '');
|
||
}
|
||
if ($spr2['tip'] == '6' || $spr2['tip'] == '7' || $spr2['tip'] == '16' || $spr2['tip'] == '17' || $spr2['tip'] == '18' || $spr2['tip'] == '19' || $spr2['tip'] == '20' || $spr2['tip'] == '21') {
|
||
foreach ($spr2['grids'] AS $grid) {
|
||
foreach ($grid['variables'] AS $variable) {
|
||
if ($variable['sequence'] == $v_second['seq']) {
|
||
$sub_q2 .= strip_tags($spr2['naslov']);
|
||
if ($show_variables_values == true) {
|
||
$sub_q2 .= ' ('.strip_tags($spr2['variable']).')';
|
||
}
|
||
if ($spr2['tip'] == '16') {
|
||
$sub_q2.= '<br />' . strip_tags($grid2['naslov']) . ($show_variables_values == true ? ' (' . strip_tags($grid2['variable']) . ')' : '');
|
||
} else {
|
||
$sub_q2.= '<br />' . strip_tags($variable['naslov']) . ($show_variables_values == true ? ' (' . strip_tags($variable['variable']) . ')' : '');
|
||
}
|
||
}
|
||
}
|
||
}
|
||
}
|
||
if ($sub_q2 == null) {
|
||
$sub_q2 .= strip_tags($spr2['naslov']);
|
||
$sub_q2 .= ($show_variables_values == true ? ' ('.strip_tags($spr2['variable']).')' : '');
|
||
}
|
||
|
||
$title = $sub_q1 . ' / ' . $sub_q2;
|
||
}
|
||
|
||
$subtitle = ' ('.$lang['srv_crosstabs']. ($element['sub_type'] == 1 ? ' - '.$lang['srv_chart'] : '') .')';
|
||
}
|
||
|
||
// mean
|
||
elseif($element['type'] == '6'){
|
||
|
||
// ustvarimo means objekt
|
||
$meansClass = new SurveyMeans($this->ank_id);
|
||
|
||
// Napolnimo podatke crosstabu
|
||
$meanData1 = explode("-", $element['spr2']);
|
||
$meanData2 = explode("-", $element['spr1']);
|
||
|
||
$v_first = array('seq' => $meanData1[0], 'spr' => $meanData1[1], 'grd' => $meanData1[2]);
|
||
$v_second = array('seq' => $meanData2[0], 'spr' => $meanData2[1], 'grd' => $meanData2[2]);
|
||
|
||
$means[0] = $meansClass->createMeans($v_first, $v_second);
|
||
|
||
// Nastavimo variable (potrebno za grafe
|
||
$meansClass->variabla1[0] = $v_second;
|
||
$meansClass->variabla2[0] = $v_first;
|
||
|
||
// Naslov
|
||
if($element['spr1'] == '' || $element['spr2'] == ''){
|
||
$title = $lang['srv_select_spr'];
|
||
}
|
||
else{
|
||
$label2 = strip_tags($meansClass->getSpremenljivkaTitle($means[0]['v1']));
|
||
$label1 = strip_tags($meansClass->getSpremenljivkaTitle($means[0]['v2']));
|
||
|
||
$title = $label1 . ' / ' . $label2;
|
||
}
|
||
|
||
$subtitle = ' ('.$lang['srv_means']. ($element['sub_type'] == 1 ? ' - '.$lang['srv_chart'] : '') .')';
|
||
}
|
||
|
||
// ttest
|
||
elseif($element['type'] == '7'){
|
||
|
||
// ustvarimo ttest objekt
|
||
$ttestClass = new SurveyTTest($this->ank_id);
|
||
|
||
// Naslov
|
||
if($element['spr1'] == '' || $element['spr2'] == ''){
|
||
$title = $lang['srv_select_spr'];
|
||
}
|
||
else{
|
||
$label2 = strip_tags($this->getTTestLabel($element['spr2'], $ttestClass));
|
||
$label1 = strip_tags($this->getTTestLabel($element['spr1'], $ttestClass));
|
||
|
||
$title = $label1 . ' / ' . $label2;
|
||
}
|
||
|
||
$subtitle = ' ('.$lang['srv_ttest']. ($element['sub_type'] == 1 ? ' - '.$lang['srv_chart'] : '') .')';
|
||
}
|
||
|
||
// break
|
||
elseif($element['type'] == '9'){
|
||
|
||
// ustvarimo ttest objekt
|
||
$breakClass = new SurveyBreak($this->ank_id);
|
||
|
||
$breakData1 = explode("-", $element['spr1']);
|
||
$breakData2 = explode("-", $element['spr2']);
|
||
|
||
|
||
$label1 = '';
|
||
$variables = $breakClass->getVariableList(2);
|
||
foreach ($variables as $variable) {
|
||
|
||
if($breakData1[0] == $variable['sequence']){
|
||
$label1 = ( (int)$variable['sub'] == 0 ? '' : ( (int)$variable['sub'] == 1 ? ' ' : ' ' )) . $variable['variableNaslov'];
|
||
$label1 = (strlen($label1) > 60) ? substr($label1, 0, 57).'...' : $label1;
|
||
|
||
break;
|
||
}
|
||
}
|
||
|
||
$label2 = '';
|
||
$variables = $this->getBreakDependentVariableList($breakClass);
|
||
foreach ($variables as $variable) {
|
||
|
||
if($breakData2[0] == $variable['sequence']){
|
||
//$label2 = $variable['variableNaslov'];
|
||
$label2 = (strlen($variable['variableNaslov']) > 60) ? substr($variable['variableNaslov'], 0, 57).'...' : $variable['variableNaslov'];
|
||
|
||
break;
|
||
}
|
||
}
|
||
|
||
$title = $label1 . ' / ' . $label2;
|
||
$subtitle = '('.$lang['srv_break']. ($element['sub_type'] == 1 ? ' - '.$lang['srv_chart'] : '') .')';
|
||
}
|
||
|
||
|
||
$this->rtf->new_line(3);
|
||
|
||
$this->rtf->set_font("Arial Black", 9);
|
||
|
||
$this->rtf->add_text($this->encodeText($title), 'center');
|
||
$this->rtf->set_font("Arial", 9);
|
||
$this->rtf->add_text($this->encodeText($subtitle), 'center');
|
||
$this->rtf->new_line();
|
||
}
|
||
|
||
function getTTestLabel($spr, $ttestClass){
|
||
|
||
$data = explode("-", $spr);
|
||
|
||
$spid = $data[1];
|
||
$seq = $data[0];
|
||
$grid = $data[2];
|
||
|
||
$spr_data = $ttestClass->_HEADERS[$spid];
|
||
if ($grid == 'undefined') {
|
||
|
||
# imamp lahko več variabel
|
||
foreach ($spr_data['grids'] as $gkey => $grid ) {
|
||
|
||
foreach ($grid['variables'] as $vkey => $variable) {
|
||
$sequence = $variable['sequence'];
|
||
if ($sequence == $seq) {
|
||
$sprLabel = '('.$variable['variable'].') '. $variable['naslov'];
|
||
}
|
||
}
|
||
}
|
||
} else {
|
||
# imamo subgrid
|
||
$sprLabel = '('.$spr_data['grids'][$grid]['variable'].') '. $spr_data['grids'][$grid]['naslov'];
|
||
}
|
||
|
||
return $sprLabel;
|
||
}
|
||
|
||
/** funkcija vrne seznam primern variabel za break
|
||
*
|
||
*/
|
||
function getBreakDependentVariableList($breakClass) {
|
||
|
||
$variablesList = array();
|
||
|
||
# zloopamo skozi header in dodamo variable (potrebujemo posamezne sekvence)
|
||
foreach ($breakClass->_HEADERS AS $skey => $spremenljivka) {
|
||
|
||
$tip = $spremenljivka['tip'];
|
||
|
||
$_dropdown_condition = (is_numeric($tip) && $tip != 5 && $tip != 8 && $tip != 9) ? true : false;
|
||
if ($_dropdown_condition) {
|
||
|
||
$cnt_all = (int)$spremenljivka['cnt_all'];
|
||
if ( $cnt_all == '1' || in_array($tip, array(1,2,3,4,7,17,18,21,22)) || ($tip == 6 && $spremenljivka['enota'] == 2) ) {
|
||
|
||
# pri tipu radio ali select dodamo tisto variablo ki ni polje "drugo"
|
||
if ($tip == 1 || $tip == 3 ) {
|
||
if (count($spremenljivka['grids']) == 1 ) {
|
||
# če imamo samo en grid ( lahko je več variabel zaradi polja drugo.
|
||
$grid = $spremenljivka['grids'][0];
|
||
if (count ($grid['variables']) > 0) {
|
||
foreach ($grid['variables'] AS $vid => $variable ){
|
||
if ($variable['other'] != 1) {
|
||
# imampo samo eno sekvenco grids[0]variables[0]
|
||
$variablesList[] = array(
|
||
'tip'=>$tip,
|
||
'spr_id'=>$skey,
|
||
'sequence'=>$spremenljivka['grids'][0]['variables'][$vid]['sequence'],
|
||
'variableNaslov'=>'('.$spremenljivka['variable'].') '.strip_tags($spremenljivka['naslov']),
|
||
'canChoose'=>true,
|
||
'sub'=>0);
|
||
|
||
}
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
else {
|
||
# imampo samo eno sekvenco grids[0]variables[0]
|
||
$variablesList[] = array(
|
||
'tip'=>$tip,
|
||
'spr_id'=>$skey,
|
||
'sequence'=>$spremenljivka['grids'][0]['variables'][0]['sequence'],
|
||
'variableNaslov'=>'('.$spremenljivka['variable'].') '.strip_tags($spremenljivka['naslov']),
|
||
'canChoose'=>true,
|
||
'sub'=>0);
|
||
}
|
||
}
|
||
else if ($cnt_all > 1){
|
||
# imamo več skupin ali podskupin, zato zlopamo skozi gride in variable
|
||
if (count($spremenljivka['grids']) > 0 ) {
|
||
$variablesList[] = array(
|
||
'tip'=>$tip,
|
||
|
||
'variableNaslov'=>'('.$spremenljivka['variable'].') '.strip_tags($spremenljivka['naslov']),
|
||
'canChoose'=>false,
|
||
'sub'=>0);
|
||
# ali imamo en grid, ali več (tabele
|
||
if (count($spremenljivka['grids']) == 1 ) {
|
||
# če imamo samo en grid ( lahko je več variabel zaradi polja drugo.
|
||
$grid = $spremenljivka['grids'][0];
|
||
if (count ($grid['variables']) > 0) {
|
||
foreach ($grid['variables'] AS $vid => $variable ){
|
||
if ($variable['other'] != 1) {
|
||
$variablesList[] = array(
|
||
'tip'=>$tip,
|
||
'spr_id'=>$skey,
|
||
'sequence'=>$variable['sequence'],
|
||
'variableNaslov'=>'('.$variable['variable'].') '.strip_tags($variable['naslov']),
|
||
'canChoose'=>true,
|
||
'sub'=>1);
|
||
}
|
||
}
|
||
}
|
||
|
||
} elseif($tip == 6) {
|
||
# imamo več gridov - tabele
|
||
foreach($spremenljivka['grids'] AS $gid => $grid) {
|
||
$sub = 0;
|
||
if ($grid['variable'] != '') {
|
||
$sub++;
|
||
$variablesList[] = array(
|
||
'tip'=>$tip,
|
||
'variableNaslov'=>'('.$grid['variable'].') '.strip_tags($grid['naslov']),
|
||
'canChoose'=>false,
|
||
'sub'=>$sub);
|
||
}
|
||
if (count ($grid['variables']) > 0) {
|
||
$sub++;
|
||
foreach ($grid['variables'] AS $vid => $variable ){
|
||
if ($variable['other'] != 1) {
|
||
$variablesList[] = array(
|
||
'tip'=>$tip,
|
||
'spr_id'=>$skey,
|
||
'sequence'=>$variable['sequence'],
|
||
'variableNaslov'=>'('.$variable['variable'].') '.strip_tags($variable['naslov']),
|
||
'canChoose'=>true,
|
||
'sub'=>$sub);
|
||
}
|
||
}
|
||
}
|
||
}
|
||
} else {
|
||
foreach($spremenljivka['grids'] AS $gid => $grid) {
|
||
$sub = 0;
|
||
if ($grid['variable'] != '') {
|
||
$sub++;
|
||
$variablesList[] = array(
|
||
'tip'=>$tip,
|
||
'spr_id'=>$skey,
|
||
'grd_id'=>$gid,
|
||
'sequence'=>$grid['variables'][0]['sequence'],
|
||
'variableNaslov'=>'('.$grid['variable'].') '.strip_tags($grid['naslov']),
|
||
'canChoose'=>true,
|
||
'sub'=>1);
|
||
}
|
||
}
|
||
}
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
return $variablesList;
|
||
}
|
||
|
||
|
||
// Izpisemo komentar elementa
|
||
function displayComment($text){
|
||
global $lang;
|
||
|
||
if($text != ''){
|
||
|
||
// pretvorimo html text v rtf
|
||
$text = $this->rtf->HTMLtoRTF($text);
|
||
|
||
$this->rtf->TextCell($this->enkaEncode($text), array('width' => 10000, 'height' => 1,
|
||
'align' => 'left', 'valign' => 'bottom' , 'border' => '','colorF' => "0" ) );
|
||
|
||
$this->rtf->new_line(1);
|
||
}
|
||
}
|
||
|
||
|
||
function createFrontPage()
|
||
{
|
||
global $lang;
|
||
|
||
$this->rtf->new_line(10);
|
||
$this->rtf->TextCell($this->encodeText( SurveyInfo::getInstance()->getSurveyTitle()), array('width' => 9500, 'height' => 3,
|
||
'align' => 'center', 'valign' => 'middle' , 'border' => array('top','bottom', 'left','right'),
|
||
'colorF' => "0", 'colorB' => "0" ) );
|
||
$this->rtf->new_line(3);
|
||
// dodamo info:
|
||
$this->rtf->TextCell("", array('width' => 9500, 'height' => 1,
|
||
'align' => 'left', 'valign' => 'bottom' , 'border' => array('bottom'),'colorF' => "0" ) );
|
||
|
||
$infoTable = array();
|
||
|
||
$imenaTable = array();
|
||
if ( SurveyInfo::getInstance()->getSurveyTitle() != SurveyInfo::getInstance()->getSurveyAkronim() )
|
||
$imenaTable[] = array($lang['export_firstpage_shortname'].': '.$this->encodeText(SurveyInfo::getInstance()->getSurveyAkronim()), "");
|
||
if ( SurveyInfo::getInstance()->getSurveyTitle() != SurveyInfo::getInstance()->getSurveyAkronim() )
|
||
$imenaTable[] = array($lang['export_firstpage_longname'].': '.$this->encodeText(SurveyInfo::getInstance()->getSurveyTitle()), "");
|
||
|
||
$imenaTable[] = array($lang['export_firstpage_qcount'].': '.$this->encodeText(SurveyInfo::getInstance()->getSurveyQuestionCount()), "" );
|
||
$imenaTable[] = array($lang['export_firstpage_active_from'].': '.$this->encodeText(SurveyInfo::getInstance()->getSurveyStartsDate()),"" );
|
||
$imenaTable[] = array($lang['export_firstpage_active_until'].': '.$this->encodeText(SurveyInfo::getInstance()->getSurveyExpireDate()),"" );
|
||
$imenaTable[] = array($lang['export_firstpage_author'].': '.$this->encodeText(SurveyInfo::getInstance()->getSurveyInsertName()),"" );
|
||
$imenaTable[] = array($lang['export_firstpage_edit'].': '.$this->encodeText(SurveyInfo::getInstance()->getSurveyEditName()),"" );
|
||
$imenaTable[] = array($lang['export_firstpage_date'].': '.$this->encodeText(SurveyInfo::getInstance()->getSurveyInsertDate()),"" );
|
||
$imenaTable[] = array($lang['export_firstpage_date'].': '.$this->encodeText(SurveyInfo::getInstance()->getSurveyEditDate()),"" );
|
||
$imenaTable[] = array($lang['export_firstpage_desc'].': '.$this->encodeText(SurveyInfo::getInstance()->getSurveyInfo()),"" );
|
||
$this->rtf->TableFromArray( array( 4600, 4600 ), $imenaTable);
|
||
|
||
$this->rtf->new_page();
|
||
}
|
||
|
||
function enkaEncode($text){ // popravimo sumnike ce je potrebno
|
||
|
||
// preverimo text za img tage in jih zamenjamo z ustrezno sliko
|
||
$pattern = '/<img[^>]+src[\\s=\'"]';
|
||
$pattern .= '+([^"\'>\\s]+)/is';
|
||
if(preg_match($pattern, $text, $match, PREG_OFFSET_CAPTURE)){
|
||
|
||
// relativna pot
|
||
if(substr($match[1][0], 0, 1) == '/')
|
||
$image = $site_url.$match[1][0];
|
||
else
|
||
$image = $match[1][0];
|
||
|
||
$file = @file_get_contents($image);
|
||
|
||
|
||
// Resizamo sliko na pravo velikost
|
||
$imgSize = getimagesize($image);
|
||
$origHeight = $imgSize[1];
|
||
$origWidth = $imgSize[0];
|
||
|
||
// Dobimo nastavljeno visino slike
|
||
$pattern = '/<img[^>]+height[\\s=\'"]';
|
||
$pattern .= '+([^"\'>\\s]+)/is';
|
||
preg_match($pattern, $text, $match, PREG_OFFSET_CAPTURE);
|
||
$height = round($match[1][0] / $origHeight) * 100;
|
||
|
||
// Dobimo nastavljeno sirino slike
|
||
$pattern = '/<img[^>]+width[\\s=\'"]';
|
||
$pattern .= '+([^"\'>\\s]+)/is';
|
||
preg_match($pattern, $text, $match, PREG_OFFSET_CAPTURE);
|
||
$width = round($match[1][0] / $origWidth) * 100;
|
||
|
||
|
||
$result .= "{";
|
||
$result .= "\\pict\\jpegblip\\picscalex".$width."\\picscaley".$height."\\bliptag132000428 ";
|
||
$result .= trim(bin2hex($file));
|
||
$result .= "\n}\n";
|
||
|
||
$text = preg_replace("/<img[^>]+\>/i", $result, $text);
|
||
}
|
||
|
||
$text = html_entity_decode($text, ENT_NOQUOTES, 'UTF-8');
|
||
return strip_tags($text);
|
||
}
|
||
|
||
function encodeText($text){ // popravimo sumnike ce je potrebno
|
||
$text = html_entity_decode($text, ENT_NOQUOTES, 'UTF-8');
|
||
$text = str_replace(array("š","š","č"),array("<EFBFBD>","<EFBFBD>","<EFBFBD>"),$text);
|
||
return strip_tags($text);
|
||
}
|
||
|
||
function formatNumber($value,$digit=0,$sufix="")
|
||
{
|
||
if ( $value <> 0 && $value != null )
|
||
$result = round($value,$digit);
|
||
else
|
||
$result = "0";
|
||
$result = number_format($result, $digit, ',', '.').$sufix;
|
||
|
||
return $result;
|
||
}
|
||
|
||
/* Skrajsa niz in doda ... nakoncu
|
||
* snippet(phrase,[max length],[phrase tail])
|
||
* snippetgreedy(phrase,[max length before next space],[phrase tail])
|
||
*
|
||
* iz: http://snipplr.com/view/9520/php-substring-without-breaking-words/
|
||
*/
|
||
function snippet($text,$length=64,$tail="...")
|
||
{
|
||
$text = trim($text);
|
||
$txtl = strlen($text);
|
||
if($txtl > $length)
|
||
{
|
||
for($i=1;$text[$length-$i]!=" ";$i++)
|
||
{
|
||
if($i == $length)
|
||
{
|
||
return substr($text,0,$length) . $tail;
|
||
}
|
||
}
|
||
$text = substr($text,0,$length-$i+1) . $tail;
|
||
}
|
||
return $text;
|
||
}
|
||
|
||
function setDisplayFrontPage($display) {$this->pi['displayFrontPage'] = $display;}
|
||
function getDisplayFrontPage() {return ($this->pi['displayFrontPage'] == true || $this->pi['displayFrontPage'] == 1);}
|
||
|
||
// Ce imamo v porocilu tabelo crosstab ali ttest ali means imamo landscape orientacijo
|
||
function landscapeTest(){
|
||
global $global_user_id;
|
||
|
||
$sql = sisplet_query("SELECT * FROM srv_custom_report WHERE ank_id='$this->ank_id' AND usr_id='$global_user_id' AND profile='$this->creportProfile' AND sub_type='0' AND (type='5' OR type='6' OR type='7' OR type='9')");
|
||
|
||
if(mysqli_num_rows($sql) > 0)
|
||
return true;
|
||
else
|
||
return false;
|
||
}
|
||
|
||
|
||
}
|
||
|
||
|
||
?>
|