32require
'../../main.inc.php';
33require_once DOL_DOCUMENT_ROOT.
'/fourn/class/fournisseur.class.php';
34require_once DOL_DOCUMENT_ROOT.
'/fourn/class/fournisseur.facture.class.php';
35require_once DOL_DOCUMENT_ROOT.
'/core/lib/fourn.lib.php';
36require_once DOL_DOCUMENT_ROOT.
'/core/lib/files.lib.php';
37require_once DOL_DOCUMENT_ROOT.
'/core/lib/images.lib.php';
38require_once DOL_DOCUMENT_ROOT.
'/core/class/html.formfile.class.php';
39if (isModEnabled(
'project')) {
40 require_once DOL_DOCUMENT_ROOT.
'/projet/class/project.class.php';
52$langs->loadLangs(array(
'bills',
'other',
'companies'));
55$action =
GETPOST(
'action',
'aZ09');
56$confirm =
GETPOST(
'confirm',
'alpha');
61 $socid = $user->socid;
63$hookmanager->initHooks(array(
'invoicesuppliercarddocument'));
64$result =
restrictedArea($user,
'fournisseur', $id,
'facture_fourn',
'facture');
68$sortfield =
GETPOST(
'sortfield',
'aZ09comma');
69$sortorder =
GETPOST(
'sortorder',
'aZ09comma');
71if (empty($page) || $page == -1) {
74$offset = $limit * $page;
88 $upload_dir =
$conf->fournisseur->facture->dir_output.
'/'.
get_exdir(
$object->id, 2, 0, 0, $object,
'invoice_supplier').$ref;
91$permissiontoadd = ($user->hasRight(
"fournisseur",
"facture",
"creer") || $user->hasRight(
"supplier_invoice",
"creer"));
98include DOL_DOCUMENT_ROOT.
'/core/actions_linkedfiles.inc.php';
105$form =
new Form($db);
107$title =
$object->ref.
" - ".$langs->trans(
'Documents');
108$helpurl =
"EN:Module_Suppliers_Invoices|FR:Module_Fournisseurs_Factures|ES:Módulo_Facturas_de_proveedores";
109llxHeader(
'', $title, $helpurl,
'', 0, 0,
'',
'',
'',
'mod-fourn-facture page-card_document');
113 print
dol_get_fiche_head($head,
'documents', $langs->trans(
'SupplierInvoice'), -1,
'supplier_invoice');
115 $totalpaid =
$object->getSommePaiement();
117 $linkback =
'<a href="'.DOL_URL_ROOT.
'/fourn/facture/list.php?restore_lastsearch_values=1'.(!empty($socid) ?
'&socid='.$socid :
'').
'">'.$langs->trans(
"BackToList").
'</a>';
119 $morehtmlref =
'<div class="refidno">';
121 $morehtmlref .= $form->editfieldkey(
"RefSupplierBill",
'ref_supplier',
$object->ref_supplier, $object, 0,
'string',
'', 0, 1);
122 $morehtmlref .= $form->editfieldval(
"RefSupplierBill",
'ref_supplier',
$object->ref_supplier, $object, 0,
'string',
'',
null,
null,
'', 1);
124 $morehtmlref .=
'<br>'.$object->thirdparty->getNomUrl(1);
126 $morehtmlref .=
' <div class="inline-block valignmiddle">(<a class="valignmiddle" href="'.DOL_URL_ROOT.
'/fourn/facture/list.php?socid='.
$object->thirdparty->id.
'&search_company='.urlencode(
$object->thirdparty->name).
'">'.$langs->trans(
"OtherBills").
'</a>)</div>';
129 if (isModEnabled(
'project')) {
130 $langs->load(
"projects");
131 $morehtmlref .=
'<br>';
133 $morehtmlref .=
img_picto($langs->trans(
"Project"),
'project',
'class="pictofixedwidth"');
134 if ($action !=
'classify') {
135 $morehtmlref .=
'<a class="editfielda" href="'.$_SERVER[
'PHP_SELF'].
'?action=classify&token='.
newToken().
'&id='.
$object->id.
'">'.
img_edit($langs->transnoentitiesnoconv(
'SetProject')).
'</a> ';
137 $morehtmlref .= $form->form_project($_SERVER[
'PHP_SELF'].
'?id='.
$object->id, (!
getDolGlobalString(
'PROJECT_CAN_ALWAYS_LINK_TO_ALL_SUPPLIERS') ?
$object->socid : -1),
$object->fk_project, ($action ==
'classify' ?
'projectid' :
'none'), 0, 0, 0, 1,
'',
'maxwidth300');
139 if (!empty(
$object->fk_project)) {
141 $proj->fetch(
$object->fk_project);
142 $morehtmlref .= $proj->getNomUrl(1);
144 $morehtmlref .=
'<span class="opacitymedium"> - '.dol_escape_htmltag($proj->title).
'</span>';
149 $morehtmlref .=
'</div>';
151 $object->totalpaid = $totalpaid;
153 dol_banner_tab($object,
'ref', $linkback, 1,
'ref',
'ref', $morehtmlref,
'', 0);
155 print
'<div class="fichecenter">';
156 print
'<div class="underbanner clearboth"></div>';
159 $filearray =
dol_dir_list($upload_dir,
"files", 0,
'',
'(\.meta|_preview.*\.png)$', $sortfield, (strtolower($sortorder) ==
'desc' ? SORT_DESC : SORT_ASC), 1);
161 foreach ($filearray as $key => $file) {
162 $totalsize += $file[
'size'];
168 if ($action ==
'delete') {
169 print $form->formconfirm($_SERVER[
"PHP_SELF"].
'?id='.
$object->id.
'&urlfile='.urlencode(
GETPOST(
"urlfile")), $langs->trans(
'DeleteFile'), $langs->trans(
'ConfirmDeleteFile'),
'confirm_deletefile',
'', 0, 1);
172 print
'<table class="border tableforfield centpercent">';
175 print
'<tr><td class="titlefield">'.$langs->trans(
'Type').
'</td><td>';
176 print
'<span class="badgeneutral">';
181 $facreplaced->fetch(
$object->fk_facture_source);
182 print
' ('.$langs->transnoentities(
"ReplaceInvoice", $facreplaced->getNomUrl(1)).
')';
186 $facusing->fetch(
$object->fk_facture_source);
187 print
' ('.$langs->transnoentities(
"CorrectInvoice", $facusing->getNomUrl(1)).
')';
190 $facidavoir =
$object->getListIdAvoirFromInvoice();
191 if (count($facidavoir) > 0) {
192 $invoicecredits = array();
193 foreach ($facidavoir as $facid) {
195 $facavoir->fetch($facid);
196 $invoicecredits[] = $facavoir->getNomUrl(1);
198 print
' ('.$langs->transnoentities(
"InvoiceHasAvoir") . (count($invoicecredits) ?
' ' :
'') . implode(
',', $invoicecredits) .
')';
210 print
'<tr><td>'.$form->editfieldkey(
"Label",
'label',
$object->label, $object, 0).
'</td><td>';
211 print $form->editfieldval(
"Label",
'label',
$object->label, $object, 0);
215 print
'<tr><td>'.$langs->trans(
'AmountHT').
'</td><td>'.
price(
$object->total_ht, 1, $langs, 0, -1, -1,
$conf->currency).
'</td></tr>';
216 print
'<tr><td>'.$langs->trans(
'AmountVAT').
'</td><td>'.
price(
$object->total_tva, 1, $langs, 0, -1, -1,
$conf->currency).
'</td></tr>';
220 if ($mysoc->localtax1_assuj ==
"1") {
221 print
'<tr><td>'.$langs->transcountry(
"AmountLT1", $mysoc->country_code).
'</td>';
222 print
'<td>'.price(
$object->total_localtax1, 1, $langs, 0, -1, -1,
$conf->currency).
'</td>';
225 if ($mysoc->localtax2_assuj ==
"1") {
226 print
'<tr><td>'.$langs->transcountry(
"AmountLT2", $mysoc->country_code).
'</td>';
227 print
'<td>'.price(
$object->total_localtax2, 1, $langs, 0, -1, -1,
$conf->currency).
'</td>';
230 print
'<tr><td>'.$langs->trans(
'AmountTTC').
'</td><td>'.
price(
$object->total_ttc, 1, $langs, 0, -1, -1,
$conf->currency).
'</td></tr>';
232 print
'</table><br>';
234 print
'<div class="underbanner clearboth"></div>';
236 print
'<table class="border tableforfield centpercent">';
239 print
'<tr><td class="titlefield nowrap">'.$langs->trans(
'NbOfAttachedFiles').
'</td><td>'.count($filearray).
'</td></tr>';
241 print
'<tr><td>'.$langs->trans(
'TotalSizeOfAttachedFiles').
'</td><td>'.
dol_print_size($totalsize, 1, 1).
'</td></tr>';
246 print
'<div class="clearboth"></div>';
251 $modulepart =
'facture_fournisseur';
252 $permission = ($user->hasRight(
"fournisseur",
"facture",
"creer") || $user->hasRight(
"supplier_invoice",
"creer"));
253 $permtoedit = ($user->hasRight(
"fournisseur",
"facture",
"creer") || $user->hasRight(
"supplier_invoice",
"creer"));
254 $param =
'&facid='.$object->id;
256 $defaulttpldir =
'/core/tpl';
257 $dirtpls = array_merge(
$conf->modules_parts[
'tpl'], array($defaulttpldir));
258 foreach ($dirtpls as $module => $reldir) {
259 if (!empty($module)) {
260 $tpl =
dol_buildpath($reldir.
'/document_actions_post_headers.tpl.php');
262 $tpl = DOL_DOCUMENT_ROOT.$reldir.
'/document_actions_post_headers.tpl.php';
265 if (empty(
$conf->file->strict_mode)) {
266 $res = @include $tpl;
275 print $langs->trans(
'ErrorUnknown');
if( $user->socid > 0) if(! $user->hasRight('accounting', 'chartofaccount')) $object
if(!defined('NOREQUIRESOC')) if(!defined( 'NOREQUIRETRAN')) if(!defined('NOTOKENRENEWAL')) if(!defined( 'NOREQUIREMENU')) if(!defined('NOREQUIREHTML')) if(!defined( 'NOREQUIREAJAX')) llxHeader($head='', $title='', $help_url='', $target='', $disablejs=0, $disablehead=0, $arrayofjs='', $arrayofcss='', $morequerystring='', $morecssonbody='', $replacemainareaby='', $disablenofollow=0, $disablenoindex=0)
Empty header.
Class to manage suppliers invoices.
const TYPE_CREDIT_NOTE
Credit note invoice.
const TYPE_REPLACEMENT
Replacement invoice.
Class to manage projects.
dol_dir_list($utf8_path, $types="all", $recursive=0, $filter="", $excludefilter=null, $sortcriteria="name", $sortorder=SORT_ASC, $mode=0, $nohook=0, $relativename="", $donotfollowsymlinks=0, $nbsecondsold=0)
Scan a directory and return a list of files/directories.
facturefourn_prepare_head(FactureFournisseur $object)
Prepare array with list of tabs.
dol_print_size($size, $shortvalue=0, $shortunit=0)
Return string with formatted size.
img_picto($titlealt, $picto, $moreatt='', $pictoisfullpath=0, $srconly=0, $notitle=0, $alt='', $morecss='', $marginleftonlyshort=2)
Show picto whatever it's its name (generic function)
GETPOSTINT($paramname, $method=0)
Return the value of a $_GET or $_POST supervariable, converted into integer.
dol_get_fiche_head($links=array(), $active='', $title='', $notab=0, $picto='', $pictoisfullpath=0, $morehtmlright='', $morecss='', $limittoshow=0, $moretabssuffix='', $dragdropfile=0)
Show tabs of a record.
dol_get_fiche_end($notab=0)
Return tab footer of a card.
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.
newToken()
Return the value of token currently saved into session with name 'newtoken'.
GETPOST($paramname, $check='alphanohtml', $method=0, $filter=null, $options=null, $noreplace=0)
Return value of a param into GET or POST supervariable.
dol_buildpath($path, $type=0, $returnemptyifnotfound=0)
Return path of url or filesystem.
dol_sanitizeFileName($str, $newstr='_', $unaccent=1)
Clean a string to use it as a file name.
getDolGlobalString($key, $default='')
Return a Dolibarr global constant string value.
img_edit($titlealt='default', $float=0, $other='')
Show logo edit/modify fiche.
get_exdir($num, $level, $alpha, $withoutslash, $object, $modulepart='')
Return a path to have a the directory according to object where files are stored.
global $conf
The following vars must be defined: $type2label $form $conf, $lang, The following vars may also be de...
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.