29require
'../main.inc.php';
30require_once DOL_DOCUMENT_ROOT.
'/core/lib/admin.lib.php';
31require_once DOL_DOCUMENT_ROOT.
'/core/lib/security.lib.php';
46$action =
GETPOST(
'action',
'aZ09');
48$consts =
GETPOST(
'const',
'array');
49$constname =
GETPOST(
'constname',
'alphanohtml');
50$constvalue =
GETPOST(
'constvalue',
'restricthtml');
51$constnote =
GETPOST(
'constnote',
'alpha');
54$sortfield =
GETPOST(
'sortfield',
'aZ09comma');
55$sortorder =
GETPOST(
'sortorder',
'aZ09comma');
57if (empty($page) || $page == -1 ||
GETPOST(
'button_search',
'alpha') ||
GETPOST(
'button_removefilter',
'alpha') || (empty($toselect) && $massaction ===
'0')) {
60$offset = $limit * $page;
63if (empty($sortfield)) {
64 $sortfield =
'entity,name';
66if (empty($sortorder)) {
70if ($action ==
'add' &&
GETPOST(
'update')) {
73if ($action ==
'add' &&
GETPOST(
'delete')) {
79if ($action ==
'delete' &&
GETPOST(
'add')) {
93if ($action ==
'add') {
96 if (empty($constname)) {
97 setEventMessages($langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"Name")),
null,
'errors');
100 if ($constvalue ==
'') {
101 setEventMessages($langs->trans(
"ErrorFieldRequired", $langs->transnoentitiesnoconv(
"Value")),
null,
'errors');
106 if (
dolibarr_set_const($db, $constname, $constvalue,
'chaine', 1, $constnote, $entity) >= 0) {
119if (!empty($consts) && $action ==
'update') {
121 foreach ($consts as $const) {
122 if (!empty($const[
"check"])) {
123 if (
dolibarr_set_const($db, $const[
"name"], $const[
"value"], $const[
"type"], 1, $const[
"note"], $const[
"entity"]) >= 0) {
130 if ($nbmodified > 0) {
137if (!empty($consts) && $action ==
'delete') {
139 foreach ($consts as $const) {
140 if (!empty($const[
"check"])) {
148 if ($nbdeleted > 0) {
155if ($action ==
'delete') {
168$form =
new Form($db);
170$wikihelp =
'EN:Setup_Other|FR:Paramétrage_Divers|ES:Configuración_Varios';
171llxHeader(
'', $langs->trans(
"Setup"), $wikihelp,
'', 0, 0,
'',
'',
'',
'mod-admin page-const');
174if (
$conf->use_javascript_ajax) {
176<script
type=
"text/javascript">
177jQuery(document).ready(
function() {
178 jQuery(
"#updateconst").hide();
179 jQuery(
"#delconst").hide();
180 jQuery(
".checkboxfordelete").click(
function() {
181 jQuery(
"#delconst").show();
183 jQuery(
".inputforupdate").keyup(
function() {
184 var field_id = jQuery(
this).attr(
"id");
185 var row_num = field_id.split(
"_");
186 jQuery(
"#updateconst").show();
187 jQuery(
"#action").val(
'update');
188 jQuery(
"#check_" + row_num[1]).prop(
"checked",
true);
197print
'<span class="opacitymedium">'.$langs->trans(
"ConstDesc").
"</span><br>\n";
203print
'<form action="'.$_SERVER[
"PHP_SELF"].((empty($user->entity) && $debug) ?
'?debug=1' :
'').
'" method="POST">';
204print
'<input type="hidden" name="token" value="'.newToken().
'">';
205print
'<input type="hidden" id="action" name="action" value="add">';
206print
'<input type="hidden" name="sortfield" value="'.$sortfield.
'">';
207print
'<input type="hidden" name="sortorder" value="'.$sortorder.
'">';
209print
'<div class="div-table-responsive-no-min">';
210print
'<table class="noborder centpercent">';
211print
'<tr class="liste_titre">';
212print
getTitleFieldOfList(
'Name', 0, $_SERVER[
'PHP_SELF'],
'name',
'', $param,
'', $sortfield, $sortorder,
'') .
"\n";
213print
getTitleFieldOfList(
"Value", 0, $_SERVER[
"PHP_SELF"],
'',
'', $param,
'', $sortfield, $sortorder);
214print
getTitleFieldOfList(
"Comment", 0, $_SERVER[
"PHP_SELF"],
'',
'', $param,
'', $sortfield, $sortorder);
215print
getTitleFieldOfList(
'DateModificationShort', 0, $_SERVER[
'PHP_SELF'],
'tms',
'', $param,
'', $sortfield, $sortorder,
'center ') .
"\n";
216if (isModEnabled(
'multicompany') && !$user->entity) {
217 print
getTitleFieldOfList(
'Entity', 0, $_SERVER[
'PHP_SELF'],
'tms',
'', $param,
'', $sortfield, $sortorder,
'center ') .
"\n";
219print
getTitleFieldOfList(
"", 0, $_SERVER[
"PHP_SELF"],
'',
'', $param,
'', $sortfield, $sortorder,
'center ');
226print
'<tr class="oddeven nohover"><td>';
227print
'<input type="text" class="flat minwidth300" name="constname" value="'.$constname.
'">';
230print
'<input type="text" class="flat minwidth100" name="constvalue" value="'.$constvalue.
'">';
233print
'<input type="text" class="flat minwidth100" name="constnote" value="'.$constnote.
'">';
238if (isModEnabled(
'multicompany') && !$user->entity) {
240 print
'<input type="text" class="flat" size="1" name="entity" value="' .
$conf->entity .
'">';
242 print
'<td class="center">';
244 print
'<td class="center">';
245 print
'<input type="hidden" name="entity" value="' .
$conf->entity .
'">';
247print
'<input type="submit" class="button button-add small" id="add" name="add" value="'.$langs->trans(
"Add").
'">';
255$sql .=
", ".$db->decrypt(
'name').
" as name";
256$sql .=
", ".$db->decrypt(
'value').
" as value";
261$sql .=
" FROM ".MAIN_DB_PREFIX.
"const";
262$sql .=
" WHERE entity IN (".$db->sanitize($user->entity.
",".
$conf->entity).
")";
263if ((empty($user->entity) || $user->admin) && $debug) {
266 $sql .=
" AND visible = 1";
271$sql .= $db->order($sortfield, $sortorder);
274$result = $db->query($sql);
276 $num = $db->num_rows($result);
280 $obj = $db->fetch_object($result);
286 print
'<tr class="oddeven" data-checkbox-id="check_'.$i.
'"><td>'.
dol_escape_htmltag($obj->name).
'</td>'.
"\n";
290 print
'<input type="hidden" name="const['.$i.
'][rowid]" value="'.$obj->rowid.
'">';
291 print
'<input type="hidden" name="const['.$i.
'][name]" value="'.$obj->name.
'">';
292 print
'<input type="hidden" name="const['.$i.
'][type]" value="'.$obj->type.
'">';
293 print
'<input type="text" id="value_'.$i.
'" class="flat inputforupdate minwidth150" name="const['.$i.
'][value]" value="'.(isset($value) ? htmlspecialchars($value) :
'').
'">';
298 print
'<input type="text" id="note_'.$i.
'" class="flat inputforupdate minwidth200" name="const['.$i.
'][note]" value="'.(empty($obj->note) ?
'' : htmlspecialchars($obj->note, 1)).
'">';
302 print
'<td class="nowraponall center">';
307 if (isModEnabled(
'multicompany') && empty($user->entity)) {
309 print
'<input type="text" class="flat" size="1" name="const['.$i.
'][entity]" value="'.((int) $obj->entity).
'">';
311 print
'<td class="center">';
313 print
'<td class="center">';
314 print
'<input type="hidden" name="const['.$i.
'][entity]" value="'.((int) $obj->entity).
'">';
317 if (!empty(
$conf->use_javascript_ajax)) {
318 print
'<input type="checkbox" class="flat checkboxfordelete" id="check_'.$i.
'" name="const['.$i.
'][check]" value="1">';
320 print
'<a href="'.$_SERVER[
'PHP_SELF'].
'?rowid='.$obj->rowid.
'&entity='.$obj->entity.
'&action=delete&token='.
newToken().((empty($user->entity) && $debug) ?
'&debug=1' :
'').
'">'.
img_delete().
'</a>';
323 print
"</td></tr>\n";
334if (
$conf->use_javascript_ajax) {
336 print
'<div id="updateconst" class="right">';
337 print
'<input type="submit" class="button button-edit marginbottomonly" name="update" value="'.$langs->trans(
"Modify").
'">';
339 print
'<div id="delconst" class="right">';
340 print
'<input type="submit" class="button button-cancel marginbottomonly" name="delete" value="'.$langs->trans(
"Delete").
'">';
dolibarr_set_const($db, $name, $value, $type='chaine', $visible=0, $note='', $entity=1)
Insert a parameter (key,value) into database (delete old key then insert it again).
dolibarr_del_const($db, $name, $entity=1)
Delete a constant.
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.
load_fiche_titre($title, $morehtmlright='', $picto='generic', $pictoisfullpath=0, $id='', $morecssontable='', $morehtmlcenter='')
Load a title with picto.
setEventMessages($mesg, $mesgs, $style='mesgs', $messagekey='', $noduplicate=0, $attop=0)
Set event messages in dol_events session object.
img_delete($titlealt='default', $other='class="pictodelete"', $morecss='')
Show delete logo.
GETPOSTINT($paramname, $method=0)
Return the value of a $_GET or $_POST supervariable, converted into integer.
natural_search($fields, $value, $mode=0, $nofirstand=0)
Generate natural SQL search string for a criteria (this criteria can be tested on one or several fiel...
dol_print_date($time, $format='', $tzoutput='auto', $outputlangs=null, $encodetooutput=false)
Output date in a string format according to outputlangs (or langs if not defined).
newToken()
Return the value of token currently saved into session with name 'newtoken'.
getTitleFieldOfList($name, $thead=0, $file="", $field="", $begin="", $moreparam="", $moreattrib="", $sortfield="", $sortorder="", $prefix="", $disablesortlink=0, $tooltip='', $forcenowrapcolumntitle=0)
Get title line of an array.
GETPOST($paramname, $check='alphanohtml', $method=0, $filter=null, $options=null, $noreplace=0)
Return value of a param into GET or POST supervariable.
dol_print_error($db=null, $error='', $errors=null)
Displays error message system with all the information to facilitate the diagnosis and the escalation...
dol_syslog($message, $level=LOG_INFO, $ident=0, $suffixinfilename='', $restricttologhandler='', $logcontext=null)
Write log message into outputs.
dol_escape_htmltag($stringtoescape, $keepb=0, $keepn=0, $noescapetags='', $escapeonlyhtmltags=0, $cleanalsojavascript=0)
Returns text escaped for inclusion in HTML alt or title or value tags, or into values of HTML input f...
global $conf
The following vars must be defined: $type2label $form $conf, $lang, The following vars may also be de...
if(preg_match('/crypted:/i', $dolibarr_main_db_pass)||!empty($dolibarr_main_db_encrypted_pass)) $conf db type
dolDecrypt($chain, $key='')
Decode a string with a symmetric encryption.
accessforbidden($message='', $printheader=1, $printfooter=1, $showonlymessage=0, $params=null)
Show a message to say access is forbidden and stop program.