* @copyright 2007-2011 PrestaShop SA * @version Release: $Revision: 8783 $ * @license http://opensource.org/licenses/osl-3.0.php Open Software License (OSL 3.0) * International Registered Trademark & Property of PrestaShop SA */ abstract class ModuleGraphCore extends Module { protected $_employee; /** @var integer array graph data */ protected $_values = array(); /** @var string array graph legends (X axis) */ protected $_legend = array(); /**@var string graph titles */ protected $_titles = array('main' => NULL, 'x' => NULL, 'y' => NULL); /** @var ModuleGraphEngine graph engine */ protected $_render; abstract protected function getData($layers); public function setEmployee($id_employee) { $this->_employee = new Employee((int)($id_employee)); } public function setLang($id_lang) { $this->_id_lang = $id_lang; } protected function setDateGraph($layers, $legend = false) { // Get dates in a manageable format $fromArray = getdate(strtotime($this->_employee->stats_date_from)); $toArray = getdate(strtotime($this->_employee->stats_date_to)); // If the granularity is inferior to 1 day if ($this->_employee->stats_date_from == $this->_employee->stats_date_to) { if ($legend) for ($i = 0; $i < 24; $i++) { if ($layers == 1) $this->_values[$i] = 0; else for ($j = 0; $j < $layers; $j++) $this->_values[$j][$i] = 0; $this->_legend[$i] = ($i % 2) ? '' : sprintf('%02dh', $i); } if (is_callable(array($this, 'setDayValues'))) $this->setDayValues($layers); } // If the granularity is inferior to 1 month TODO : change to manage 28 to 31 days elseif (strtotime($this->_employee->stats_date_to) - strtotime($this->_employee->stats_date_from) <= 2678400) { if ($legend) { $days = array(); if ($fromArray['mon'] == $toArray['mon']) for ($i = $fromArray['mday']; $i <= $toArray['mday']; ++$i) $days[] = $i; else { $imax = date('t', mktime(0, 0, 0, $fromArray['mon'], 1, $fromArray['year'])); for ($i = $fromArray['mday']; $i <= $imax; ++$i) $days[] = $i; for ($i = 1; $i <= $toArray['mday']; ++$i) $days[] = $i; } foreach ($days as $i) { if ($layers == 1) $this->_values[$i] = 0; else for ($j = 0; $j < $layers; $j++) $this->_values[$j][$i] = 0; $this->_legend[$i] = ($i % 2) ? '' : sprintf('%02d', $i); } } if (is_callable(array($this, 'setMonthValues'))) $this->setMonthValues($layers); } // If the granularity is less than 1 year elseif (strtotime('-1 year', strtotime($this->_employee->stats_date_to)) < strtotime($this->_employee->stats_date_from)) { if ($legend) { $months = array(); if ($fromArray['year'] == $toArray['year']) for ($i = $fromArray['mon']; $i <= $toArray['mon']; ++$i) $months[] = $i; else { for ($i = $fromArray['mon']; $i <= 12; ++$i) $months[] = $i; for ($i = 1; $i <= $toArray['mon']; ++$i) $months[] = $i; } foreach ($months as $i) { if ($layers == 1) $this->_values[$i] = 0; else for ($j = 0; $j < $layers; $j++) $this->_values[$j][$i] = 0; $this->_legend[$i] = sprintf('%02d', $i); } } if (is_callable(array($this, 'setYearValues'))) $this->setYearValues($layers); } // If the granularity is greater than 1 year else { if ($legend) { $years = array(); for ($i = $fromArray['year']; $i <= $toArray['year']; ++$i) $years[] = $i; foreach ($years as $i) { if ($layers == 1) $this->_values[$i] = 0; else for ($j = 0; $j < $layers; $j++) $this->_values[$j][$i] = 0; $this->_legend[$i] = sprintf('%04d', $i); } } if (is_callable(array($this, 'setAllTimeValues'))) $this->setAllTimeValues($layers); } } protected function csvExport($datas) { global $cookie; $this->setEmployee(intval($cookie->id_employee)); $this->setLang(intval($cookie->id_lang)); $layers = isset($datas['layers']) ? $datas['layers'] : 1; if (isset($datas['option'])) $this->setOption($datas['option'], $layers); $this->getData($layers); // Generate first line (column titles) if (is_array($this->_titles['main'])) for ($i = 0; $i <= sizeof($this->_titles['main']); $i++) { if ($i > 0) $this->_csv .= ';'; if (isset($this->_titles['main'][$i])) $this->_csv .= $this->_titles['main'][$i]; } else // If there is only one column title, there is in fast two column (the first without title) $this->_csv .= ';'.$this->_titles['main']; $this->_csv .= "\n"; if (sizeof($this->_legend)) { $total = 0; if ($datas['type'] == 'pie') foreach ($this->_legend AS $key => $legend) for ($i = 0; $i < (is_array($this->_titles['main']) ? sizeof($this->_values) : 1); ++$i) $total += (is_array($this->_values[$i]) ? $this->_values[$i][$key] : $this->_values[$key]); foreach ($this->_legend AS $key => $legend) { $this->_csv .= $legend.';'; for ($i = 0; $i < (is_array($this->_titles['main']) ? sizeof($this->_values) : 1); ++$i) { if (!isset($this->_values[$i]) || !is_array($this->_values[$i])) if (isset($this->_values[$key])) { // We don't want strings to be divided. Example: product name if (is_numeric($this->_values[$key])) $this->_csv .= $this->_values[$key] / (($datas['type'] == 'pie') ? $total : 1); else $this->_csv .= $this->_values[$key]; }else $this->_csv .= '0'; else { // We don't want strings to be divided. Example: product name if (is_numeric($this->_values[$i][$key])) $this->_csv .= $this->_values[$i][$key] / (($datas['type'] == 'pie') ? $total : 1); else $this->_csv .= $this->_values[$i][$key]; } $this->_csv .= ';'; } $this->_csv .= "\n"; } } $this->_displayCsv(); } protected function _displayCsv() { ob_end_clean(); header('Content-Type: application/octet-stream'); header('Content-Disposition: attachment; filename="'.$this->displayName.' - '.time().'.csv"'); echo $this->_csv; exit; } public function create($render, $type, $width, $height, $layers) { if (!Tools::file_exists_cache($file = dirname(__FILE__).'/../modules/'.$render.'/'.$render.'.php')) die(Tools::displayError()); require_once($file); $this->_render = new $render($type); $this->getData($layers); $this->_render->createValues($this->_values); $this->_render->setSize($width, $height); $this->_render->setLegend($this->_legend); $this->_render->setTitles($this->_titles); } public function draw() { $this->_render->draw(); } public static function engine($params) { if (!($render = Configuration::get('PS_STATS_RENDER'))) return Tools::displayError('No graph engine selected'); if (!file_exists(dirname(__FILE__).'/../modules/'.$render.'/'.$render.'.php')) return Tools::displayError('Graph engine selected is unavailable.'); global $cookie; $id_employee = (int)($cookie->id_employee); $id_lang = (int)($cookie->id_lang); if (!isset($params['layers'])) $params['layers'] = 1; if (!isset($params['type'])) $params['type'] = 'column'; if (!isset($params['width'])) $params['width'] = 550; if (!isset($params['height'])) $params['height'] = 270; global $cookie; $id_employee = (int)($cookie->id_employee); $drawer = 'drawer.php?render='.$render.'&module='.Tools::safeOutput(Tools::getValue('module')).'&type='.Tools::safeOutput($params['type']).'&layers='.Tools::safeOutput($params['layers']).'&id_employee='.$id_employee.'&id_lang='.$id_lang; if (isset($params['option'])) $drawer .= '&option='.$params['option']; require_once(dirname(__FILE__).'/../modules/'.$render.'/'.$render.'.php'); return call_user_func(array($render, 'hookGraphEngine'), $params, $drawer); } protected static function getEmployee($employee = null) { if (!$employee) { global $cookie; $employee = new Employee((int)($cookie->id_employee)); } if (empty($employee->stats_date_from) OR empty($employee->stats_date_to) OR $employee->stats_date_from == '0000-00-00' OR $employee->stats_date_to == '0000-00-00') { if (empty($employee->stats_date_from) OR $employee->stats_date_from == '0000-00-00') $employee->stats_date_from = date('Y').'-01-01'; if (empty($employee->stats_date_to) OR $employee->stats_date_to == '0000-00-00') $employee->stats_date_to = date('Y').'-12-31'; $employee->update(); } return $employee; } public function getDate() { return self::getDateBetween($this->_employee); } public static function getDateBetween($employee = null) { $employee = self::getEmployee($employee); return ' \''.$employee->stats_date_from.' 00:00:00\' AND \''.$employee->stats_date_to.' 23:59:59\' '; } public function getLang() { return $this->_id_lang; } }