2 /*=====================================================================*\
3 || ################################################################### ||
4 || # BugStrike [#]version[#]
5 || # --------------------------------------------------------------- # ||
6 || # Copyright ©2002-[#]year[#] by Iris Studios, Inc. All Rights Reserved. # ||
7 || # This file may not be reproduced in any way without permission. # ||
8 || # --------------------------------------------------------------- # ||
9 || # User License Agreement at http://www.iris-studios.com/license/ # ||
10 || ################################################################### ||
11 \*=====================================================================*/
13 $fetchtemplates = array(
19 require_once('./global.php');
21 $bug = $db->query_first("SELECT * FROM " . TABLE_PREFIX
. "bug WHERE bugid = " . intval($bugsys->in
['bugid']));
24 $message->error('alert: bad bug');
27 if ($bug['hidden'] AND !can_perform('canviewhidden'))
29 $message->error_permission();
32 // ###################################################################
34 $customfields = $db->query("
36 FROM " . TABLE_PREFIX
. "bugfield AS bugfield
37 LEFT JOIN " . TABLE_PREFIX
. "bugfieldpermission AS permission
38 ON (bugfield.fieldid = permission.fieldid)
39 WHERE permission.mask <> 0
40 AND permission.usergroupid = {$bugsys->userinfo['usergroupid']}"
43 while ($field = $db->fetch_array($customfields))
45 $fieldlist["custom_field$field[fieldid]"] = 'custom_field' . $field['fieldid'] . " (\"$field[name]\")";
48 // ###################################################################
50 $logs_fetch = $db->query("
51 SELECT history.*, user.userid, user.email, user.displayname, user.showemail
52 FROM " . TABLE_PREFIX
. "history AS history
53 LEFT JOIN " . TABLE_PREFIX
. "user AS user
54 ON (user.userid = history.userid)
55 WHERE bugid = $bug[bugid]"
57 while ($log = $db->fetch_array($logs_fetch))
59 $log['formatted'] = call_user_func_array('phrase', array_merge(array($log['language']), unserialize($log['arguments'])));
60 $log['date'] = datelike('standard', $log['dateline']);
61 $log['user'] = construct_user_display($log);
63 $logs["$log[dateline]"]["$log[historyid]"] = $log;
64 ksort($logs["$log[dateline]"]);
69 foreach ($logs AS $dateline => $logitems)
73 $show['changes'] = false
;
75 foreach ($logitems AS $log)
77 $hasvalues = ((empty($log['original']) AND (empty($log['changed']) AND $log['changed'] != 0)) ? false
: true
);
79 if ($newlog = $fieldlist["$log[field]"])
81 $log['field'] = $newlog;
84 $show['changes'] = (($hasvalues) ? true
: $show['changes']);
89 eval('$changes .= "' . $template->fetch('history_bit') . '";');
92 if (!in_array($log['formatted'], $messages))
94 $messages[] = $log['formatted'];
98 $log['messages'] = implode("</div>\n<div>", $messages);
100 eval('$history .= "' . $template->fetch('history_group') . '";');
103 eval('$template->flush("' . $template->fetch('history') . '");');
105 /*=====================================================================*\
106 || ###################################################################
109 || ###################################################################
110 \*=====================================================================*/