97 public static function listBoxes($dbs, $mode, $zone, $user =
null, $excludelist = array(), $includehidden = 1)
103 if ($mode ==
'activated') {
104 $sql =
"SELECT b.rowid, b.position, b.box_order, b.fk_user,";
105 $sql .=
" d.rowid as box_id, d.file, d.note, d.tms";
106 $sql .=
" FROM ".$dbs->prefix().
"boxes as b, ".$dbs->prefix().
"boxes_def as d";
107 $sql .=
" WHERE b.box_id = d.rowid";
108 $sql .=
" AND b.entity IN (0,".$conf->entity.
")";
110 $sql .=
" AND b.position = ".((int) $zone);
112 if (is_object($user)) {
113 $sql .=
" AND b.fk_user IN (0,".$user->id.
")";
115 $sql .=
" AND b.fk_user = 0";
117 $sql .=
" ORDER BY b.box_order";
119 $sql =
"SELECT d.rowid as box_id, d.file, d.note, d.tms";
120 $sql .=
" FROM ".$dbs->prefix().
"boxes_def as d";
121 $sql .=
" WHERE d.entity IN (0, ".$conf->entity.
")";
124 dol_syslog(self::class.
"::listBoxes get default box list for mode=".$mode.
" userid=".(is_object($user) ? $user->id :
''), LOG_DEBUG);
125 $resql = $dbs->query($sql);
127 $num = $dbs->num_rows($resql);
130 $obj = $dbs->fetch_object($resql);
132 if (!in_array($obj->box_id, $excludelist)) {
134 if (preg_match(
'/^([^@]+)@([^@]+)$/i', $obj->file, $regs)) {
135 $boxname = preg_replace(
'/\.php$/i',
'', $regs[1]);
137 $relsourcefile =
"/".$module.
"/core/boxes/".$boxname.
".php";
139 $boxname = preg_replace(
'/\.php$/i',
'', $obj->file);
140 $relsourcefile =
"/core/boxes/".$boxname.
".php";
149 if (class_exists($boxname)) {
150 $box =
new $boxname($dbs, $obj->note);
151 '@phan-var-force ModeleBoxes $box';
155 $box->rowid = (empty($obj->rowid) ?
'' : $obj->rowid);
156 $box->id = (empty($obj->box_id) ?
'' : $obj->box_id);
157 $box->position = ((isset($obj->position) && $obj->position ==
'') ?
'' : (isset($obj->position) ? $obj->position :
''));
158 $box->box_order = (empty($obj->box_order) ?
'' : $obj->box_order);
159 $box->fk_user = (empty($obj->fk_user) ? 0 : $obj->fk_user);
160 $box->sourcefile = $relsourcefile;
161 $box->class = $boxname;
163 if ($mode ==
'activated' && !is_object($user)) {
164 if (is_numeric($box->box_order)) {
165 if (((
int) $box->box_order % 2) == 1) {
166 $box->box_order =
'A'.$box->box_order;
167 } elseif (((
int) $box->box_order % 2) == 0) {
168 $box->box_order =
'B'.$box->box_order;
173 $box->box_id = (empty($obj->box_id) ?
'' : $obj->box_id);
174 $box->note = (empty($obj->note) ?
'' : $obj->note);
178 $enabled = $box->enabled;
179 if (isset($box->depends) && count($box->depends) > 0) {
180 foreach ($box->depends as $moduleelem) {
181 $arrayelem = explode(
'|', $moduleelem);
183 foreach ($arrayelem as $module) {
184 $tmpmodule = preg_replace(
'/@[^@]+/',
'', $module);
190 if (empty($tmpenabled)) {
199 if ($enabled && ($includehidden || empty($box->hidden))) {
205 dol_syslog(
"Failed to load box '".$boxname.
"' into file '".$relsourcefile.
"'", LOG_WARNING);
212 return array(
'error' => $dbs->lasterror());
228 public static function saveboxorder($dbs, $zone, $boxorder, $userid = 0)
234 require_once DOL_DOCUMENT_ROOT.
'/core/lib/functions2.lib.php';
236 dol_syslog(self::class.
"::saveboxorder zone=".$zone.
" userid=".$userid);
238 if (!$userid || $userid == 0) {
242 $user =
new User($dbs);
249 $confuserzone =
'MAIN_BOXES_'.$zone;
250 $tab[$confuserzone] =
'1';
252 $error = $dbs->lasterror();
257 if (!is_numeric($zone)) {
262 $sql =
"DELETE FROM ".$dbs->prefix().
"boxes";
263 $sql .=
" WHERE entity = ".$conf->entity;
264 $sql .=
" AND fk_user = ".((int) $userid);
265 $sql .=
" AND position = ".((int) $zone);
267 dol_syslog(self::class.
"::saveboxorder", LOG_DEBUG);
268 $result = $dbs->query($sql);
270 $colonnes = explode(
'-', $boxorder);
271 foreach ($colonnes as $collist) {
272 $part = explode(
':', $collist);
275 dol_syslog(self::class.
"::saveboxorder column=".$colonne.
' list='.$list);
278 $listarray = explode(
',', $list);
279 foreach ($listarray as
$id) {
280 if (is_numeric(
$id)) {
283 $ii = sprintf(
'%02d', $i);
285 $sql =
"INSERT INTO ".$dbs->prefix().
"boxes";
286 $sql .=
"(box_id, position, box_order, fk_user, entity)";
288 $sql .=
" ".((int)
$id).
",";
289 $sql .=
" ".((int) $zone).
",";
290 $sql .=
" '".$dbs->escape($colonne.$ii).
"',";
291 $sql .=
" ".((int) $userid).
",";
292 $sql .=
" ".((int) $conf->entity);
295 $result = $dbs->query($sql);