* Copyright (C) 2004-2012 Laurent Destailleur * Copyright (C) 2005 Eric Seigne * Copyright (C) 2005-2012 Regis Houssin * Copyright (C) 2006 Andre Cianfarani * Copyright (C) 2006 Auguria SARL * Copyright (C) 2010-2011 Juanjo Menent * * 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, see . */ /** * \file htdocs/product/fiche.php * \ingroup product * \brief Page to show product */ require("../main.inc.php"); require_once(DOL_DOCUMENT_ROOT."/core/class/canvas.class.php"); require_once(DOL_DOCUMENT_ROOT."/product/class/product.class.php"); require_once(DOL_DOCUMENT_ROOT."/product/class/html.formproduct.class.php"); require_once(DOL_DOCUMENT_ROOT."/core/class/extrafields.class.php"); require_once(DOL_DOCUMENT_ROOT."/core/lib/product.lib.php"); require_once(DOL_DOCUMENT_ROOT."/core/lib/company.lib.php"); if ($conf->propal->enabled) require_once(DOL_DOCUMENT_ROOT."/comm/propal/class/propal.class.php"); if ($conf->facture->enabled) require_once(DOL_DOCUMENT_ROOT."/compta/facture/class/facture.class.php"); if ($conf->commande->enabled) require_once(DOL_DOCUMENT_ROOT."/commande/class/commande.class.php"); $langs->load("products"); $langs->load("other"); if ($conf->stock->enabled) $langs->load("stocks"); if ($conf->facture->enabled) $langs->load("bills"); $mesg=''; $error=0; $errors=array(); $id = GETPOST('id', 'int'); $ref = GETPOST('ref', 'alpha'); $action=(GETPOST('action','alpha') ? GETPOST('action','alpha') : 'view'); $confirm=GETPOST('confirm','alpha'); $socid=GETPOST('socid','int'); if ($user->societe_id) $socid=$user->societe_id; $object = new Product($db); $extrafields = new ExtraFields($db); // Get object canvas (By default, this is not defined, so standard usage of dolibarr) $object->getCanvas($id,$ref); $canvas = $object->canvas?$object->canvas:GETPOST("canvas"); if (! empty($canvas)) { require_once(DOL_DOCUMENT_ROOT."/core/class/canvas.class.php"); $objcanvas = new Canvas($db,$action); $objcanvas->getCanvas('product','card',$canvas); } // Security check $fieldvalue = (! empty($id) ? $id : (! empty($ref) ? $ref : '')); $fieldtype = (! empty($ref) ? 'ref' : 'rowid'); $result=restrictedArea($user,'produit|service',$fieldvalue,'product&product','','',$fieldtype,$objcanvas); // Initialize technical object to manage hooks of thirdparties. Note that conf->hooks_modules contains array array include_once(DOL_DOCUMENT_ROOT.'/core/class/hookmanager.class.php'); $hookmanager=new HookManager($db); $hookmanager->initHooks(array('productcard')); /* * Actions */ $parameters=array('id'=>$id, 'ref'=>$ref, 'objcanvas'=>$objcanvas); $reshook=$hookmanager->executeHooks('doActions',$parameters,$object,$action); // Note that $action and $object may have been modified by some hooks $error=$hookmanager->error; $errors=$hookmanager->errors; if (empty($reshook)) { // Type if ($action == 'setfk_product_type' && $user->rights->produit->creer) { $object->fetch($id); $result = $object->setValueFrom('fk_product_type', $_POST['fk_product_type']); Header("Location: ".$_SERVER['PHP_SELF']."?id=".$object->id); exit; } // Barcode type if ($action == 'setfk_barcode_type' && $user->rights->barcode->creer) { $object->fetch($id); $result = $object->setValueFrom('fk_barcode_type', $_POST['fk_barcode_type']); Header("Location: ".$_SERVER['PHP_SELF']."?id=".$object->id); exit; } // Barcode value if ($action == 'setbarcode' && $user->rights->barcode->creer) { $object->fetch($id); //Todo: ajout verification de la validite du code barre en fonction du type $result = $object->setValueFrom('barcode', $_POST['barcode']); Header("Location: ".$_SERVER['PHP_SELF']."?id=".$object->id); exit; } if ($action == 'setaccountancy_code_buy') { $object->fetch($id,$ref); $result = $object->setValueFrom('accountancy_code_buy', $_POST['accountancy_code_buy']); if ($result < 0) { $mesg=join(',',$object->errors); } $action=""; } if ($action == 'setaccountancy_code_sell') { $object->fetch($id,$ref); $result = $object->setValueFrom('accountancy_code_sell', $_POST['accountancy_code_sell']); if ($result < 0) { $mesg=join(',',$object->errors); } $action=""; } // Add a product or service if ($action == 'add' && ($user->rights->produit->creer || $user->rights->service->creer)) { $error=0; if (empty($_POST["libelle"])) { $mesg='
'.$langs->trans('ErrorFieldRequired',$langs->transnoentities('Label')).'
'; $action = "create"; $_GET["canvas"] = $_POST["canvas"]; $_GET["type"] = $_POST["type"]; $error++; } if (empty($ref)) { $mesg='
'.$langs->trans('ErrorFieldRequired',$langs->transnoentities('Ref')).'
'; $action = "create"; $_GET["canvas"] = $_POST["canvas"]; $_GET["type"] = $_POST["type"]; $error++; } if (! $error) { $object->ref = $ref; $object->libelle = $_POST["libelle"]; $object->price_base_type = $_POST["price_base_type"]; if ($object->price_base_type == 'TTC') $object->price_ttc = $_POST["price"]; else $object->price = $_POST["price"]; if ($object->price_base_type == 'TTC') $object->price_min_ttc = $_POST["price_min"]; else $object->price_min = $_POST["price_min"]; $object->tva_tx = str_replace('*','',$_POST['tva_tx']); $object->tva_npr = preg_match('/\*/',$_POST['tva_tx'])?1:0; // local taxes. $object->localtax1_tx = get_localtax($object->tva_tx,1); $object->localtax2_tx = get_localtax($object->tva_tx,2); $object->type = $_POST["type"]; $object->status = $_POST["statut"]; $object->status_buy = $_POST["statut_buy"]; $object->description = dol_htmlcleanlastbr($_POST["desc"]); $object->note = dol_htmlcleanlastbr($_POST["note"]); $object->customcode = $_POST["customcode"]; $object->country_id = $_POST["country_id"]; $object->duration_value = $_POST["duration_value"]; $object->duration_unit = $_POST["duration_unit"]; $object->seuil_stock_alerte = $_POST["seuil_stock_alerte"]?$_POST["seuil_stock_alerte"]:0; $object->canvas = $_POST["canvas"]; $object->weight = $_POST["weight"]; $object->weight_units = $_POST["weight_units"]; $object->length = $_POST["size"]; $object->length_units = $_POST["size_units"]; $object->surface = $_POST["surface"]; $object->surface_units = $_POST["surface_units"]; $object->volume = $_POST["volume"]; $object->volume_units = $_POST["volume_units"]; $object->finished = $_POST["finished"]; $object->hidden = $_POST["hidden"]=='yes'?1:0; // MultiPrix if($conf->global->PRODUIT_MULTIPRICES) { for($i=2;$i<=$conf->global->PRODUIT_MULTIPRICES_LIMIT;$i++) { if($_POST["price_".$i]) { $object->multiprices["$i"] = price2num($_POST["price_".$i],'MU'); $object->multiprices_base_type["$i"] = $_POST["multiprices_base_type_".$i]; } else { $object->multiprices["$i"] = ""; } } } // Get extra fields foreach($_POST as $key => $value) { if (preg_match("/^options_/",$key)) { $object->array_options[$key]=$_POST[$key]; } } $id = $object->create($user); if ($id > 0) { Header("Location: ".$_SERVER['PHP_SELF']."?id=".$id); exit; } else { $mesg='
'.$langs->trans($object->error).'
'; $action = "create"; $_GET["type"] = $_POST["type"]; } } } // Update a product or service if ($action == 'update' && ($user->rights->produit->creer || $user->rights->service->creer)) { if (! empty($_POST["cancel"])) { $action = ''; } else { if ($object->fetch($id,$ref)) { $object->oldcopy=dol_clone($object); $object->ref = $ref; $object->libelle = $_POST["libelle"]; $object->description = dol_htmlcleanlastbr($_POST["desc"]); $object->note = dol_htmlcleanlastbr($_POST["note"]); $object->customcode = $_POST["customcode"]; $object->country_id = $_POST["country_id"]; $object->status = $_POST["statut"]; $object->status_buy = $_POST["statut_buy"]; $object->seuil_stock_alerte = $_POST["seuil_stock_alerte"]; $object->duration_value = $_POST["duration_value"]; $object->duration_unit = $_POST["duration_unit"]; $object->canvas = $_POST["canvas"]; $object->weight = $_POST["weight"]; $object->weight_units = $_POST["weight_units"]; $object->length = $_POST["size"]; $object->length_units = $_POST["size_units"]; $object->surface = $_POST["surface"]; $object->surface_units = $_POST["surface_units"]; $object->volume = $_POST["volume"]; $object->volume_units = $_POST["volume_units"]; $object->finished = $_POST["finished"]; $object->hidden = $_POST["hidden"]=='yes'?1:0; // Get extra fields foreach($_POST as $key => $value) { if (preg_match("/^options_/",$key)) { $object->array_options[$key]=$_POST[$key]; } } if ($object->check()) { if ($object->update($object->id, $user) > 0) { $action = 'view'; } else { $action = 'edit'; $mesg = $object->error; } } else { $action = 'edit'; $mesg = $langs->trans("ErrorProductBadRefOrLabel"); } } } } // Action clone object if ($action == 'confirm_clone' && $confirm != 'yes') { $action=''; } if ($action == 'confirm_clone' && $confirm == 'yes' && ($user->rights->produit->creer || $user->rights->service->creer)) { if (! GETPOST('clone_content') && ! GETPOST('clone_prices') ) { $mesg='
'.$langs->trans("NoCloneOptionsSpecified").'
'; } else { $db->begin(); $originalId = $id; if ($object->fetch($id,$ref) > 0) { $object->ref = GETPOST('clone_ref'); $object->status = 0; $object->status_buy = 0; $object->finished = 1; $object->id = null; if ($object->check()) { $id = $object->create($user); if ($id > 0) { // $object->clone_fournisseurs($originalId, $id); $db->commit(); $db->close(); Header("Location: ".$_SERVER["PHP_SELF"]."?id=".$id); exit; } else { $id=$originalId; if ($object->error == 'ErrorProductAlreadyExists') { $db->rollback(); $_error = 1; $action = ""; $mesg='
'.$langs->trans("ErrorProductAlreadyExists",$object->ref); $mesg.=' '.$langs->trans("ShowCardHere").'.'; $mesg.='
'; //dol_print_error($object->db); } else { $db->rollback(); $mesg=$object->error; dol_print_error($db,$object->error); } } } } else { $db->rollback(); dol_print_error($db,$object->error); } } } // Delete a product if ($action == 'confirm_delete' && $confirm != 'yes') { $action=''; } if ($action == 'confirm_delete' && $confirm == 'yes') { $object = new Product($db); $object->fetch($id,$ref); if ( ($object->type == 0 && $user->rights->produit->supprimer) || ($object->type == 1 && $user->rights->service->supprimer) ) { $result = $object->delete($object->id); } if ($result > 0) { Header('Location: '.DOL_URL_ROOT.'/product/liste.php?delprod='.urlencode($object->ref)); exit; } else { $mesg=$object->error; $reload = 0; $action=''; } } // Add product into proposal if ($action == 'addinpropal') { $propal = new Propal($db); $result=$propal->fetch($_POST["propalid"]); if ($result <= 0) { dol_print_error($db,$propal->error); exit; } $soc = new Societe($db); $result=$soc->fetch($propal->socid); if ($result <= 0) { dol_print_error($db,$soc->error); exit; } $prod = new Product($db); $result=$prod->fetch($id,$ref); if ($result <= 0) { dol_print_error($db,$prod->error); exit; } $desc = $prod->description; $tva_tx = get_default_tva($mysoc, $soc, $prod->id); $localtax1_tx= get_localtax($tva_tx, 1, $soc); $localtax2_tx= get_localtax($tva_tx, 2, $soc); $pu_ht = $prod->price; $pu_ttc = $prod->price_ttc; $price_base_type = $prod->price_base_type; // If multiprice if ($conf->global->PRODUIT_MULTIPRICES && $soc->price_level) { $pu_ht = $prod->multiprices[$soc->price_level]; $pu_ttc = $prod->multiprices_ttc[$soc->price_level]; $price_base_type = $prod->multiprices_base_type[$soc->price_level]; } // On reevalue prix selon taux tva car taux tva transaction peut etre different // de ceux du produit par defaut (par exemple si pays different entre vendeur et acheteur). if ($tva_tx != $prod->tva_tx) { if ($price_base_type != 'HT') { $pu_ht = price2num($pu_ttc / (1 + ($tva_tx/100)), 'MU'); } else { $pu_ttc = price2num($pu_ht * (1 + ($tva_tx/100)), 'MU'); } } $result = $propal->addline( $propal->id, $desc, $pu_ht, $_POST["qty"], $tva_tx, $localtax1_tx, // localtax1 $localtax2_tx, // localtax2 $prod->id, $_POST["remise_percent"], $price_base_type, $pu_ttc ); if ($result > 0) { Header("Location: ".DOL_URL_ROOT."/comm/propal.php?id=".$propal->id); return; } $mesg = $langs->trans("ErrorUnknown").": $result"; } // Add product into order if ($action == 'addincommande') { $commande = new Commande($db); $result=$commande->fetch($_POST["commandeid"]); if ($result <= 0) { dol_print_error($db,$commande->error); exit; } $soc = new Societe($db); $result=$soc->fetch($commande->socid); if ($result <= 0) { dol_print_error($db,$soc->error); exit; } $prod = new Product($db); $result=$prod->fetch($id,$ref); if ($result <= 0) { dol_print_error($db,$prod->error); exit; } $desc = $prod->description; $tva_tx = get_default_tva($mysoc, $soc, $prod->id); $localtax1_tx= get_localtax($tva_tx, 1, $soc); $localtax2_tx= get_localtax($tva_tx, 2, $soc); $pu_ht = $prod->price; $pu_ttc = $prod->price_ttc; $price_base_type = $prod->price_base_type; // If multiprice if ($conf->global->PRODUIT_MULTIPRICES && $soc->price_level) { $pu_ht = $prod->multiprices[$soc->price_level]; $pu_ttc = $prod->multiprices_ttc[$soc->price_level]; $price_base_type = $prod->multiprices_base_type[$soc->price_level]; } // On reevalue prix selon taux tva car taux tva transaction peut etre different // de ceux du produit par defaut (par exemple si pays different entre vendeur et acheteur). if ($tva_tx != $prod->tva_tx) { if ($price_base_type != 'HT') { $pu_ht = price2num($pu_ttc / (1 + ($tva_tx/100)), 'MU'); } else { $pu_ttc = price2num($pu_ht * (1 + ($tva_tx/100)), 'MU'); } } $result = $commande->addline( $commande->id, $desc, $pu_ht, $_POST["qty"], $tva_tx, $localtax1_tx, // localtax1 $localtax2_tx, // localtax2 $prod->id, $_POST["remise_percent"], '', '', //Todo: voir si fk_remise_except est encore valable car n'apparait plus dans les propales $price_base_type, $pu_ttc ); if ($result > 0) { Header("Location: ".DOL_URL_ROOT."/commande/fiche.php?id=".$commande->id); exit; } } // Add product into invoice if ($action == 'addinfacture' && $user->rights->facture->creer) { $facture = New Facture($db); $result=$facture->fetch($_POST["factureid"]); if ($result <= 0) { dol_print_error($db,$facture->error); exit; } $soc = new Societe($db); $soc->fetch($facture->socid); if ($result <= 0) { dol_print_error($db,$soc->error); exit; } $prod = new Product($db); $result = $prod->fetch($id,$ref); if ($result <= 0) { dol_print_error($db,$prod->error); exit; } $desc = $prod->description; $tva_tx = get_default_tva($mysoc, $soc, $prod->id); $localtax1_tx= get_localtax($tva_tx, 1, $soc); $localtax2_tx= get_localtax($tva_tx, 2, $soc); $pu_ht = $prod->price; $pu_ttc = $prod->price_ttc; $price_base_type = $prod->price_base_type; // If multiprice if ($conf->global->PRODUIT_MULTIPRICES && $soc->price_level) { $pu_ht = $prod->multiprices[$soc->price_level]; $pu_ttc = $prod->multiprices_ttc[$soc->price_level]; $price_base_type = $prod->multiprices_base_type[$soc->price_level]; } // On reevalue prix selon taux tva car taux tva transaction peut etre different // de ceux du produit par defaut (par exemple si pays different entre vendeur et acheteur). if ($tva_tx != $prod->tva_tx) { if ($price_base_type != 'HT') { $pu_ht = price2num($pu_ttc / (1 + ($tva_tx/100)), 'MU'); } else { $pu_ttc = price2num($pu_ht * (1 + ($tva_tx/100)), 'MU'); } } $result = $facture->addline( $facture->id, $desc, $pu_ht, $_POST["qty"], $tva_tx, $localtax1_tx, $localtax2_tx, $prod->id, $_POST["remise_percent"], '', '', '', '', '', $price_base_type, $pu_ttc ); if ($result > 0) { Header("Location: ".DOL_URL_ROOT."/compta/facture.php?facid=".$facture->id); exit; } } } if (GETPOST("cancel") == $langs->trans("Cancel")) { $action = ''; Header("Location: ".$_SERVER["PHP_SELF"]."?id=".$id); exit; } /* * View */ // fetch optionals attributes and labels $extralabels=$extrafields->fetch_name_optionals_label('product'); $helpurl=''; if (GETPOST("type") == '0') $helpurl='EN:Module_Products|FR:Module_Produits|ES:Módulo_Productos'; if (GETPOST("type") == '1') $helpurl='EN:Module_Services_En|FR:Module_Services|ES:Módulo_Servicios'; if (isset($_GET['type'])) $title = $langs->trans('CardProduct'.$_GET['type']); else $title = $langs->trans('ProductServiceCard'); llxHeader('', $title, $helpurl); $form = new Form($db); $formproduct = new FormProduct($db); $object=new Product($db); if (is_object($objcanvas) && $objcanvas->displayCanvasExists($action)) { // ----------------------------------------- // When used with CANVAS // ----------------------------------------- if (! $objcanvas->hasActions() && ($id || $ref)) { $object = new Product($db); $object->fetch($id, $ref); // For use with "pure canvas" (canvas that contains templates only) } $objcanvas->assign_values($action, $object->id, $ref); // Set value for templates $objcanvas->display_canvas($action); // Show template } else { // ----------------------------------------- // When used in standard mode // ----------------------------------------- if ($action == 'create' && ($user->rights->produit->creer || $user->rights->service->creer)) { //WYSIWYG Editor require_once(DOL_DOCUMENT_ROOT."/core/class/doleditor.class.php"); print '
'; print ''; print ''; print ''."\n"; if ($_GET["type"]==1) $title=$langs->trans("NewService"); else $title=$langs->trans("NewProduct"); print_fiche_titre($title); dol_htmloutput_mesg($mesg); print ''; print ''; print ''; // Label print ''; // On sell print ''; // To buy print ''; // Stock min level if ($_GET["type"] != 1 && $conf->stock->enabled) { print ''; } else { print ''; } // Description (used in invoice, propal...) print '"; // Nature if ($_GET["type"] != 1) { print ''; } // Duration if ($_GET["type"] == 1) { print ''; } if ($_GET["type"] != 1) // Le poids et le volume ne concerne que les produits et pas les services { // Weight print ''; // Length print ''; // Surface print ''; // Volume print ''; } // Customs code print ''; // Origin country print ''; // Other attributes $parameters=array('colspan' => ' colspan="2"'); $reshook=$hookmanager->executeHooks('formObjectOptions',$parameters,$object,$action); // Note that $action and $object may have been modified by hook if (empty($reshook) && ! empty($extrafields->attribute_label)) { foreach($extrafields->attribute_label as $key=>$label) { $value=(isset($_POST["options_".$key])?$_POST["options_".$key]:$object->array_options["options_".$key]); print ''."\n"; } } // Note (private, no output on invoices, propales...) print '"; print '
'.$langs->trans("Ref").''; if ($_error == 1) { print $langs->trans("RefAlreadyExists"); } print '
'.$langs->trans("Label").'
'.$langs->trans("Status").' ('.$langs->trans("Sell").')'; $statutarray=array('1' => $langs->trans("OnSell"), '0' => $langs->trans("NotOnSell")); print $form->selectarray('statut',$statutarray,$_POST["statut"]); print '
'.$langs->trans("Status").' ('.$langs->trans("Buy").')'; $statutarray=array('1' => $langs->trans("ProductStatusOnBuy"), '0' => $langs->trans("ProductStatusNotOnBuy")); print $form->selectarray('statut_buy',$statutarray,$_POST["statut_buy"]); print '
'.$langs->trans("StockLimit").''; print ''; print '
'.$langs->trans("Description").''; $doleditor = new DolEditor('desc', $_POST["desc"], '', 160, 'dolibarr_notes', '', false, true, $conf->global->FCKEDITOR_ENABLE_PRODUCTDESC, 4, 90); $doleditor->Create(); print "
'.$langs->trans("Nature").''; $statutarray=array('1' => $langs->trans("Finished"), '0' => $langs->trans("RowMaterial")); print $form->selectarray('finished',$statutarray,$_POST["finished"]); print '
'.$langs->trans("Duration").'  '; print ''.$langs->trans("Hour").' '; print ''.$langs->trans("Day").' '; print ''.$langs->trans("Week").' '; print ''.$langs->trans("Month").' '; print ''.$langs->trans("Year").' '; print '
'.$langs->trans("Weight").''; print ''; print $formproduct->select_measuring_units("weight_units","weight"); print '
'.$langs->trans("Length").''; print ''; print $formproduct->select_measuring_units("size_units","size"); print '
'.$langs->trans("Surface").''; print ''; print $formproduct->select_measuring_units("surface_units","surface"); print '
'.$langs->trans("Volume").''; print ''; print $formproduct->select_measuring_units("volume_units","volume"); print '
'.$langs->trans("CustomCode").'
'.$langs->trans("CountryOrigin").''; print $form->select_country($_POST["country_id"],'country_id'); if ($user->admin) print info_admin($langs->trans("YouCanChangeValuesForThisListFromDictionnarySetup"),1); print '
'.$label.''; print $extrafields->showInputField($key,$value); print '
'.$langs->trans("NoteNotVisibleOnBill").''; $doleditor = new DolEditor('note', $_POST["note"], '', 180, 'dolibarr_notes', '', false, true, $conf->global->FCKEDITOR_ENABLE_PRODUCTDESC, 8, 70); $doleditor->Create(); print "
'; print '
'; if ($conf->global->PRODUIT_MULTIPRICES) { // We do no show price array on create when multiprices enabled. // We must set them on prices tab. } else { print ''; // PRIX print ''; print ''; // MIN PRICE print ''; print ''; // VAT print ''; print '
'.$langs->trans("SellingPrice").''; print $form->select_PriceBaseType($object->price_base_type, "price_base_type"); print '
'.$langs->trans("MinPrice").''; print '
'.$langs->trans("VATRate").''; print $form->load_tva("tva_tx",-1,$mysoc,''); print '
'; print '
'; } print '
'; print '
'; } /* * Product card */ else if ($id || $ref) { $res=$object->fetch($id,$ref); if ($res < 0) { dol_print_error($db,$object->error); exit; } $res=$object->fetch_optionals($object->id,$extralabels); // Fiche en mode edition if ($action == 'edit' && ($user->rights->produit->creer || $user->rights->service->creer)) { //WYSIWYG Editor require_once(DOL_DOCUMENT_ROOT."/core/class/doleditor.class.php"); $type = $langs->trans('Product'); if ($object->isservice()) $type = $langs->trans('Service'); print_fiche_titre($langs->trans('Modify').' '.$type.' : '.$object->ref, ""); dol_htmloutput_errors($mesg); // Main official, simple, and not duplicated code print '
'."\n"; print ''; print ''; print ''; print ''; print ''; // Ref print ''; // Label print ''; // Status print ''; // To Buy print ''; // Description (used in invoice, propal...) print '"; print "\n"; // Nature if($object->type!=1) { print ''; } if ($object->isproduct() && $conf->stock->enabled) { print "".''; } else { print ''; } if ($object->isservice()) { // Duration print ''; } else { // Weight print ''; // Length print ''; // Surface print ''; // Volume print ''; } // Customs code print ''; // Origin country print ''; // Other attributes $parameters=array('colspan' => ' colspan="2"'); $reshook=$hookmanager->executeHooks('formObjectOptions',$parameters,$object,$action); // Note that $action and $object may have been modified by hook if (empty($reshook) && ! empty($extrafields->attribute_label)) { foreach($extrafields->attribute_label as $key=>$label) { $value=(isset($_POST["options_".$key])?$_POST["options_".$key]:$object->array_options["options_".$key]); print ''."\n"; } } // Note print '"; print '
'.$langs->trans("Ref").'
'.$langs->trans("Label").'
'.$langs->trans("Status").' ('.$langs->trans("Sell").')'; print ''; print '
'.$langs->trans("Status").' ('.$langs->trans("Buy").')'; print ''; print '
'.$langs->trans("Description").''; $doleditor = new DolEditor('desc', $object->description, '', 160, 'dolibarr_notes', '', false, true, $conf->global->FCKEDITOR_ENABLE_PRODUCTDESC, 4, 90); $doleditor->Create(); print "
'.$langs->trans("Nature").''; $statutarray=array('-1'=>' ', '1' => $langs->trans("Finished"), '0' => $langs->trans("RowMaterial")); print $form->selectarray('finished',$statutarray,$object->finished); print '
'.$langs->trans("StockLimit").''; print ''; print '
'.$langs->trans("Duration").''; print '  '; print 'duration_unit=='h'?' checked':'').'>'.$langs->trans("Hour"); print '  '; print 'duration_unit=='d'?' checked':'').'>'.$langs->trans("Day"); print '  '; print 'duration_unit=='w'?' checked':'').'>'.$langs->trans("Week"); print '  '; print 'duration_unit=='m'?' checked':'').'>'.$langs->trans("Month"); print '  '; print 'duration_unit=='y'?' checked':'').'>'.$langs->trans("Year"); print '
'.$langs->trans("Weight").''; print ' '; print $formproduct->select_measuring_units("weight_units", "weight", $object->weight_units); print '
'.$langs->trans("Length").''; print ' '; print $formproduct->select_measuring_units("size_units", "size", $object->length_units); print '
'.$langs->trans("Surface").''; print ' '; print $formproduct->select_measuring_units("surface_units", "surface", $object->surface_units); print '
'.$langs->trans("Volume").''; print ' '; print $formproduct->select_measuring_units("volume_units", "volume", $object->volume_units); print '
'.$langs->trans("CustomCode").'
'.$langs->trans("CountryOrigin").''; print $form->select_country($object->country_id,'country_id'); if ($user->admin) print info_admin($langs->trans("YouCanChangeValuesForThisListFromDictionnarySetup"),1); print '
'.$label.''; print $extrafields->showInputField($key,$value); print '
'.$langs->trans("NoteNotVisibleOnBill").''; $doleditor = new DolEditor('note', $object->note, '', 200, 'dolibarr_notes', '', false, true, $conf->global->FCKEDITOR_ENABLE_PRODUCTDESC, 8, 70); $doleditor->Create(); print "
'; print '
'; print '
    '; print '
