* Copyright (C) 2004-2005 Laurent Destailleur * Copyright (C) 2005-2007 Regis Houssin * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * * $Id$ * $Source$ */ /** \file htdocs/docsoc.php \brief Fichier onglet documents liés à la société \ingroup societe \version $Revision$ */ require("./pre.inc.php"); require_once(DOL_DOCUMENT_ROOT."/lib/company.lib.php"); $langs->load("companies"); $langs->load('other'); $user->getrights('commercial'); $mesg = ""; // Sécurité accés client $socid = isset($_GET["socid"])?$_GET["socid"]:''; if ($socid == '') accessforbidden(); if ($user->societe_id > 0) { $action = ''; $socid = $user->societe_id; } // Protection restriction commercial if (!$user->rights->commercial->client->voir && $socid && !$user->societe_id > 0) { $sql = "SELECT sc.fk_soc, s.client"; $sql .= " FROM ".MAIN_DB_PREFIX."societe_commerciaux as sc, ".MAIN_DB_PREFIX."societe as s"; $sql .= " WHERE sc.fk_soc = ".$socid." AND sc.fk_user = ".$user->id." AND s.client = 1"; if ( $db->query($sql) ) { if ( $db->num_rows() == 0) accessforbidden(); } } /* * Actions */ $upload_dir = $conf->societe->dir_output . "/" . $socid ; $courrier_dir = $conf->societe->dir_output . "/courrier/" . get_exdir($socid) ; // Envoie fichier if ( $_POST["sendit"] && $conf->upload != 0) { if (! is_dir($upload_dir)) create_exdir($upload_dir); if (is_dir($upload_dir)) { if (doliMoveFileUpload($_FILES['userfile']['tmp_name'], $upload_dir . "/" . $_FILES['userfile']['name'])) { $mesg = '
'.$langs->trans("FileTransferComplete").'
'; //print_r($_FILES); } else { // Echec transfert (fichier dépassant la limite ?) $mesg = '
'.$langs->trans("ErrorFileNotUploaded").'
'; // print_r($_FILES); } } } // Suppression fichier if ($_POST['action'] == 'confirm_deletefile' && $_POST['confirm'] == 'yes') { $file = $upload_dir . "/" . urldecode($_GET["urlfile"]); dol_delete_file($file); $mesg = '
'.$langs->trans("FileWasRemoved").'
'; } /* * Affichage liste */ llxHeader(); if ($socid > 0) { $societe = new Societe($db); if ($societe->fetch($socid)) { /* * Affichage onglets */ $head = societe_prepare_head($societe); $html=new Form($db); dolibarr_fiche_head($head, 'document', $societe->nom); /* * Confirmation de la suppression d'une ligne produit */ if ($_GET['action'] == 'delete_file') { $html->form_confirm($_SERVER["PHP_SELF"].'?socid='.$socid.'&urlfile='.urldecode($_GET["urlfile"]), $langs->trans('DeleteFile'), $langs->trans('ConfirmDeleteFile'), 'confirm_deletefile'); print '
'; } // Construit liste des fichiers clearstatcache(); $totalsize=0; $filearray=array(); $errorlevel=error_reporting(); error_reporting(0); $handle=opendir($upload_dir); error_reporting($errorlevel); if ($handle) { $i=0; while (($file = readdir($handle))!==false) { if (!is_dir($dir.$file) && substr($file, 0, 1) <> '.' && substr($file, 0, 3) <> 'CVS') { $filearray[$i]=$file; $totalsize+=filesize($upload_dir."/".$file); $i++; } } closedir($handle); } else { // print '
'.$langs->trans("ErrorCanNotReadDir",$upload_dir).'
'; } print ''; // Ref print ''; // Prefix print ''; // Nbre fichiers print ''; //Total taille print ''; print '
'.$langs->trans("Name").''.$societe->nom.'
'.$langs->trans('Prefix').''.$societe->prefix_comm.'
'.$langs->trans("NbOfAttachedFiles").''.sizeof($filearray).'
'.$langs->trans("TotalSizeOfAttachedFiles").''.$totalsize.' '.$langs->trans("bytes").'
'; print ''; if ($mesg) { print "$mesg
"; } // Affiche formulaire upload $html->form_attach_new_file('docsoc.php?socid='.$socid); // Affiche liste des documents existant print_titre($langs->trans("AttachedFiles")); print ''; print ''; $var=true; foreach($filearray as $key => $file) { if (!is_dir($dir.$file) && substr($file, 0, 1) <> '.' && substr($file, 0, 3) <> 'CVS') { $var=!$var; print "\n"; print ''; print ''; print '\n"; } } print "
'.$langs->trans("Document").''.$langs->trans("Size").''.$langs->trans("Date").' 
"; echo ''.$file.''; print "'.filesize($upload_dir."/".$file). ' '.$langs->trans("bytes").''.dolibarr_print_date(filemtime($upload_dir."/".$file),"%d %b %Y %H:%M:%S").''; echo ''.img_delete().''; print "


"; // Courriers // Les courriers sont des documents speciaux generes par des scripts // Voir Rodo $filearray=array(); $errorlevel=error_reporting(); error_reporting(0); $handle=opendir($courrier_dir); error_reporting($errorlevel); if ($handle) { $i=0; while (($file = readdir($handle))!==false) { if (!is_dir($dir.$file) && substr($file, 0, 1) <> '.' && substr($file, 0, 3) <> 'CVS') { $filearray[$i]=$file; $i++; } } closedir($handle); } print ''; print ''; $var=true; foreach($filearray as $key => $file) { if (!is_dir($dir.$file) && substr($file, 0, 1) <> '.' && substr($file, 0, 3) <> 'CVS') { $var=!$var; print "\n"; print ''; print ''; print "\n"; } } print "
'.$langs->trans("Courriers").''.$langs->trans("Size").''.$langs->trans("Date").'
"; $loc = "courrier/".get_exdir($socid); echo ''.$file.''; print "'.filesize($courrier_dir."/".$file). ' '.$langs->trans("bytes").''.dolibarr_print_date(filemtime($courrier_dir."/".$file),"%d %b %Y %H:%M:%S").'
"; } else { dolibarr_print_error($db); } } else { dolibarr_print_error(); } $db->close(); llxFooter('$Date$ - $Revision$'); ?>