123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187 |
- <?php
- /**
- * Define a exportmodel.
- * @author Valentin MORREEL
- * @category Plugin
- * @license copyright
- */
- class ExportModel extends Entity{
- public $id,$label,$description,$plugin,$dataset,$slug,$filename,$privacy,$export_format;
- protected $TABLE_NAME = 'export_model';
- public $fields =
- array(
- 'id' => 'key',
- 'label' => 'string',
- 'description' => 'longstring',
- 'plugin' => 'string',
- 'dataset' => 'string',
- 'slug' => 'string',
- 'filename' => 'string',
- 'privacy' => 'string',
- 'export_format' => 'string'
- );
- const PRIVACY_PRIVATE = 'private';
- const PRIVACY_PUBLIC = 'public';
- public function privacy(){
- return $this->privacy==self::PRIVACY_PRIVATE?'Privé':'Public';
- }
- //Renvoie les infos des documents placés en dropzone
- public function documents(){
- $documents = array();
- foreach(glob(__ROOT__.FILE_PATH.'export'.SLASH.'documents'.SLASH.$this->plugin.SLASH.$this->id.SLASH.'*.*') as $file){
- if(is_dir($file)) continue;
- $filenameDisk = $file;
- // $filenameDisk = strtoupper(substr(PHP_OS, 0, 3)) === 'WIN' ? html_decode_utf8($file) : $file;
- if(strtoupper(substr(PHP_OS, 0, 3)) === 'WIN') $file = utf8_encode($file);
- $documents[] = array(
- 'path' => 'export'.SLASH.'documents'.SLASH.$this->plugin.SLASH.$this->id.SLASH.basename($file),
- 'url' => 'action.php?action=export_exportmodel_download_document&path='.$this->plugin.SLASH.$this->id.SLASH.rawurlencode(basename($file)),
- 'name' => basename($file),
- 'icon' => getExtIcon(getExt($file)),
- 'lastModification' => ' - '.date('d/m/Y', filemtime($filenameDisk))
- );
- }
- return $documents;
- }
- public static function get_standard_dataset($parameters){
- global $myUser, $myFirm;
- if(isset($parameters['description']) && $parameters['description']!=true){
- //Common DS
- $data['programme.date.compact'] = date('d/m/Y');
- setlocale (LC_TIME, 'fr_FR.utf8','fra');
- $data['programme.date.littéral'] = utf8_encode(strftime('%d %B %Y'));
- $data['programme.heure'] = date('H:i');
- $data['utilisateur.photo'] = '::'.$myUser->getAvatar(true);
- $data['utilisateur.identifiant'] = $myUser->login;
- $data['utilisateur.prénom'] = $myUser->firstname;
- $data['utilisateur.nom'] = $myUser->name;
- $data['utilisateur.fonction'] = $myUser->function;
- $data['utilisateur.email'] = $myUser->mail;
-
- $data['établissement.logo'] = '::'.$myFirm->logo('path');
- $data['établissement.libellé'] = $myFirm->label;
- $data['établissement.téléphone'] = $myFirm->phone;
- $data['établissement.fax'] = $myFirm->fax;
- $data['établissement.adresse.rue'] = $myFirm->street;
- $data['établissement.adresse.complément'] = $myFirm->street2;
- $data['établissement.adresse.ville'] = $myFirm->city;
- $data['établissement.adresse.cp'] = $myFirm->zipcode;
- $data['établissement.email'] = $myFirm->mail;
- $data['établissement.siret'] = $myFirm->siret;
- } else {
- //Common DS
- $data['programme.date.compact'] = 'Date courante (format "dd/mm/YYYY")';
- $data['programme.date.littéral'] = 'Date courante (format "01 Janvier 1970")';
- $data['programme.heure'] = 'Heure courante (format hh:mm)';
- $data['utilisateur.photo'] = array('desc'=>'Photo de profil de l\'utilisateur courant', 'type'=>'photo');
- $data['utilisateur.identifiant'] = 'Identifiant de l\'utilisateur courant';
- $data['utilisateur.prénom'] = 'Prénom de l\'utilisateur courant';
- $data['utilisateur.nom'] = 'Nom de l\'utilisateur courant';
- $data['utilisateur.fonction'] = 'Fonction occupée par l\'utilisateur courant';
- $data['utilisateur.email'] = 'Adresse e-mail de l\'utilisateur courant';
- $data['établissement.logo'] = array('desc'=>'Le logo de l\'établissement courant', 'type'=>'photo');
- $data['établissement.libellé'] = 'Le libellé de l\'établissement courant';
- $data['établissement.téléphone'] = 'Le n° de téléphone de l\'établissement courant';
- $data['établissement.fax'] = 'Le n° de fax de l\'établissement courant';
- $data['établissement.adresse.rue'] = 'La rue de l\'établissement courant';
- $data['établissement.adresse.complément'] ='Le complément d\'adresse de l\'établissement courant';
- $data['établissement.adresse.ville'] ='La ville de l\'établissement courant';
- $data['établissement.adresse.cp'] = 'Le code postal de l\'établissement courant';
- $data['établissement.email'] = 'L\'adresse mail de l\'établissement courant';
- $data['établissement.siret'] = 'Le n° de SIRET de l\'établissement courant';
- }
- return $data;
- }
- //Renvoie les différents type de templates pris en compte
- public static function templates($key=null){
- $templates = array();
- foreach (glob(__DIR__.SLASH.'template'.SLASH.'*.class.php') as $templatePath) {
- require_once($templatePath);
- $className = str_replace('.class.php','',basename($templatePath));
- $infos = get_class_vars($className);
- $templates[$infos['extension']] = array('handler' => $className,'mime'=>$infos['mime'],'extension'=>$infos['extension'], 'description'=>$infos['description']);
- }
- if(!isset($key)) return $templates;
- return isset($templates[$key]) ? $templates[$key] : $templates['txt'];
- }
- //Permet d'ajouter un jeu de données pour un plugin donné
- public static function add($plugin, $dataset, $label, $func){
- Plugin::addHook('export_model_data', function(&$datasets, $params) use ($plugin, $dataset, $label, $func){
- global $myUser;
- if(isset($params['plugin']) && $params['plugin'] != $plugin) return;
- if(isset($params['dataset']) && $params['dataset'] != $dataset) return;
- $datasets[$dataset] = array(
- 'plugin' => $plugin,
- 'dataset' => $dataset,
- 'label' => $label,
- 'function' => $func
- );
- });
- }
- //Récuperation de toutes les données (ou description) d'un dataset
- public static function dataset($plugin,$dataset,$parameters=array(),$description = null){
-
- $datasets = array();
-
- Plugin::callHook('export_model_data', array(
- &$datasets, array(
- 'plugin' => $plugin,
- 'dataset' => $dataset,
- 'description' => true
- )));
- $current = reset($datasets);
- $current['values'] = array();
- //Merge des données génériques erp et des données du dataset
- $allDataset = array_merge(
- ExportModel::get_standard_dataset($parameters),
- $current['function']($parameters)
- );
- foreach ($allDataset as $macro => $value) {
- $row = array();
- if(is_array($value)){
- $row['type'] = $value['type'];
- $row['desc'] = $value['desc'];
- if(isset($value['subitems']))
- $row['subitems'] = $value['subitems'];
- } else {
- $row['type'] = 'value';
- $row['desc'] = $value;
- }
- $current['values'][$macro] = $row;
- }
- return $current;
- }
- //Permet de fusionner le fichier d'export modèle et les données associées
- public static function merge_data_template(&$filename, $docInfos, $datas, $return = 'stream'){
- $document = $docInfos['document'];
- $ext = getExt($document['name']);
- $tplType = ExportModel::templates($docInfos['format']);
- $tplHandler = $tplType['handler'];
- //Gestion macros de nombre et macro dans le titre
- foreach($datas as $key => $value){
- if(is_array($value)){
- $datas[$key.'.nombre'] = count($value);
- continue;
- }
- $filename = str_replace('{{'.$key.'}}', $value, $filename);
- }
- $filename = preg_replace('#[\<\>\?\|\*\:\\\/\"\'\,]#i', '-', $filename);
- $filePath = (strtoupper(substr(PHP_OS, 0, 3)) === 'WIN') ? utf8_decode($document['path']) : $document['path'];
- return $tplHandler::from_template($filePath, $datas, $return);
- }
- }
- ?>
|