'; print '
'; } // Fiche en mode visu else { dol_htmloutput_mesg($mesg); $head=product_prepare_head($object, $user); $titre=$langs->trans("CardProduct".$object->type); $picto=($object->type==1?'service':'product'); dol_fiche_head($head, 'card', $titre, 0, $picto); $showphoto=$object->is_photo_available($conf->product->multidir_output[$object->entity]); $showbarcode=$conf->barcode->enabled && $user->rights->barcode->lire; // En mode visu print ''; // Ref print ''; print ''; // Label print ''; $nblignes=8; if ($object->type!=1) $nblignes++; if ($object->isservice()) $nblignes++; else $nblignes+=4; if ($showbarcode) $nblignes+=2; // Photo if ($showphoto || $showbarcode) { print ''; } print ''; // Type if ($conf->produit->enabled && $conf->service->enabled) { // TODO change for compatibility with edit in place $typeformat='select;0:'.$langs->trans("Product").',1:'.$langs->trans("Service"); print ''; } if ($showbarcode) { // Barcode type print ''."\n"; // Barcode value print ''."\n"; } // Accountancy sell code print ''; // Accountancy buy code print ''; // Status (to sell) print ''; // Status (to buy) print ''; // Description print ''; // Nature if($object->type!=1) { print ''; } if ($object->isservice()) { // Duration print ''; } else { // Weight print '\n"; // Length print '\n"; // Surface print '\n"; // Volume print '\n"; } // Customs code print ''; // Origin country code print ''; // Other attributes $parameters=array('colspan' => ' colspan="'.(2+(($showphoto||$showbarcode)?1:0)).'"'); $reshook=$hookmanager->executeHooks('formObjectOptions',$parameters,$object,$action); // Note that $action and $object may have been modified by hook if (empty($reshook) && ! empty($extrafields->attribute_label)) { foreach($extrafields->attribute_label as $key=>$label) { $value=(isset($_POST["options_".$key])?$_POST["options_".$key]:$object->array_options["options_".$key]); print ''."\n"; } } // Note print ''; print "
'.$langs->trans("Ref").''; print $form->showrefnav($object,'ref','',1,'ref'); print '
'.$langs->trans("Label").''.$object->libelle.''; if ($showphoto) print $object->show_photos($conf->product->multidir_output[$object->entity],1,1,0,0,0,80); if ($showphoto && $showbarcode) print '

