29 require
'../../main.inc.php';
31 require_once DOL_DOCUMENT_ROOT.
'/expensereport/class/expensereport.class.php';
32 require_once DOL_DOCUMENT_ROOT.
'/core/class/html.formaccounting.class.php';
35 $langs->loadLangs(array(
"bills",
"accountancy",
"trips"));
37 $action =
GETPOST(
'action',
'aZ09');
38 $cancel =
GETPOST(
'cancel',
'alpha');
39 $backtopage =
GETPOST(
'backtopage',
'alpha');
41 $codeventil =
GETPOST(
'codeventil',
'int');
48 if ($user->socid > 0) {
51 if (empty($user->rights->accounting->mouvements->lire)) {
60 if ($action ==
'ventil' && $user->rights->accounting->bind->write) {
62 if ($codeventil < 0) {
66 $sql =
" UPDATE ".MAIN_DB_PREFIX.
"expensereport_det";
67 $sql .=
" SET fk_code_ventilation = ".((int) $codeventil);
68 $sql .=
" WHERE rowid = ".((int) $id);
74 setEventMessages($langs->trans(
"RecordModifiedSuccessfully"),
null,
'mesgs');
76 header(
"Location: ".$backtopage);
81 header(
"Location: ./lines.php");
91 llxHeader(
"", $langs->trans(
'FicheVentilation'));
93 if ($cancel == $langs->trans(
"Cancel")) {
103 $sql =
"SELECT er.ref, er.rowid as facid, erd.fk_c_type_fees, erd.comments, erd.rowid, erd.fk_code_ventilation,";
104 $sql .=
" f.id as type_fees_id, f.code as type_fees_code, f.label as type_fees_label,";
105 $sql .=
" aa.account_number, aa.label";
106 $sql .=
" FROM ".MAIN_DB_PREFIX.
"expensereport_det as erd";
107 $sql .=
" LEFT JOIN ".MAIN_DB_PREFIX.
"c_type_fees as f ON f.id = erd.fk_c_type_fees";
108 $sql .=
" LEFT JOIN ".MAIN_DB_PREFIX.
"accounting_account as aa ON erd.fk_code_ventilation = aa.rowid";
109 $sql .=
" INNER JOIN ".MAIN_DB_PREFIX.
"expensereport as er ON er.rowid = erd.fk_expensereport";
110 $sql .=
" WHERE er.fk_statut > 0 AND erd.rowid = ".((int) $id);
111 $sql .=
" AND er.entity IN (".getEntity(
'expensereport', 0).
")";
113 dol_syslog(
"/accounting/expensereport/card.php", LOG_DEBUG);
114 $result = $db->query($sql);
117 $num_lines = $db->num_rows($result);
121 $objp = $db->fetch_object($result);
123 print
'<form action="'.$_SERVER[
"PHP_SELF"].
'?id='.$id.
'" method="post">'.
"\n";
124 print
'<input type="hidden" name="token" value="'.newToken().
'">';
125 print
'<input type="hidden" name="action" value="ventil">';
126 print
'<input type="hidden" name="backtopage" value="'.dol_escape_htmltag($backtopage).
'">';
128 print
load_fiche_titre($langs->trans(
'ExpenseReportsVentilation'),
'',
'title_accountancy');
132 print
'<table class="border centpercent">';
135 print
'<tr><td class="titlefield">'.$langs->trans(
"ExpenseReport").
'</td>';
136 $expensereport_static->ref = $objp->ref;
137 $expensereport_static->id = $objp->erid;
138 print
'<td>'.$expensereport_static->getNomUrl(1).
'</td>';
141 print
'<tr><td>'.$langs->trans(
"Line").
'</td>';
142 print
'<td>'.stripslashes(nl2br($objp->rowid)).
'</td></tr>';
144 print
'<tr><td>'.$langs->trans(
"Description").
'</td>';
145 print
'<td>'.stripslashes(nl2br($objp->comments)).
'</td></tr>';
147 print
'<tr><td>'.$langs->trans(
"TypeFees").
'</td>';
148 print
'<td>'.($langs->trans($objp->type_fees_code) == $objp->type_fees_code ? $objp->type_fees_label : $langs->trans(($objp->type_fees_code))).
'</td>';
150 print
'<tr><td>'.$langs->trans(
"Account").
'</td><td>';
151 print $formaccounting->select_account($objp->fk_code_ventilation,
'codeventil', 1);
157 print
'<div class="center">';
158 print
'<input class="button button-save" type="submit" value="'.$langs->trans(
"Save").
'">';
159 print
' ';
160 print
'<input class="button button-cancel" type="submit" name="cancel" value="'.$langs->trans(
"Cancel").
'">';
171 print
"Error ID incorrect";
if(!defined('NOREQUIRESOC')) if(!defined('NOREQUIRETRAN')) if(!defined('NOTOKENRENEWAL')) if(!defined('NOREQUIREMENU')) if(!defined('NOREQUIREHTML')) if(!defined('NOREQUIREAJAX')) llxHeader()
Empty header.
Class to manage Trips and Expenses.
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.
if($cancel &&! $id) if($action=='add' &&! $cancel) if($action=='delete') if($id) $form
Actions.
load_fiche_titre($titre, $morehtmlright='', $picto='generic', $pictoisfullpath=0, $id='', $morecssontable='', $morehtmlcenter='')
Load a title with picto.
dol_get_fiche_head($links=array(), $active='', $title='', $notab=0, $picto='', $pictoisfullpath=0, $morehtmlright='', $morecss='', $limittoshow=0, $moretabssuffix='')
Show tabs of a record.
dol_get_fiche_end($notab=0)
Return tab footer of a card.
setEventMessages($mesg, $mesgs, $style='mesgs', $messagekey='')
Set event messages in dol_events session object.
GETPOST($paramname, $check='alphanohtml', $method=0, $filter=null, $options=null, $noreplace=0)
Return value of a param into GET or POST supervariable.
isModEnabled($module)
Is Dolibarr module enabled.
dol_syslog($message, $level=LOG_INFO, $ident=0, $suffixinfilename='', $restricttologhandler='', $logcontext=null)
Write log message into outputs.
accessforbidden($message='', $printheader=1, $printfooter=1, $showonlymessage=0, $params=null)
Show a message to say access is forbidden and stop program.