27require
'../main.inc.php';
28require_once DOL_DOCUMENT_ROOT.
'/fourn/class/fournisseur.commande.class.php';
29require_once DOL_DOCUMENT_ROOT.
'/fourn/class/fournisseur.facture.class.php';
30require_once DOL_DOCUMENT_ROOT.
'/categories/class/categorie.class.php';
32$langs->loadLangs(array(
"suppliers",
"orders",
"companies"));
37 $socid = $user->socid;
48$companystatic =
new Societe($db);
50llxHeader(
"", $langs->trans(
"SuppliersArea"));
57print
'<div class="fichecenter"><div class="fichethirdleft">';
61$sql =
"SELECT count(cf.rowid), cf.fk_statut";
62$sql .=
" FROM ".MAIN_DB_PREFIX.
"commande_fournisseur as cf,";
63$sql .=
" ".MAIN_DB_PREFIX.
"societe as s";
64if (!$user->hasRight(
"societe",
"client",
"voir") && !$socid) {
65 $sql .=
" LEFT JOIN ".MAIN_DB_PREFIX.
"societe_commerciaux as sc ON s.rowid = sc.fk_soc";
67$sql .=
" WHERE cf.fk_soc = s.rowid ";
68if (!$user->hasRight(
"societe",
"client",
"voir") && !$socid) {
69 $sql .=
" AND sc.fk_user = ".((int) $user->id);
71$sql .=
" AND cf.entity = ".$conf->entity;
72$sql .=
" GROUP BY cf.fk_statut";
74$resql = $db->query($sql);
76 $num = $db->num_rows($resql);
79 print
'<table class="noborder centpercent">';
80 print
'<tr class="liste_titre"><td>'.$langs->trans(
"Orders").
'</td><td class="center">'.$langs->trans(
"Nb").
'</td><td> </td>';
84 $row = $db->fetch_row($resql);
86 print
'<tr class="oddeven">';
87 print
'<td>'.$commandestatic->LibStatut($row[1]).
'</td>';
88 print
'<td class="center">'.$row[0].
'</td>';
89 print
'<td class="center"><a href="'.DOL_URL_ROOT.
'/fourn/commande/list.php?statut='.$row[1].
'">'.$commandestatic->LibStatut($row[1], 3).
'</a></td>';
103if (isModEnabled(
"supplier_order")) {
104 $langs->load(
"orders");
106 $sql =
"SELECT cf.rowid, cf.ref, cf.total_ttc,";
107 $sql .=
" s.nom as name, s.rowid as socid";
108 $sql .=
" FROM ".MAIN_DB_PREFIX.
"commande_fournisseur as cf";
109 $sql .=
", ".MAIN_DB_PREFIX.
"societe as s";
110 if (!$user->hasRight(
"societe",
"client",
"voir") && !$socid) {
111 $sql .=
" LEFT JOIN ".MAIN_DB_PREFIX.
"societe_commerciaux as sc ON s.rowid = sc.fk_soc";
113 $sql .=
" WHERE cf.fk_soc = s.rowid";
114 if (!$user->hasRight(
"societe",
"client",
"voir") && !$socid) {
115 $sql .=
" AND sc.fk_user = ".((int) $user->id);
117 $sql .=
" AND cf.entity = ".$conf->entity;
118 $sql .=
" AND cf.fk_statut = 0";
120 $sql .=
" AND cf.fk_soc = ".((int) $socid);
123 $resql = $db->query($sql);
126 $num = $db->num_rows($resql);
128 print
'<table class="noborder centpercent">';
129 print
'<tr class="liste_titre">';
130 print
'<td colspan="3">'.$langs->trans(
"DraftOrders").
'<span class="badge marginleftonlyshort">'.$num.
'</span></td></tr>';
134 $obj = $db->fetch_object($resql);
136 print
'<tr class="oddeven"><td class="nowrap">';
137 $commandestatic->id = $obj->rowid;
138 $commandestatic->ref = $obj->ref;
139 print $commandestatic->getNomUrl(1,
'', 16);
141 print
'<td class="nowrap">';
142 $companystatic->id = $obj->socid;
143 $companystatic->name = $obj->name;
144 $companystatic->client = 0;
145 print $companystatic->getNomUrl(1,
'', 16);
147 print
'<td class="right nowrap">'.price($obj->total_ttc).
'</td></tr>';
149 $total += $obj->total_ttc;
152 print
'<tr class="liste_total"><td>'.$langs->trans(
"Total").
'</td><td colspan="2" class="right">'.
price($total).
"</td></tr>";
161if (isModEnabled(
"supplier_invoice") && ($user->hasRight(
'fournisseur',
'facture',
'lire') || $user->hasRight(
'supplier_invoice',
'read'))) {
162 $sql =
"SELECT ff.ref_supplier, ff.rowid, ff.total_ttc, ff.type";
163 $sql .=
", s.nom as name, s.rowid as socid";
164 $sql .=
" FROM ".MAIN_DB_PREFIX.
"facture_fourn as ff";
165 $sql .=
", ".MAIN_DB_PREFIX.
"societe as s";
166 if (!$user->hasRight(
"societe",
"client",
"voir") && !$socid) {
167 $sql .=
" LEFT JOIN ".MAIN_DB_PREFIX.
"societe_commerciaux as sc ON s.rowid = sc.fk_soc";
169 $sql .=
" WHERE s.rowid = ff.fk_soc";
170 if (!$user->hasRight(
"societe",
"client",
"voir") && !$socid) {
171 $sql .=
" AND sc.fk_user = ".((int) $user->id);
173 $sql .=
" AND ff.entity = ".$conf->entity;
174 $sql .=
" AND ff.fk_statut = 0";
176 $sql .=
" AND f.fk_soc = ".((int) $socid);
179 $resql = $db->query($sql);
182 $num = $db->num_rows($resql);
184 print
'<table class="noborder centpercent">';
185 print
'<tr class="liste_titre">';
186 print
'<td colspan="3">'.$langs->trans(
"DraftBills").
'<span class="badge marginleftonlyshort">'.$num.
'</span></td></tr>';
190 while ($i < $num && $i < 20) {
191 $obj = $db->fetch_object($resql);
193 print
'<tr class="oddeven"><td class="nowrap">';
194 $facturestatic->ref = $obj->ref;
195 $facturestatic->id = $obj->rowid;
196 $facturestatic->type = $obj->type;
197 print $facturestatic->getNomUrl(1,
'');
199 print
'<td class="nowrap">';
200 $companystatic->id = $obj->socid;
201 $companystatic->name = $obj->name;
202 $companystatic->client = 0;
203 print $companystatic->getNomUrl(1,
'', 16);
205 print
'<td class="right">'.price($obj->total_ttc).
'</td>';
207 $tot_ttc += $obj->total_ttc;
211 print
'<tr class="liste_total"><td class="left">'.$langs->trans(
"Total").
'</td>';
212 print
'<td colspan="2" class="right">'.price($tot_ttc).
'</td>';
225print
'</div><div class="fichetwothirdright">';
232$sql =
"SELECT s.rowid as socid, s.nom as name, s.town, s.datec, s.tms, s.prefix_comm, s.code_fournisseur";
234 $sql .=
", spe.accountancy_code_supplier as code_compta_fournisseur";
236 $sql .=
", s.code_compta_fournisseur";
238$sql .=
", st.libelle as stcomm";
239$sql .=
" FROM ".MAIN_DB_PREFIX.
"societe as s";
241 $sql .=
" LEFT JOIN " . MAIN_DB_PREFIX .
"societe_perentity as spe ON spe.fk_soc = s.rowid AND spe.entity = " . ((int) $conf->entity);
243$sql .=
", ".MAIN_DB_PREFIX.
"c_stcomm as st";
244if (!$user->hasRight(
"societe",
"client",
"voir") && !$socid) {
245 $sql .=
", ".MAIN_DB_PREFIX.
"societe_commerciaux as sc";
247$sql .=
" WHERE s.fk_stcomm = st.id";
248$sql .=
" AND s.fournisseur = 1";
249$sql .=
" AND s.entity IN (".getEntity(
'societe').
")";
250if (!$user->hasRight(
"societe",
"client",
"voir") && !$socid) {
251 $sql .=
" AND s.rowid = sc.fk_soc AND sc.fk_user = ".((int) $user->id);
254 $sql .=
" AND s.rowid = ".((int) $socid);
256$sql .=
" ORDER BY s.tms DESC";
257$sql .= $db->plimit($max, 0);
259$resql = $db->query($sql);
261 $langs->load(
"boxes");
262 $num = $db->num_rows($resql);
265 print
'<table class="noborder centpercent">';
266 print
'<tr class="liste_titre">';
267 print
'<td colspan="2">'.$langs->trans(
"BoxTitleLastSuppliers", min($max, $num)).
"</td>\n";
268 print
'<td class="right">'.$langs->trans(
"DateModification").
"</td>\n";
271 while ($obj = $db->fetch_object($resql)) {
272 print
'<tr class="oddeven">';
273 print
'<td><a href="card.php?socid='.$obj->socid.
'">'.
img_object($langs->trans(
"ShowSupplier"),
"company").
'</a>';
274 print
" <a href=\"card.php?socid=".$obj->socid.
"\">".$obj->name.
"</a></td>\n";
275 print
'<td class="left">'.$obj->code_fournisseur.
' </td>';
276 print
'<td class="right">'.dol_print_date($db->jdate($obj->tms),
'day').
'</td>';
290$companystatic->LoadSupplierCateg();
293if (count($companystatic->SupplierCategories)) {
296 print
'<table class="liste centpercent">';
297 print
'<tr class="liste_titre"><td colspan="2">';
298 print $langs->trans(
"Category");
299 print
"</td></tr>\n";
301 foreach ($companystatic->SupplierCategories as $rowid => $label) {
302 print
'<tr class="oddeven">'.
"\n";
304 $categstatic->id = $rowid;
305 $categstatic->ref = $label;
306 $categstatic->label = $label;
307 print $categstatic->getNomUrl(1);
if(!defined('NOREQUIRESOC')) if(!defined( 'NOREQUIRETRAN')) if(!defined('NOTOKENRENEWAL')) if(!defined( 'NOREQUIREMENU')) if(!defined('NOREQUIREHTML')) if(!defined( 'NOREQUIREAJAX')) llxHeader()
Empty header.
Class to manage categories.
Class to manage predefined suppliers products.
Class to manage suppliers invoices.
Class to manage third parties objects (customers, suppliers, prospects...)
load_fiche_titre($title, $morehtmlright='', $picto='generic', $pictoisfullpath=0, $id='', $morecssontable='', $morehtmlcenter='')
Load a title with picto.
img_object($titlealt, $picto, $moreatt='', $pictoisfullpath=0, $srconly=0, $notitle=0)
Show a picto called object_picto (generic function)
GETPOSTINT($paramname, $method=0)
Return the value of a $_GET or $_POST supervariable, converted into integer.
price($amount, $form=0, $outlangs='', $trunc=1, $rounding=-1, $forcerounding=-1, $currency_code='')
Function to format a value into an amount for visual output Function used into PDF and HTML pages.
dol_print_error($db=null, $error='', $errors=null)
Displays error message system with all the information to facilitate the diagnosis and the escalation...
getDolGlobalString($key, $default='')
Return dolibarr global constant string value.
restrictedArea(User $user, $features, $object=0, $tableandshare='', $feature2='', $dbt_keyfield='fk_soc', $dbt_select='rowid', $isdraft=0, $mode=0)
Check permissions of a user to show a page and an object.