'; if ($showbarcode) print $form->showbarcode($object); print '
'.$form->editfieldkey("Type",'fk_product_type',$object->type,$object,$user->rights->produit->creer||$user->rights->service->creer,$typeformat).''; print $form->editfieldval("Type",'fk_product_type',$object->type,$object,$user->rights->produit->creer||$user->rights->service->creer,$typeformat); print '
'; print ''; print '
'; print $langs->trans("BarcodeType"); print ''; if (($action != 'editbarcodetype') && $user->rights->barcode->creer) print 'id.'">'.img_edit($langs->trans('Edit'),1).'
'; print '
'; if ($action == 'editbarcodetype') { require_once(DOL_DOCUMENT_ROOT."/core/class/html.formbarcode.class.php"); $formbarcode = new FormBarCode($db); $formbarcode->form_barcode_type($_SERVER['PHP_SELF'].'?id='.$object->id,$object->barcode_type,'barcodetype_id'); } else { $object->fetch_barcode(); print $object->barcode_type_label?$object->barcode_type_label:($object->barcode?'
'.$langs->trans("SetDefaultBarcodeType").'
':''); } print '
'; print ''; print '
'; print $langs->trans("BarcodeValue"); print ''; if (($action != 'editbarcode') && $user->rights->barcode->creer) print 'id.'">'.img_edit($langs->trans('Edit'),1).'
'; print '
'; if ($action == 'editbarcode') { print '
'; print ''; print ''; print ''; print ' '; } else { print $object->barcode; } print '
'.$form->editfieldkey("ProductAccountancySellCode",'accountancy_code_sell',$object->accountancy_code_sell,$object,$user->rights->produit->creer||$user->rights->service->creer).''; print $form->editfieldval("ProductAccountancySellCode",'accountancy_code_sell',$object->accountancy_code_sell,$object,$user->rights->produit->creer||$user->rights->service->creer); print '
'.$form->editfieldkey("ProductAccountancyBuyCode",'accountancy_code_buy',$object->accountancy_code_buy,$object,$user->rights->produit->creer||$user->rights->service->creer).''; print $form->editfieldval("ProductAccountancyBuyCode",'accountancy_code_buy',$object->accountancy_code_buy,$object,$user->rights->produit->creer||$user->rights->service->creer); print '
'.$langs->trans("Status").' ('.$langs->trans("Sell").')'; print $object->getLibStatut(2,0); print '
'.$langs->trans("Status").' ('.$langs->trans("Buy").')'; print $object->getLibStatut(2,1); print '
'.$langs->trans("Description").''.(dol_textishtml($object->description)?$object->description:dol_nl2br($object->description,1,true)).'
'.$langs->trans("Nature").''; print $object->getLibFinished(); print '
'.$langs->trans("Duration").''.$object->duration_value.' '; if ($object->duration_value > 1) { $dur=array("h"=>$langs->trans("Hours"),"d"=>$langs->trans("Days"),"w"=>$langs->trans("Weeks"),"m"=>$langs->trans("Months"),"y"=>$langs->trans("Years")); } else if ($object->duration_value > 0) { $dur=array("h"=>$langs->trans("Hour"),"d"=>$langs->trans("Day"),"w"=>$langs->trans("Week"),"m"=>$langs->trans("Month"),"y"=>$langs->trans("Year")); } print $langs->trans($dur[$object->duration_unit])." "; print '
'.$langs->trans("Weight").''; if ($object->weight != '') { print $object->weight." ".measuring_units_string($object->weight_units,"weight"); } else { print ' '; } print "
'.$langs->trans("Length").''; if ($object->length != '') { print $object->length." ".measuring_units_string($object->length_units,"size"); } else { print ' '; } print "
'.$langs->trans("Surface").''; if ($object->surface != '') { print $object->surface." ".measuring_units_string($object->surface_units,"surface"); } else { print ' '; } print "
'.$langs->trans("Volume").''; if ($object->volume != '') { print $object->volume." ".measuring_units_string($object->volume_units,"volume"); } else { print ' '; } print "
'.$langs->trans("CustomCode").''.$object->customcode.'
'.$langs->trans("CountryOrigin").''.getCountry($object->country_id,0,$db).'
'.$label.''; print $extrafields->showOutputField($key,$value); print '
'.$langs->trans("Note").''.(dol_textishtml($object->note)?$object->note:dol_nl2br($object->note,1,true)).'
\n"; dol_fiche_end(); } } else if ($action != 'create') { Header("Location: index.php"); exit; } } // Define confirmation messages $formquestionclone=array( 'text' => $langs->trans("ConfirmClone"), array('type' => 'text', 'name' => 'clone_ref','label' => $langs->trans("NewRefForClone"), 'value' => $langs->trans("CopyOf").' '.$object->ref, 'size'=>24), array('type' => 'checkbox', 'name' => 'clone_content','label' => $langs->trans("CloneContentProduct"), 'value' => 1), array('type' => 'checkbox', 'name' => 'clone_prices', 'label' => $langs->trans("ClonePricesProduct").' ('.$langs->trans("FeatureNotYetAvailable").')', 'value' => 0, 'disabled' => true) ); // Confirm delete product if ($action == 'delete' && empty($conf->use_javascript_ajax)) { print $form->formconfirm("fiche.php?id=".$object->id,$langs->trans("DeleteProduct"),$langs->trans("ConfirmDeleteProduct"),"confirm_delete",'',0,"action-delete"); } // Clone confirmation if ($action == 'clone' && empty($conf->use_javascript_ajax)) { print $form->formconfirm($_SERVER["PHP_SELF"].'?id='.$object->id,$langs->trans('CloneProduct'),$langs->trans('ConfirmCloneProduct',$object->ref),'confirm_clone',$formquestionclone,'yes','action-clone',230,600); } /* ************************************************************************** */ /* */ /* Barre d'action */ /* */ /* ************************************************************************** */ print "\n".'
'."\n"; if ($action == '' || $action == 'view') { if ($user->rights->produit->creer || $user->rights->service->creer) { if ($object->no_button_edit <> 1) print 'id.'">'.$langs->trans("Modify").''; if ($object->no_button_copy <> 1) { if ($conf->use_javascript_ajax) { print ''.$langs->trans('ToClone').''."\n"; print $form->formconfirm($_SERVER["PHP_SELF"].'?id='.$object->id,$langs->trans('CloneProduct'),$langs->trans('ConfirmCloneProduct',$object->ref),'confirm_clone',$formquestionclone,'yes','action-clone',230,600); } else { print 'id.'">'.$langs->trans("ToClone").''; } } } $object_is_used = $object->isObjectUsed($object->id); if (($object->type == 0 && $user->rights->produit->supprimer) || ($object->type == 1 && $user->rights->service->supprimer)) { if (! $object_is_used && $object->no_button_delete <> 1) { if ($conf->use_javascript_ajax) { print ''.$langs->trans('Delete').''."\n"; print $form->formconfirm("fiche.php?id=".$object->id,$langs->trans("DeleteProduct"),$langs->trans("ConfirmDeleteProduct"),"confirm_delete",'',0,"action-delete"); } else { print 'id.'">'.$langs->trans("Delete").''; } } else { print ''.$langs->trans("Delete").''; } } else { print ''.$langs->trans("Delete").''; } } print "\n

\n"; /* * All the "Add to" areas */ if ($id && ($action == '' || $action == 'view') && $object->status) { print ''; // Propals if($conf->propal->enabled && $user->rights->propale->creer) { $propal = new Propal($db); $langs->load("propal"); print ''; if ($user->rights->societe->client->voir) { print ''; } else { print ''; } print ''; // Liste de "Mes propals" print 'rights->societe->client->voir?' width="50%"':'').' valign="top">'; $sql = "SELECT s.nom, s.rowid as socid, p.rowid as propalid, p.ref, p.datep as dp"; $sql.= " FROM ".MAIN_DB_PREFIX."societe as s, ".MAIN_DB_PREFIX."propal as p"; $sql.= " WHERE p.fk_soc = s.rowid"; $sql.= " AND p.entity = ".$conf->entity; $sql.= " AND p.fk_statut = 0"; $sql.= " AND p.fk_user_author = ".$user->id; $sql.= " ORDER BY p.datec DESC, p.tms DESC"; $result=$db->query($sql); if ($result) { $var=true; $num = $db->num_rows($result); print '
'; print $langs->trans("AddToMyProposals") . ''; print $langs->trans("AddToOtherProposals").' 
'; if ($num) { $i = 0; while ($i < $num) { $objp = $db->fetch_object($result); $var=!$var; print ''; print ''; print ''; print ""; print '\n"; print "\n"; print "\n"; print ''; print ''; print ''; $i++; } } else { print ""; } print "
'; print "propalid."\">".img_object($langs->trans("ShowPropal"),"propal")." ".$objp->ref."socid."\">".dol_trunc($objp->nom,18)."".dol_print_date($objp->dp,"%d %b")."'; print ''.$langs->trans("ReductionShort"); print '%'; print " ".$object->stock_proposition; print ''; print ''; print '
"; print $langs->trans("NoOpenedPropals"); print "
"; $db->free($result); } print ''; if ($user->rights->societe->client->voir) { // Liste de "Other propals" print ''; $var=true; $otherprop = $propal->liste_array(1,1,1); print '
'; print ''; print ''; if (is_array($otherprop) && count($otherprop)) { $var=!$var; print ''; print ''; } else { print "'; } print '
'; print ''; print $langs->trans("OtherPropals").''; print $form->selectarray("propalid", $otherprop); print '
'.$langs->trans("Qty"); print ''.$langs->trans("ReductionShort"); print '%'; print ''; print ''; print '
"; print $langs->trans("NoOtherOpenedPropals"); print '
'; print '
'; print ''; } print ''; } // Commande if($conf->commande->enabled && $user->rights->commande->creer) { $commande = new Commande($db); $langs->load("orders"); print ''; print $langs->trans("AddToMyOrders").''; if ($user->rights->societe->client->voir) { print ''; print $langs->trans("AddToOtherOrders").''; } else { print ' '; } print ''; // Liste de "Mes commandes" print 'rights->societe->client->voir?' width="50%"':'').' valign="top">'; $sql = "SELECT s.nom, s.rowid as socid, c.rowid as commandeid, c.ref, c.date_commande as dc"; $sql.= " FROM ".MAIN_DB_PREFIX."societe as s, ".MAIN_DB_PREFIX."commande as c"; $sql.= " WHERE c.fk_soc = s.rowid"; $sql.= " AND c.entity = ".$conf->entity; $sql.= " AND c.fk_statut = 0"; $sql.= " AND c.fk_user_author = ".$user->id; $sql.= " ORDER BY c.date_creation DESC"; $result=$db->query($sql); if ($result) { $num = $db->num_rows($result); $var=true; print ''; if ($num) { $i = 0; while ($i < $num) { $objc = $db->fetch_object($result); $var=!$var; print ''; print ''; print ''; print ""; print '\n"; print "\n"; print "\n"; print ''; print ''; print ''; $i++; } } else { print "'; } print "
'; print "commandeid."\">".img_object($langs->trans("ShowOrder"),"order")." ".$objc->ref."socid."\">".dol_trunc($objc->nom,18)."".dol_print_date($db->jdate($objc->dc),"%d %b")."'; print ''.$langs->trans("ReductionShort"); print '%'; print " ".$object->stock_proposition; print ''; print ''; print '
"; print $langs->trans("NoOpenedOrders"); print '
"; $db->free($result); } print ''; if ($user->rights->societe->client->voir) { // Liste de "Other orders" print ''; $var=true; $othercom = $commande->liste_array(1, $user); print '
'; print ''; print ''; if (is_array($othercom) && count($othercom)) { $var=!$var; print ''; print ''; } else { print "'; } print '
'; print ''; print $langs->trans("OtherOrders").''; print $form->selectarray("commandeid", $othercom); print '
'.$langs->trans("Qty"); print ''.$langs->trans("ReductionShort"); print '%'; print ''; print ''; print '
"; print $langs->trans("NoOtherOpenedOrders"); print '
'; print '
'; print ''; } print ''; } // Factures if ($conf->facture->enabled && $user->rights->facture->creer) { print ''; print $langs->trans("AddToMyBills").''; if ($user->rights->societe->client->voir) { print ''; print $langs->trans("AddToOtherBills").''; } else { print ' '; } print ''; // Liste de Mes factures print 'rights->societe->client->voir?' width="50%"':'').' valign="top">'; $sql = "SELECT s.nom, s.rowid as socid, f.rowid as factureid, f.facnumber, f.datef as df"; $sql.= " FROM ".MAIN_DB_PREFIX."societe as s, ".MAIN_DB_PREFIX."facture as f"; $sql.= " WHERE f.fk_soc = s.rowid"; $sql.= " AND f.entity = ".$conf->entity; $sql.= " AND f.fk_statut = 0"; $sql.= " AND f.fk_user_author = ".$user->id; $sql.= " ORDER BY f.datec DESC, f.rowid DESC"; $result=$db->query($sql); if ($result) { $num = $db->num_rows($result); $var=true; print ''; if ($num) { $i = 0; while ($i < $num) { $objp = $db->fetch_object($result); $var=!$var; print ''; print ''; print ''; print ""; print "\n"; print "\n"; print "\n"; print ''; print ''; print ''; $i++; } } else { print "'; } print "
"; print "factureid."\">".img_object($langs->trans("ShowBills"),"bill")." ".$objp->facnumber."socid."\">".dol_trunc($objp->nom,18)."".dol_print_date($db->jdate($objp->df),"%d %b")."'; print ''.$langs->trans("ReductionShort"); print '%'; print ''; print ''; print '
"; print $langs->trans("NoDraftBills"); print '
"; $db->free($result); } else { dol_print_error($db); } print ''; if ($user->rights->societe->client->voir) { $facture = new Facture($db); print ''; // Liste de Autres factures $var=true; $sql = "SELECT s.nom, s.rowid as socid, f.rowid as factureid, f.facnumber, f.datef as df"; $sql.= " FROM ".MAIN_DB_PREFIX."societe as s, ".MAIN_DB_PREFIX."facture as f"; $sql.= " WHERE f.fk_soc = s.rowid"; $sql.= " AND f.entity = ".$conf->entity; $sql.= " AND f.fk_statut = 0"; $sql.= " AND f.fk_user_author <> ".$user->id; $sql.= " ORDER BY f.datec DESC, f.rowid DESC"; $result=$db->query($sql); if ($result) { $num = $db->num_rows($result); $var=true; print ''; if ($num) { $i = 0; while ($i < $num) { $objp = $db->fetch_object($result); $var=!$var; print ''; print ''; print ''; print ""; print "\n"; print "\n"; print ""; print ''; print ''; print ''; $i++; } } else { print "'; } print "
factureid."\">$objp->facnumbersocid."\">".dol_trunc($objp->nom,24)."".$langs->trans("Qty"); print "'; print ''.$langs->trans("ReductionShort"); print '%'; print ''; print ''; print '
"; print $langs->trans("NoOtherDraftBills"); print '
"; $db->free($result); } else { dol_print_error($db); } print ''; } print ''; } print ''; print '
'; } $db->close(); llxFooter(); ?>