2005-08-24 22:29:41 +02:00
|
|
|
|
<?php
|
2007-01-02 16:23:19 +01:00
|
|
|
|
/* Copyright (C) 2003-2007 Rodolphe Quiedeville <rodolphe@quiedeville.org>
|
2008-01-10 18:12:07 +01:00
|
|
|
|
* Copyright (C) 2004-2008 Laurent Destailleur <eldy@users.sourceforge.net>
|
2005-08-24 22:29:41 +02:00
|
|
|
|
* Copyright (C) 2005 Marc Barilley / Ocebo <marc@ocebo.com>
|
2007-11-01 21:39:36 +01:00
|
|
|
|
* Copyright (C) 2005 Regis Houssin <regis@dolibarr.fr>
|
2005-08-24 22:29:41 +02:00
|
|
|
|
* Copyright (C) 2005 Simon TOSSER <simon@kornog-computing.com>
|
|
|
|
|
|
*
|
|
|
|
|
|
* 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.
|
|
|
|
|
|
*/
|
2005-09-06 18:33:13 +02:00
|
|
|
|
|
2005-08-25 01:58:47 +02:00
|
|
|
|
/**
|
|
|
|
|
|
\file htdocs/product/document.php
|
|
|
|
|
|
\ingroup product
|
|
|
|
|
|
\brief Page des documents joints sur les produits
|
2008-02-25 00:29:30 +01:00
|
|
|
|
\version $Id$
|
2005-08-25 01:58:47 +02:00
|
|
|
|
*/
|
|
|
|
|
|
|
2005-08-24 22:29:41 +02:00
|
|
|
|
require('./pre.inc.php');
|
2006-08-02 00:42:38 +02:00
|
|
|
|
require_once(DOL_DOCUMENT_ROOT."/lib/product.lib.php");
|
2005-08-25 01:58:47 +02:00
|
|
|
|
require_once(DOL_DOCUMENT_ROOT."/product.class.php");
|
2008-05-04 15:33:49 +02:00
|
|
|
|
require_once(DOL_DOCUMENT_ROOT."/lib/files.lib.php");
|
2008-01-10 18:12:07 +01:00
|
|
|
|
require_once(DOL_DOCUMENT_ROOT."/html.formfile.class.php");
|
2005-08-24 22:29:41 +02:00
|
|
|
|
|
2005-12-03 12:48:44 +01:00
|
|
|
|
$langs->load("other");
|
2006-06-10 11:27:34 +02:00
|
|
|
|
$langs->load("products");
|
2005-12-03 12:47:09 +01:00
|
|
|
|
|
2005-08-24 22:29:41 +02:00
|
|
|
|
if (!$user->rights->produit->lire)
|
|
|
|
|
|
accessforbidden();
|
|
|
|
|
|
|
|
|
|
|
|
$action=empty($_GET['action']) ? (empty($_POST['action']) ? '' : $_POST['action']) : $_GET['action'];
|
2005-12-03 04:49:00 +01:00
|
|
|
|
|
2008-05-04 16:24:29 +02:00
|
|
|
|
// Security check
|
|
|
|
|
|
if ($user->societe_id > 0)
|
|
|
|
|
|
{
|
|
|
|
|
|
unset($_GET["action"]);
|
|
|
|
|
|
$action='';
|
|
|
|
|
|
$socid = $user->societe_id;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// Get parameters
|
|
|
|
|
|
$page=$_GET["page"];
|
|
|
|
|
|
$sortorder=$_GET["sortorder"];
|
|
|
|
|
|
$sortfield=$_GET["sortfield"];
|
|
|
|
|
|
|
|
|
|
|
|
if (! $sortorder) $sortorder="ASC";
|
|
|
|
|
|
if (! $sortfield) $sortfield="name";
|
|
|
|
|
|
if ($page == -1) { $page = 0 ; }
|
|
|
|
|
|
$offset = $conf->liste_limit * $page ;
|
|
|
|
|
|
$pageprev = $page - 1;
|
|
|
|
|
|
$pagenext = $page + 1;
|
|
|
|
|
|
|
|
|
|
|
|
|
2005-12-03 04:49:00 +01:00
|
|
|
|
$product = new Product($db);
|
|
|
|
|
|
if ($_GET['id'] || $_GET["ref"])
|
2005-08-25 01:58:47 +02:00
|
|
|
|
{
|
2005-12-03 04:49:00 +01:00
|
|
|
|
if ($_GET["ref"]) $result = $product->fetch('',$_GET["ref"]);
|
|
|
|
|
|
if ($_GET["id"]) $result = $product->fetch($_GET["id"]);
|
|
|
|
|
|
|
2008-07-10 19:11:04 +02:00
|
|
|
|
$upload_dir = $conf->produit->dir_output.'/'.sanitize_string($product->ref);
|
2005-08-25 01:58:47 +02:00
|
|
|
|
}
|
2008-02-25 00:29:30 +01:00
|
|
|
|
$modulepart='produit';
|
2005-08-24 22:29:41 +02:00
|
|
|
|
|
2005-12-03 04:49:00 +01:00
|
|
|
|
|
2005-08-25 01:58:47 +02:00
|
|
|
|
/*
|
|
|
|
|
|
* Action envoie fichier
|
|
|
|
|
|
*/
|
2005-12-03 04:49:00 +01:00
|
|
|
|
if ($_POST["sendit"] && $conf->upload)
|
2005-08-24 22:29:41 +02:00
|
|
|
|
{
|
2005-08-25 02:04:51 +02:00
|
|
|
|
/*
|
|
|
|
|
|
* Creation r<EFBFBD>pertoire si n'existe pas
|
|
|
|
|
|
*/
|
|
|
|
|
|
if (! is_dir($upload_dir)) create_exdir($upload_dir);
|
|
|
|
|
|
|
2005-08-25 01:58:47 +02:00
|
|
|
|
if (is_dir($upload_dir))
|
|
|
|
|
|
{
|
2008-07-10 19:11:04 +02:00
|
|
|
|
if (dol_move_uploaded_file($_FILES['userfile']['tmp_name'], $upload_dir . "/" . $_FILES['userfile']['name'],0) > 0)
|
2005-08-25 01:58:47 +02:00
|
|
|
|
{
|
|
|
|
|
|
$mesg = '<div class="ok">'.$langs->trans("FileTransferComplete").'</div>';
|
|
|
|
|
|
//print_r($_FILES);
|
|
|
|
|
|
}
|
|
|
|
|
|
else
|
|
|
|
|
|
{
|
|
|
|
|
|
// Echec transfert (fichier d<>passant la limite ?)
|
|
|
|
|
|
$mesg = '<div class="error">'.$langs->trans("ErrorFileNotUploaded").'</div>';
|
|
|
|
|
|
// print_r($_FILES);
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
2005-08-24 22:29:41 +02:00
|
|
|
|
|
|
|
|
|
|
|
2007-07-30 22:43:57 +02:00
|
|
|
|
/*
|
|
|
|
|
|
*
|
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
$html = new Form($db);
|
2005-08-24 22:29:41 +02:00
|
|
|
|
|
2006-06-10 11:27:34 +02:00
|
|
|
|
llxHeader("","",$langs->trans("CardProduct".$product->type));
|
2005-08-25 01:58:47 +02:00
|
|
|
|
|
2005-08-24 22:29:41 +02:00
|
|
|
|
|
2005-12-03 04:49:00 +01:00
|
|
|
|
if ($product->id)
|
2005-08-24 22:29:41 +02:00
|
|
|
|
{
|
2005-08-25 01:58:47 +02:00
|
|
|
|
if ( $error_msg )
|
|
|
|
|
|
{
|
|
|
|
|
|
echo '<div class="error">'.$error_msg.'</div><br>';
|
|
|
|
|
|
}
|
2005-08-24 22:29:41 +02:00
|
|
|
|
|
2005-08-25 01:58:47 +02:00
|
|
|
|
if ($action=='delete')
|
|
|
|
|
|
{
|
|
|
|
|
|
$file = $upload_dir . '/' . urldecode($_GET['urlfile']);
|
2008-02-25 00:29:30 +01:00
|
|
|
|
$result=dol_delete_file($file);
|
|
|
|
|
|
//if ($result >= 0) $mesg=$langs->trans("FileWasRemoced");
|
2005-08-25 01:58:47 +02:00
|
|
|
|
}
|
2005-08-24 22:29:41 +02:00
|
|
|
|
|
2007-01-02 16:23:19 +01:00
|
|
|
|
$head=product_prepare_head($product, $user);
|
2006-08-02 00:42:38 +02:00
|
|
|
|
$titre=$langs->trans("CardProduct".$product->type);
|
|
|
|
|
|
dolibarr_fiche_head($head, 'documents', $titre);
|
2005-08-24 22:29:41 +02:00
|
|
|
|
|
2005-08-25 01:58:47 +02:00
|
|
|
|
|
2008-05-04 15:33:49 +02:00
|
|
|
|
// Construit liste des fichiers
|
|
|
|
|
|
$filearray=dol_dir_list($upload_dir,"files",0,'','\.meta$',$sortfield,(strtolower($sortorder)=='desc'?SORT_ASC:SORT_DESC),1);
|
|
|
|
|
|
$totalsize=0;
|
|
|
|
|
|
foreach($filearray as $key => $file)
|
|
|
|
|
|
{
|
|
|
|
|
|
$totalsize+=$file['size'];
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2005-08-25 01:58:47 +02:00
|
|
|
|
|
2005-12-03 04:49:00 +01:00
|
|
|
|
print '<table class="border" width="100%">';
|
|
|
|
|
|
|
|
|
|
|
|
// Reference
|
|
|
|
|
|
print '<tr>';
|
|
|
|
|
|
print '<td width="28%">'.$langs->trans("Ref").'</td><td colspan="3">';
|
2007-11-10 15:30:54 +01:00
|
|
|
|
print $html->showrefnav($product,'ref','',1,'ref');
|
2005-12-03 04:49:00 +01:00
|
|
|
|
print '</td>';
|
|
|
|
|
|
print '</tr>';
|
|
|
|
|
|
|
|
|
|
|
|
// Libelle
|
|
|
|
|
|
print '<tr><td>'.$langs->trans("Label").'</td><td colspan="3">'.$product->libelle.'</td></tr>';
|
|
|
|
|
|
|
2006-03-17 00:54:29 +01:00
|
|
|
|
// Prix
|
2007-07-30 22:43:57 +02:00
|
|
|
|
print '<tr><td>'.$langs->trans("SellingPrice").'</td><td colspan="2">';
|
|
|
|
|
|
if ($product->price_base_type == 'TTC')
|
|
|
|
|
|
{
|
|
|
|
|
|
print price($product->price_ttc).' '.$langs->trans($product->price_base_type);
|
|
|
|
|
|
}
|
|
|
|
|
|
else
|
|
|
|
|
|
{
|
|
|
|
|
|
print price($product->price).' '.$langs->trans($product->price_base_type);
|
|
|
|
|
|
}
|
|
|
|
|
|
print '</td></tr>';
|
2006-03-17 00:54:29 +01:00
|
|
|
|
|
|
|
|
|
|
// Statut
|
|
|
|
|
|
print '<tr><td>'.$langs->trans("Status").'</td><td colspan="2">';
|
|
|
|
|
|
print $product->getLibStatut(2);
|
|
|
|
|
|
print '</td></tr>';
|
|
|
|
|
|
|
2005-08-25 01:58:47 +02:00
|
|
|
|
print '<tr><td>'.$langs->trans("NbOfAttachedFiles").'</td><td colspan="3">'.sizeof($filearray).'</td></tr>';
|
|
|
|
|
|
print '<tr><td>'.$langs->trans("TotalSizeOfAttachedFiles").'</td><td colspan="3">'.$totalsize.' '.$langs->trans("bytes").'</td></tr>';
|
|
|
|
|
|
print '</table>';
|
2005-08-24 22:29:41 +02:00
|
|
|
|
|
2005-08-25 01:58:47 +02:00
|
|
|
|
print '</div>';
|
2005-08-24 22:29:41 +02:00
|
|
|
|
|
|
|
|
|
|
|
2006-11-13 23:01:35 +01:00
|
|
|
|
// Affiche formulaire upload
|
2008-01-10 18:12:07 +01:00
|
|
|
|
$formfile=new FormFile($db);
|
|
|
|
|
|
$formfile->form_attach_new_file(DOL_URL_ROOT.'/product/document.php?id='.$product->id);
|
2005-08-24 22:29:41 +02:00
|
|
|
|
|
2006-11-13 23:01:35 +01:00
|
|
|
|
|
2008-05-04 15:33:49 +02:00
|
|
|
|
// List of document
|
2008-05-04 16:24:29 +02:00
|
|
|
|
$param='&id='.$product->id;
|
|
|
|
|
|
$formfile->list_of_documents($filearray,$product,'produit',$param);
|
2007-10-29 23:05:45 +01:00
|
|
|
|
|
2005-08-24 22:29:41 +02:00
|
|
|
|
}
|
|
|
|
|
|
else
|
|
|
|
|
|
{
|
|
|
|
|
|
print $langs->trans("UnkownError");
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
$db->close();
|
|
|
|
|
|
|
|
|
|
|
|
llxFooter('$Date$ - $Revision$');
|
|
|
|
|
|
?>
|