dolibarr  17.0.4
objectline_view.tpl.php
1 <?php
2 /* Copyright (C) 2010-2013 Regis Houssin <regis.houssin@inodbox.com>
3  * Copyright (C) 2010-2011 Laurent Destailleur <eldy@users.sourceforge.net>
4  * Copyright (C) 2012-2013 Christophe Battarel <christophe.battarel@altairis.fr>
5  * Copyright (C) 2012 Cédric Salvador <csalvador@gpcsolutions.fr>
6  * Copyright (C) 2012-2014 Raphaël Doursenaud <rdoursenaud@gpcsolutions.fr>
7  * Copyright (C) 2013 Florian Henry <florian.henry@open-concept.pro>
8  * Copyright (C) 2017 Juanjo Menent <jmenent@2byte.es>
9  *
10  * This program is free software; you can redistribute it and/or modify
11  * it under the terms of the GNU General Public License as published by
12  * the Free Software Foundation; either version 3 of the License, or
13  * (at your option) any later version.
14  *
15  * This program is distributed in the hope that it will be useful,
16  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18  * GNU General Public License for more details.
19  *
20  * You should have received a copy of the GNU General Public License
21  * along with this program. If not, see <https://www.gnu.org/licenses/>.
22  *
23  * Need to have following variables defined:
24  * $object (invoice, order, ...)
25  * $conf
26  * $langs
27  * $forceall (0 by default, 1 for supplier invoices/orders)
28  * $element (used to test $user->rights->$element->creer)
29  * $permtoedit (used to replace test $user->rights->$element->creer)
30  * $inputalsopricewithtax (0 by default, 1 to also show column with unit price including tax)
31  * $object_rights->creer initialized from = $object->getRights()
32  * $disableedit, $disablemove, $disableremove
33  *
34  * $type, $text, $description, $line
35  */
36 
37 require_once DOL_DOCUMENT_ROOT.'/workstation/class/workstation.class.php';
38 
39 // Protection to avoid direct call of template
40 if (empty($object) || !is_object($object)) {
41  print "Error, template page can't be called as URL";
42  exit;
43 }
44 
45 global $filtertype;
46 if (empty($filtertype)) $filtertype = 0;
47 
48 
49 global $forceall, $senderissupplier, $inputalsopricewithtax, $outputalsopricetotalwithtax, $langs;
50 
51 if (empty($dateSelector)) {
52  $dateSelector = 0;
53 }
54 if (empty($forceall)) {
55  $forceall = 0;
56 }
57 if (empty($senderissupplier)) {
58  $senderissupplier = 0;
59 }
60 if (empty($inputalsopricewithtax)) {
61  $inputalsopricewithtax = 0;
62 }
63 if (empty($outputalsopricetotalwithtax)) {
64  $outputalsopricetotalwithtax = 0;
65 }
66 
67 // add html5 elements
68 if ($filtertype == 1) $domData = ' data-element="'.$line->element.'service"';
69 else $domData = ' data-element="'.$line->element.'"';
70 
71 $domData .= ' data-id="'.$line->id.'"';
72 $domData .= ' data-qty="'.$line->qty.'"';
73 $domData .= ' data-product_type="'.$line->product_type.'"';
74 
75 // Lines for extrafield
76 $objectline = new BOMLine($object->db);
77 
78 $coldisplay = 0;
79 print "<!-- BEGIN PHP TEMPLATE objectline_view.tpl.php -->\n";
80 print '<tr id="row-'.$line->id.'" class="drag drop oddeven" '.$domData.' >';
81 
82 // Line nb
83 if (!empty($conf->global->MAIN_VIEW_LINE_NUMBER)) {
84  print '<td class="linecolnum center">'.($i + 1).'</td>';
85  $coldisplay++;
86 }
87 
88 // Product
89 print '<td class="linecoldescription minwidth300imp">';
90 print '<div id="line_'.$line->id.'"></div>';
91 $coldisplay++;
92 $tmpproduct = new Product($object->db);
93 $tmpproduct->fetch($line->fk_product);
94 $tmpbom = new BOM($object->db);
95 $res = $tmpbom->fetch($line->fk_bom_child);
96 if ($tmpbom->id > 0) {
97  print $tmpproduct->getNomUrl(1);
98  print ' '.$langs->trans("or").' ';
99  print $tmpbom->getNomUrl(1);
100  print ' <a class="collapse_bom" id="collapse-'.$line->id.'" href="#">';
101  print (empty($conf->global->BOM_SHOW_ALL_BOM_BY_DEFAULT) ? img_picto('', 'folder') : img_picto('', 'folder-open'));
102  print '</a>';
103 } else {
104  print $tmpproduct->getNomUrl(1);
105  print ' - '.$tmpproduct->label;
106 }
107 
108 // Line extrafield
109 if (!empty($extrafields)) {
110  $temps = $line->showOptionals($extrafields, 'view', array(), '', '', 1, 'line');
111  if (!empty($temps)) {
112  print '<div style="padding-top: 10px" id="extrafield_lines_area_'.$line->id.'" name="extrafield_lines_area_'.$line->id.'">';
113  print $temps;
114  print '</div>';
115  }
116 }
117 
118 print '</td>';
119 
120 // Qty
121 print '<td class="linecolqty nowrap right">';
122 $coldisplay++;
123 echo price($line->qty, 0, '', 0, 0); // Yes, it is a quantity, not a price, but we just want the formating role of function price
124 print '</td>';
125 
126 if ($filtertype != 1) {
127  if (!empty($conf->global->PRODUCT_USE_UNITS)) {
128  print '<td class="linecoluseunit nowrap left">';
129  $label = $tmpproduct->getLabelOfUnit('long');
130  if ($label !== '') {
131  print $langs->trans($label);
132  }
133  print '</td>';
134  }
135 
136  print '<td class="linecolqtyfrozen nowrap right">';
137  $coldisplay++;
138  echo $line->qty_frozen ? yn($line->qty_frozen) : '';
139  print '</td>';
140  print '<td class="linecoldisablestockchange nowrap right">';
141  $coldisplay++;
142  echo $line->disable_stock_change ? yn($line->disable_stock_change) : ''; // Yes, it is a quantity, not a price, but we just want the formating role of function price
143  print '</td>';
144 
145  print '<td class="linecolefficiency nowrap right">';
146  $coldisplay++;
147  echo $line->efficiency;
148  print '</td>';
149 } else {
150  // Unit
151  print '<td class="linecolunit nowrap right">';
152  $coldisplay++;
153 
154  if (!empty($line->fk_unit)) {
155  require_once DOL_DOCUMENT_ROOT.'/core/class/cunits.class.php';
156  $unit = new CUnits($this->db);
157  $unit->fetch($line->fk_unit);
158  print (isset($unit->label) ? "&nbsp;".$langs->trans(ucwords($unit->label))."&nbsp;" : '');
159  }
160 
161  print '</td>';
162 
163  // Work station
164  if (isModEnabled('workstation')) {
165  $workstation = new Workstation($object->db);
166  $res = $workstation->fetch($tmpproduct->fk_default_workstation);
167 
168  print '<td class="linecolunit nowrap right">';
169  $coldisplay++;
170  if ($res > 0) echo $workstation->getNomUrl();
171  print '</td>';
172  }
173 }
174 
175 // Cost
176 $total_cost = 0;
177 $tmpbom->calculateCosts();
178 print '<td id="costline_'.$line->id.'" class="linecolcost nowrap right">';
179 $coldisplay++;
180 if (!empty($line->fk_bom_child)) {
181  echo '<span class="amount">'.price($tmpbom->total_cost * $line->qty).'</span>';
182 } else {
183  echo '<span class="amount">'.price($line->total_cost).'</span>';
184 }
185 print '</td>';
186 
187 if ($this->status == 0 && ($object_rights->write) && $action != 'selectlines') {
188  print '<td class="linecoledit center">';
189  $coldisplay++;
190  if (($line->info_bits & 2) == 2 || !empty($disableedit)) {
191  } else {
192  print '<a class="editfielda reposition" href="'.$_SERVER["PHP_SELF"].'?id='.$this->id.'&action=editline&token='.newToken().'&lineid='.$line->id.'">'.img_edit().'</a>';
193  }
194  print '</td>';
195 
196  print '<td class="linecoldelete center">';
197  $coldisplay++;
198  if (($line->fk_prev_id == null) && empty($disableremove)) {
199  //La suppression n'est autorisée que si il n'y a pas de ligne dans une précédente situation
200  print '<a class="reposition" href="'.$_SERVER["PHP_SELF"].'?id='.$this->id.'&action=deleteline&token='.newToken().'&lineid='.$line->id.'">';
201  print img_delete();
202  print '</a>';
203  }
204  print '</td>';
205 
206  if ($num > 1 && $conf->browser->layout != 'phone' && empty($disablemove)) {
207  print '<td class="linecolmove tdlineupdown center">';
208  $coldisplay++;
209  if ($i > 0) {
210  print '<a class="lineupdown" href="'.$_SERVER["PHP_SELF"].'?id='.$this->id.'&action=up&token='.newToken().'&rowid='.$line->id.'">';
211  echo img_up('default', 0, 'imgupforline');
212  print '</a>';
213  }
214  if ($i < $num - 1) {
215  print '<a class="lineupdown" href="'.$_SERVER["PHP_SELF"].'?id='.$this->id.'&action=down&token='.newToken().'&rowid='.$line->id.'">';
216  echo img_down('default', 0, 'imgdownforline');
217  print '</a>';
218  }
219  print '</td>';
220  } else {
221  print '<td '.(($conf->browser->layout != 'phone' && empty($disablemove)) ? ' class="linecolmove tdlineupdown center"' : ' class="linecolmove center"').'></td>';
222  $coldisplay++;
223  }
224 } else {
225  print '<td colspan="3"></td>';
226  $coldisplay = $coldisplay + 3;
227 }
228 
229 if ($action == 'selectlines') {
230  print '<td class="linecolcheck center">';
231  print '<input type="checkbox" class="linecheckbox" name="line_checkbox['.($i + 1).']" value="'.$line->id.'" >';
232  print '</td>';
233 }
234 
235 print '</tr>';
236 
237 // Select of all the sub-BOM lines
238 // From this pont to the end of the file, we only take care of sub-BOM lines
239 $sql = 'SELECT rowid, fk_bom_child, fk_product, qty FROM '.MAIN_DB_PREFIX.'bom_bomline AS bl';
240 $sql.= ' WHERE fk_bom ='. (int) $tmpbom->id;
241 $resql = $object->db->query($sql);
242 
243 if ($resql) {
244  // Loop on all the sub-BOM lines if they exist
245  while ($obj = $object->db->fetch_object($resql)) {
246  $sub_bom_product = new Product($object->db);
247  $sub_bom_product->fetch($obj->fk_product);
248 
249  $sub_bom = new BOM($object->db);
250  if (!empty($obj->fk_bom_child)) {
251  $sub_bom->fetch($obj->fk_bom_child);
252  }
253 
254  $sub_bom_line = new BOMLine($object->db);
255  $sub_bom_line->fetch($obj->rowid);
256 
257  //If hidden conf is set, we show directly all the sub-BOM lines
258  if (empty($conf->global->BOM_SHOW_ALL_BOM_BY_DEFAULT)) {
259  print '<tr style="display:none" class="sub_bom_lines" parentid="'.$line->id.'">';
260  } else {
261  print '<tr class="sub_bom_lines" parentid="'.$line->id.'">';
262  }
263 
264  // Product OR BOM
265  print '<td style="padding-left: 5%" id="sub_bom_product_'.$sub_bom_line->id.'">';
266  if (!empty($obj->fk_bom_child)) {
267  print $sub_bom_product->getNomUrl(1);
268  print ' '.$langs->trans('or').' ';
269  print $sub_bom->getNomUrl(1);
270  } else {
271  print $sub_bom_product->getNomUrl(1);
272  print '</td>';
273  }
274 
275  // Qty
276  $label = $sub_bom_product->getLabelOfUnit('long');
277  if ($sub_bom_line->qty_frozen > 0) {
278  print '<td class="linecolqty nowrap right" id="sub_bom_qty_'.$sub_bom_line->id.'">'.price($sub_bom_line->qty, 0, '', 0, 0).'</td>';
279  if (!empty($conf->global->PRODUCT_USE_UNITS)) {
280  print '<td class="linecoluseunit nowrap left">';
281  if ($label !== '') print $langs->trans($label);
282  print '</td>';
283  }
284  print '<td class="linecolqtyfrozen nowrap right" id="sub_bom_qty_frozen_'.$sub_bom_line->id.'">'.$langs->trans('Yes').'</td>';
285  } else {
286  print '<td class="linecolqty nowrap right" id="sub_bom_qty_'.$sub_bom_line->id.'">'.price($sub_bom_line->qty * $line->qty, 0, '', 0, 0).'</td>';
287  if (!empty($conf->global->PRODUCT_USE_UNITS)) {
288  print '<td class="linecoluseunit nowrap left">';
289  if ($label !== '') print $langs->trans($label);
290  print '</td>';
291  }
292 
293  print '<td class="linecolqtyfrozen nowrap right" id="sub_bom_qty_frozen_'.$sub_bom_line->id.'">&nbsp;</td>';
294  }
295 
296  // Disable stock change
297  if ($sub_bom_line->disable_stock_change > 0) {
298  print '<td class="linecoldisablestockchange nowrap right" id="sub_bom_stock_change_'.$sub_bom_line->id.'">'.$sub_bom_line->disable_stock_change.'</td>';
299  } else {
300  print '<td class="linecoldisablestockchange nowrap right" id="sub_bom_stock_change_'.$sub_bom_line->id.'">&nbsp;</td>';
301  }
302 
303  // Efficiency
304  print '<td class="linecolefficiency nowrap right" id="sub_bom_efficiency_'.$sub_bom_line->id.'">'.$sub_bom_line->efficiency.'</td>';
305 
306  // Cost
307  if (!empty($sub_bom->id)) {
308  $sub_bom->calculateCosts();
309  print '<td class="linecolcost nowrap right" id="sub_bom_cost_'.$sub_bom_line->id.'"><span class="amount">'.price(price2num($sub_bom->total_cost * $sub_bom_line->qty * $line->qty, 'MT')).'</span></td>';
310  $total_cost+= $sub_bom->total_cost * $sub_bom_line->qty * $line->qty;
311  } elseif ($sub_bom_product->type == Product::TYPE_SERVICE && isModEnabled('workstation') && !empty($sub_bom_product->fk_default_workstation)) {
312  //Convert qty to hour
313  $unit = measuringUnitString($sub_bom_line->fk_unit, '', '', 1);
314  $qty = convertDurationtoHour($sub_bom_line->qty, $unit);
315  $workstation = new Workstation($this->db);
316  $res = $workstation->fetch($sub_bom_product->fk_default_workstation);
317  if ($res > 0) $sub_bom_line->total_cost = price2num($qty * ($workstation->thm_operator_estimated + $workstation->thm_machine_estimated), 'MT');
318 
319  print '<td class="linecolcost nowrap right" id="sub_bom_cost_'.$sub_bom_line->id.'"><span class="amount">'.price(price2num($sub_bom_line->total_cost, 'MT')).'</span></td>';
320  $this->total_cost += $line->total_cost;
321  } elseif ($sub_bom_product->cost_price > 0) {
322  print '<td class="linecolcost nowrap right" id="sub_bom_cost_'.$sub_bom_line->id.'">';
323  print '<span class="amount">'.price(price2num($sub_bom_product->cost_price * $sub_bom_line->qty * $line->qty, 'MT')).'</span></td>';
324  $total_cost+= $sub_bom_product->cost_price * $sub_bom_line->qty * $line->qty;
325  } elseif ($sub_bom_product->pmp > 0) { // PMP if cost price isn't defined
326  print '<td class="linecolcost nowrap right" id="sub_bom_cost_'.$sub_bom_line->id.'">';
327  print '<span class="amount">'.price(price2num($sub_bom_product->pmp * $sub_bom_line->qty * $line->qty, 'MT')).'</span></td>';
328  $total_cost.= $sub_bom_product->pmp * $sub_bom_line->qty * $line->qty;
329  } else { // Minimum purchase price if cost price and PMP aren't defined
330  $sql_supplier_price = 'SELECT MIN(price) AS min_price, quantity AS qty FROM '.MAIN_DB_PREFIX.'product_fournisseur_price';
331  $sql_supplier_price.= ' WHERE fk_product = '. (int) $sub_bom_product->id;
332  $resql_supplier_price = $object->db->query($sql_supplier_price);
333  if ($resql_supplier_price) {
334  $obj = $object->db->fetch_object($resql_supplier_price);
335  if (!empty($obj->qty) && !empty($sub_bom_line->qty) && !empty($line->qty)) {
336  $line_cost = $obj->min_price/$obj->qty * $sub_bom_line->qty * $line->qty;
337  } else {
338  $line_cost = $obj->min_price;
339  }
340  print '<td class="linecolcost nowrap right" id="sub_bom_cost_'.$sub_bom_line->id.'"><span class="amount">'.price2num($line_cost, 'MT').'</span></td>';
341  $total_cost+= $line_cost;
342  }
343  }
344 
345  print '<td></td>';
346  print '<td></td>';
347  print '<td></td>';
348  }
349 }
350 
351 
352 print "<!-- END PHP TEMPLATE objectline_view.tpl.php -->\n";
Class for BOM.
Definition: bom.class.php:37
Class for BOMLine.
Definition: bom.class.php:1545
Class of dictionary type of thirdparty (used by imports)
Class to manage products or services.
const TYPE_SERVICE
Service.
Class for Workstation.
if(isModEnabled('facture') &&!empty($user->rights->facture->lire)) if((isModEnabled('fournisseur') &&empty($conf->global->MAIN_USE_NEW_SUPPLIERMOD) && $user->hasRight("fournisseur", "facture", "lire"))||(isModEnabled('supplier_invoice') && $user->hasRight("supplier_invoice", "lire"))) if(isModEnabled('don') &&!empty($user->rights->don->lire)) if(isModEnabled('tax') &&!empty($user->rights->tax->charges->lire)) if(isModEnabled('facture') &&isModEnabled('commande') && $user->hasRight("commande", "lire") &&empty($conf->global->WORKFLOW_DISABLE_CREATE_INVOICE_FROM_ORDER)) $resql
Social contributions to pay.
Definition: index.php:745
convertDurationtoHour($duration_value, $duration_unit)
Convert duration to hour.
Definition: date.lib.php:330
img_delete($titlealt='default', $other='class="pictodelete"', $morecss='')
Show delete logo.
yn($yesno, $case=1, $color=0)
Return yes or no in current language.
price2num($amount, $rounding='', $option=0)
Function that return a number with universal decimal format (decimal separator is '.
img_down($titlealt='default', $selected=0, $moreclass='')
Show down arrow logo.
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.
img_picto($titlealt, $picto, $moreatt='', $pictoisfullpath=false, $srconly=0, $notitle=0, $alt='', $morecss='', $marginleftonlyshort=2)
Show picto whatever it's its name (generic function)
newToken()
Return the value of token currently saved into session with name 'newtoken'.
isModEnabled($module)
Is Dolibarr module enabled.
img_edit($titlealt='default', $float=0, $other='')
Show logo editer/modifier fiche.
img_up($titlealt='default', $selected=0, $moreclass='')
Show top arrow logo.
measuringUnitString($unit, $measuring_style='', $scale='', $use_short_label=0, $outputlangs=null)
Return translation label of a unit key.
$conf db
API class for accounts.
Definition: inc.php:41