2010-04-09 14:40:43 +00:00

184 lines
4.7 KiB
PHP

<?php
// Include XML_Serializer
require_once('XML/Serializer.php');
/**
* Export - Gère les différents format d'exportation
* @package export
* @author Michael RICOIS
* @copyright Scores&Decisions
*/
class ExportXML {
public $fileName = '';
public $path = '';
public $rootName = 'root';
public $defaultTagName = 'element';
public $records = array();
public $encoding = 'UTF-8';
public $serializer_options = array();
public $content = '';
function __construct() {
$this->path = realpath(dirname(__FILE__).'/../cache/');
}
function setXMLOptions(){
// An array of serializer options
$this->serializer_options = array (
'addDecl' => TRUE,
'encoding' => $this->encoding,
'indent' => ' ',
'rootName' => $this->rootName,
'defaultTagName' => $this->defaultTagName,
);
}
function serialize(){
$this->setXMLOptions();
// Instantiate the serializer with the options
$err_rep = error_reporting();
error_reporting(E_ALL & ~E_NOTICE & ~E_STRICT & ~E_DEPRECATED);
$Serializer = new XML_Serializer($this->serializer_options);
// Serialize the data structure
$status = $Serializer->serialize($this->records);
// Check whether serialization worked
if (PEAR::isError($status)) {
//$status->getMessage()
}
$this->content = $Serializer->getSerializedData();
error_reporting($err_rep);
}
function writeXML($fileName){
$fileName = str_replace('.php','',$fileName);
$this->fileName = $this->path .'/'. $fileName . '.xml';
$this->serialize();
if( !file_put_contents($this->fileName, $this->content))
{
//TODO : Gestion des erreurs
}
}
}
class ExportCSV {
public $fileName = '';
public $path = '';
public $encoding = 'UTF-8';
public $delimiter = ';';
public $records = array();
function __construct() {
$this->path = realpath(dirname(__FILE__).'/../cache/');
}
/**
* Ecrit un fichier csv à partir d'un tableau.
* @param string $fileName
* @param array $records
* @param string $delimiter
* @return void
*/
function writeCSV($fileName)
{
$fileName = str_replace('.php','',$fileName);
$this->fileName = $this->path .'/'. $fileName . '.csv';
//Ouverture du fichier
$fp = fopen($this->fileName, 'w');
//On attribue le header
$newRecords=array();
$this->array_flatten($this->records[0],$newRecords);
$headerKeys = array_keys($newRecords);
if ($fp != FALSE){
//Header du fichier csv
fputcsv($fp, $headerKeys, $this->delimiter);
}
foreach( $this->records as $record ){
$newRecords=array();
$this->array_flatten($record,$newRecords);
$values = array_values($newRecords);
if ($fp != FALSE){
//Contenu du fichier
fputcsv($fp, $values, $this->delimiter);
}else{
//Erreur
}
}
fclose($fp);
}
function array_flatten($array, &$newArray = Array(),
$prefix = '', $delimiter = '|') {
foreach ($array as $key => $child) {
if (is_array($child)) {
$newPrefix = $prefix.$key.$delimiter;
$newArray = $this->array_flatten($child, $newArray,
$newPrefix, $delimiter);
} else {
$newArray[$prefix.$key] = $child;
}
}
return $newArray;
}
}
class tabExport
{
public $tab = array();
public $notdisplay = array();
public $title = array();
public $type = array();
public $convert = array();
function __construct() {}
function convertTable() {
$this->convert = $this->rArray($this->tab);
return $this->convert;
}
function rArray($array) {
foreach ($array as $key => $child) {
if (is_array($child)) {
if (!in_array($key, $this->notdisplay, TRUE)) {
$newArray[$this->renameKey($key)] = $this->rArray($child);
}
} else {
if (!in_array($key, $this->notdisplay, TRUE)) {
$newArray[$this->renameKey($key)] =
$this->convertValue($key, $child);
}
}
}
return $newArray;
}
function renameKey($key){
$newKey = $key;
if (array_key_exists($key, $this->title)) {
$newKey = $this->title[$key];
}
return $newKey;
}
function convertValue($key, $value){
if (array_key_exists($key, $this->type)) {
switch ($this->type[$key]) {
case 'date':
//Test des différents formats de value
break;
}
}
return $value;
}
}
class ExportPDF
{
function __construct(){}
}
?>