dolibarr  17.0.4
accountancy_codes.php
1 <?php
2 /* Copyright (C) 2007-2017 Laurent Destailleur <eldy@users.sourceforge.net>
3  * Copyright (C) 2018 Alexandre Spangaro <aspangaro@open-dsi.fr>
4  *
5  * This program is free software; you can redistribute it and/or modify
6  * it under the terms of the GNU General Public License as published by
7  * the Free Software Foundation; either version 3 of the License, or
8  * (at your option) any later version.
9  *
10  * This program is distributed in the hope that it will be useful,
11  * but WITHOUT ANY WARRANTY; without even the implied warranty of
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13  * GNU General Public License for more details.
14  *
15  * You should have received a copy of the GNU General Public License
16  * along with this program. If not, see <https://www.gnu.org/licenses/>.
17  */
18 
25 // Load Dolibarr environment
26 require '../main.inc.php';
27 require_once DOL_DOCUMENT_ROOT . '/core/lib/asset.lib.php';
28 require_once DOL_DOCUMENT_ROOT . '/asset/class/asset.class.php';
29 require_once DOL_DOCUMENT_ROOT . '/asset/class/assetaccountancycodes.class.php';
30 
31 // Load translation files required by the page
32 $langs->loadLangs(array("assets", "companies"));
33 
34 // Get parameters
35 $id = GETPOST('id', 'int');
36 $ref = GETPOST('ref', 'alpha');
37 $action = GETPOST('action', 'aZ09');
38 $cancel = GETPOST('cancel', 'aZ09');
39 $backtopage = GETPOST('backtopage', 'alpha');
40 
41 // Initialize technical objects
42 $object = new Asset($db);
43 $assetaccountancycodes = new AssetAccountancyCodes($db);
44 $extrafields = new ExtraFields($db);
45 $diroutputmassaction = $conf->asset->dir_output . '/temp/massgeneration/' . $user->id;
46 $hookmanager->initHooks(array('assetaccountancycodes', 'globalcard')); // Note that conf->hooks_modules contains array
47 // Fetch optionals attributes and labels
48 $extrafields->fetch_name_optionals_label($object->table_element);
49 
50 // Load object
51 include DOL_DOCUMENT_ROOT . '/core/actions_fetchobject.inc.php'; // Must be include, not include_once // Must be include, not include_once. Include fetch and fetch_thirdparty but not fetch_optionals
52 if ($id > 0 || !empty($ref)) {
53  $upload_dir = $conf->asset->multidir_output[$object->entity] . "/" . $object->id;
54 }
55 
56 $permissiontoadd = $user->rights->asset->write; // Used by the include of actions_addupdatedelete.inc.php
57 
58 // Security check (enable the most restrictive one)
59 if ($user->socid > 0) accessforbidden();
60 $isdraft = (($object->status == $object::STATUS_DRAFT) ? 1 : 0);
61 restrictedArea($user, $object->element, $object->id, $object->table_element, '', 'fk_soc', 'rowid', $isdraft);
62 if (!isModEnabled('asset')) accessforbidden();
63 
64 $result = $assetaccountancycodes->fetchAccountancyCodes($object->id);
65 if ($result < 0) {
66  setEventMessages($assetaccountancycodes->error, $assetaccountancycodes->errors, 'errors');
67 }
68 
69 
70 /*
71  * Actions
72  */
73 
74 $reshook = $hookmanager->executeHooks('doActions', array(), $object, $action); // Note that $action and $object may have been modified by some hooks
75 if ($reshook < 0) {
76  setEventMessages($hookmanager->error, $hookmanager->errors, 'errors');
77 }
78 if (empty($reshook)) {
79  $backurlforlist = DOL_URL_ROOT.'/asset/list.php';
80 
81  if (empty($backtopage) || ($cancel && empty($id))) {
82  if (empty($backtopage) || ($cancel && strpos($backtopage, '__ID__'))) {
83  if (empty($id) && (($action != 'add' && $action != 'create') || $cancel)) {
84  $backtopage = $backurlforlist;
85  } else {
86  $backtopage = DOL_URL_ROOT.'/asset/accountancy_codes.php?id='.((!empty($id) && $id > 0) ? $id : '__ID__');
87  }
88  }
89  }
90 
91  if ($cancel) {
92  /*var_dump($cancel);var_dump($backtopage);var_dump($backtopageforcancel);exit;*/
93  if (!empty($backtopageforcancel)) {
94  header("Location: ".$backtopageforcancel);
95  exit;
96  } elseif (!empty($backtopage)) {
97  header("Location: ".$backtopage);
98  exit;
99  }
100  $action = '';
101  }
102 
103  if ($action == "update") {
104  $assetaccountancycodes->setAccountancyCodesFromPost();
105 
106  $result = $assetaccountancycodes->updateAccountancyCodes($user, $object->id);
107  if ($result < 0) {
108  setEventMessages($assetaccountancycodes->error, $assetaccountancycodes->errors, 'errors');
109  $action = 'edit';
110  } else {
111  setEventMessage($langs->trans('RecordSaved'));
112  header("Location: " . $_SERVER["PHP_SELF"] . '?id=' . $object->id);
113  exit;
114  }
115  }
116 }
117 
118 
119 /*
120  * View
121  */
122 
123 $form = new Form($db);
124 
125 $help_url = '';
126 llxHeader('', $langs->trans('Asset'), $help_url);
127 
128 if ($id > 0 || !empty($ref)) {
129  $head = assetPrepareHead($object);
130  print dol_get_fiche_head($head, 'accountancy_codes', $langs->trans("Asset"), -1, $object->picto);
131 
132  // Object card
133  // ------------------------------------------------------------
134  $linkback = '<a href="' . DOL_URL_ROOT . '/asset/list.php?restore_lastsearch_values=1' . (!empty($socid) ? '&socid=' . $socid : '') . '">' . $langs->trans("BackToList") . '</a>';
135 
136  $morehtmlref = '<div class="refidno">';
137  $morehtmlref .= '</div>';
138 
139  dol_banner_tab($object, 'ref', $linkback, 1, 'ref', 'ref', $morehtmlref);
140 
141  print '<div class="fichecenter">';
142  print '<div class="underbanner clearboth"></div>';
143  print '</div>';
144 
145  if ($action == 'edit') {
146  print '<form method="POST" action="' . $_SERVER["PHP_SELF"] . '?id=' . $object->id . '">';
147  print '<input type="hidden" name="token" value="' . newToken() . '">';
148  print '<input type="hidden" name="action" value="update">';
149  if ($backtopage) {
150  print '<input type="hidden" name="backtopage" value="' . $backtopage . '">';
151  }
152  if ($backtopageforcancel) {
153  print '<input type="hidden" name="backtopageforcancel" value="' . $backtopageforcancel . '">';
154  }
155 
156  print dol_get_fiche_head(array(), '');
157 
158  include DOL_DOCUMENT_ROOT . '/asset/tpl/accountancy_codes_edit.tpl.php';
159 
160  print dol_get_fiche_end();
161 
162  print $form->buttonsSaveCancel();
163 
164  print '</form>';
165  } else {
166  include DOL_DOCUMENT_ROOT . '/asset/tpl/accountancy_codes_view.tpl.php';
167  }
168 
169  print dol_get_fiche_end();
170 
171  if ($action != 'edit') {
172  print '<div class="tabsAction">' . "\n";
173  $parameters = array();
174  $reshook = $hookmanager->executeHooks('addMoreActionsButtons', $parameters, $object, $action); // Note that $action and $object may have been modified by hook
175  if ($reshook < 0) {
176  setEventMessages($hookmanager->error, $hookmanager->errors, 'errors');
177  }
178 
179  if (empty($reshook)) {
180  if ($object->status == $object::STATUS_DRAFT/* && !empty($object->enabled_modes)*/) {
181  print dolGetButtonAction($langs->trans('Modify'), '', 'default', $_SERVER["PHP_SELF"] . '?id=' . $object->id . '&action=edit&token=' . newToken(), '', $permissiontoadd);
182  }
183  }
184  print '</div>' . "\n";
185  }
186 }
187 
188 // End of page
189 llxFooter();
190 $db->close();
if(GETPOST('button_removefilter_x', 'alpha')||GETPOST('button_removefilter.x', 'alpha')||GETPOST('button_removefilter', 'alpha')) if(GETPOST('button_search_x', 'alpha')||GETPOST('button_search.x', 'alpha')||GETPOST('button_search', 'alpha')) if($action=="save" &&empty($cancel)) $help_url
View.
Definition: agenda.php:118
assetPrepareHead(Asset $object)
Prepare array of tabs for Asset.
Definition: asset.lib.php:87
if(!defined('NOREQUIRESOC')) if(!defined('NOREQUIRETRAN')) if(!defined('NOTOKENRENEWAL')) if(!defined('NOREQUIREMENU')) if(!defined('NOREQUIREHTML')) if(!defined('NOREQUIREAJAX')) llxHeader()
Empty header.
Definition: wrapper.php:56
llxFooter()
Empty footer.
Definition: wrapper.php:70
Class for AssetAccountancyCodes.
Class for Asset.
Definition: asset.class.php:31
Class to manage standard extra fields.
Class to manage generation of HTML components Only common components must be here.
if($cancel &&! $id) if($action=='add' &&! $cancel) if($action=='delete') if($id) $form
Actions.
Definition: card.php:143
dol_banner_tab($object, $paramid, $morehtml='', $shownav=1, $fieldid='rowid', $fieldref='ref', $morehtmlref='', $moreparam='', $nodbprefix=0, $morehtmlleft='', $morehtmlstatus='', $onlybanner=0, $morehtmlright='')
Show tab footer of a card.
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.
newToken()
Return the value of token currently saved into session with name 'newtoken'.
dolGetButtonAction($label, $text='', $actionType='default', $url='', $id='', $userRight=1, $params=array())
Function dolGetButtonAction.
GETPOST($paramname, $check='alphanohtml', $method=0, $filter=null, $options=null, $noreplace=0)
Return value of a param into GET or POST supervariable.
setEventMessage($mesgs, $style='mesgs')
Set event message in dol_events session object.
isModEnabled($module)
Is Dolibarr module enabled.
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.
accessforbidden($message='', $printheader=1, $printfooter=1, $showonlymessage=0, $params=null)
Show a message to say access is forbidden and stop program.