2 /*=====================================================================*\
3 || ###################################################################
4 || # Bugdar [#]version[#]
5 || # Copyright ©2002-[#]year[#] Iris Studios, Inc.
7 || # This program is free software; you can redistribute it and/or modify
8 || # it under the terms of the GNU General Public License as published by
9 || # the Free Software Foundation; version [#]gpl[#] of the License.
11 || # This program is distributed in the hope that it will be useful, but
12 || # WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
13 || # or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
16 || # You should have received a copy of the GNU General Public License along
17 || # with this program; if not, write to the Free Software Foundation, Inc.,
18 || # 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
19 || ###################################################################
20 \*=====================================================================*/
22 require_once('./global.php');
23 require_once('./includes/functions_datastore.php');
25 NavLinks
::fieldsPages();
26 $navigator->set_focus('tab', 'fields', null
);
28 if (!can_perform('canadminbugs'))
33 // ###################################################################
35 if (empty($_REQUEST['do']))
37 $_REQUEST['do'] = 'modify';
40 // ###################################################################
42 if ($_REQUEST['do'] == 'kill')
44 $action = $db->query_first("SELECT * FROM " . TABLE_PREFIX
. "autoaction WHERE actionid = " . $bugsys->input_clean('actionid', TYPE_UINT
));
47 $admin->error($lang->getlex('error_invalid_id'));
50 $db->query("DELETE FROM " . TABLE_PREFIX
. "autoaction WHERE actionid = $action[actionid]");
54 $admin->redirect('autoaction.php?do=modify');
57 // ###################################################################
59 if ($_REQUEST['do'] == 'delete')
61 $action = $db->query_first("SELECT * FROM " . TABLE_PREFIX
. "autoaction WHERE actionid = " . $bugsys->input_clean('actionid', TYPE_UINT
));
64 $admin->error($lang->getlex('error_invalid_id'));
67 $admin->page_confirm($lang->string('Are you sure you want to delete this action?'), "autoaction.php?do=kill&actionid=$action[actionid]");
70 // ###################################################################
72 if ($_POST['do'] == 'insert' OR $_POST['do'] == 'update')
74 if (empty($bugsys->in
['name']))
76 $admin->error($lang->string('You need to specify a name for this action.'));
79 foreach ($bugsys->in
['fields'] AS $key => $value)
81 if (!empty($value) AND $value != -1 AND !is_array($value))
83 $deltas['builtin']["$key"] = $value;
87 foreach ($bugsys->in
['fields']['custom'] AS $key => $value)
89 if (!empty($value) AND $value != -1)
91 $deltas['custom']["$key"] = $value;
95 if (sizeof($deltas['custom']) < 1 AND sizeof($deltas['builtin']) < 1)
97 $admin->error($lang->string('You need to specify some fields to change.'));
100 if ($_POST['do'] == 'insert')
103 INSERT INTO " . TABLE_PREFIX
. "autoaction
104 (name, description, fieldchanges, comment)
106 ('" . $bugsys->in
['name'] . "', '" . $bugsys->in
['description'] . "',
107 '" . $bugsys->escape(serialize($deltas)) . "', '" . $bugsys->in
['comment'] . "'
111 build_auto_actions();
113 $admin->redirect('autoaction.php');
117 if (!$bugsys->in
['actionid'])
119 $admin->error($lang->getlex('error_invalid_id'));
123 UPDATE " . TABLE_PREFIX
. "autoaction
124 SET name = '" . $bugsys->in
['name'] . "',
125 description = '" . $bugsys->in
['description'] . "',
126 fieldchanges = '" . $bugsys->escape(serialize($deltas)) . "',
127 comment = '" . $bugsys->in
['comment'] . "'
128 WHERE actionid = " . $bugsys->input_clean('actionid', TYPE_UINT
)
131 build_auto_actions();
133 $admin->redirect('autoaction.php');
137 // ###################################################################
139 if ($_REQUEST['do'] == 'add' OR $_REQUEST['do'] == 'edit')
141 $add = (($_REQUEST['do'] == 'add') ? true
: false
);
142 $edit = (($add) ? false
: true
);
146 NavLinks
::autoactionsEdit($bugsys->in
['actionid']);
147 $navigator->set_focus('link', 'fields-pages-autoactions', 'fields-pages');
149 $action = $db->query_first("SELECT * FROM " . TABLE_PREFIX
. "autoaction WHERE actionid = " . $bugsys->input_clean('actionid', TYPE_UINT
));
152 $admin->error($lang->getlex('error_invalid_id'));
154 $action['fields'] = unserialize($action['fieldchanges']);
158 NavLinks
::autoactionsAdd();
159 $navigator->set_focus('link', 'autoactions-add', 'autoactions');
162 $admin->page_start(($add ?
$lang->string('New Automatic Action') : $lang->string('Edit Automatic Action')));
164 $admin->form_start('autoaction.php', ($add ?
'insert' : 'update'));
168 $admin->form_hidden_field('actionid', $action['actionid']);
171 $admin->table_start();
172 $admin->table_head(($add ?
$lang->string('New Automatic Action') : $lang->string('Edit Automatic Action')), 2, 'automatic_actions');
174 $admin->row_input($lang->string('Name'), 'name', $action['name']);
175 $admin->row_textarea($lang->string('Description'), 'description', $action['description']);
176 $admin->row_textarea($lang->string('Add Comment'), 'comment', $action['comment']);
178 $admin->row_span($lang->string('Field Changes'), 'thead', 'center');
180 // -------------------------------------------------------------------
182 construct_datastore_select('severity', 'severity', 'severityid', $action['fields']['builtin']['severity'], true
, true
);
183 $admin->row_list($lang->string('Severity'), 'fields[severity]');
185 construct_datastore_select('priority', 'priority', 'priorityid', $action['fields']['builtin']['priority'], true
, true
);
186 $admin->row_list($lang->string('Priority'), 'fields[priority]');
188 construct_datastore_select('status', 'status', 'statusid', $action['fields']['builtin']['status'], true
, true
);
189 $admin->row_list($lang->string('Status'), 'fields[status]');
191 construct_datastore_select('resolution', 'resolution', 'resolutionid', $action['fields']['builtin']['resolution'], true
, true
);
192 $admin->row_list($lang->string('Resolution'), 'fields[resolution]');
194 $admin->row_span('', 'tcat', 'center');
196 // -------------------------------------------------------------------
198 $fields_fetch = $bugsys->db
->query("
200 FROM " . TABLE_PREFIX
. "bugfield AS bugfield
201 LEFT JOIN " . TABLE_PREFIX
. "bugfieldpermission AS permission
202 ON (bugfield.fieldid = permission.fieldid)
203 WHERE permission.mask <> 0
204 AND permission.usergroupid = {$bugsys->userinfo['usergroupid']}
205 AND bugfield.cansearch = 1"
207 while ($field = $bugsys->db
->fetch_array($fields_fetch))
209 switch ($field['type'])
212 $admin->row_input($field['name'], "fields[custom][$field[fieldid]]", $action['fields']['custom']["$field[fieldid]"]);
215 case 'input_checkbox':
216 $admin->list_item('', 0, ((!$action['fields']['custom']["$field[fieldid]"]) ? true
: false
));
217 $admin->list_item($lang->string('Checked'), 1, (($action['fields']['custom']["$field[fieldid]"] == 1) ? true
: false
));
218 $admin->list_item($lang->string('Un-Checked'), 2, (($action['fields']['custom']["$field[fieldid]"] == 2) ? true
: false
));
219 $admin->row_list($field['name'], "fields[custom][$field[fieldid]]");
222 case 'select_single':
223 $selectopts = unserialize($field['selects']);
225 $admin->list_item('', -1, ((!$action['fields']['custom']["$field[fieldid]"]) ? true
: false
));
227 foreach ($selectopts AS $id => $select)
229 $admin->list_item(stripslashes($select), $id, (($action['fields']['custom']["$field[fieldid]"] == $id AND $edit) ? true
: false
));
231 $admin->row_list($field['name'], "fields[custom][$field[fieldid]]");
237 $admin->row_submit();
244 // ###################################################################
246 if ($_REQUEST['do'] == 'modify')
248 NavLinks
::autoactionsAdd();
249 $navigator->set_focus('link', 'fields-pages-autoactions', 'fields-pages');
251 $admin->page_start($lang->string('Automatic Actions'));
253 $admin->table_start();
254 $admin->table_head($lang->string('Automatic Actions'), 2, 'automatic_actions');
256 $actions = $db->query("SELECT * FROM " . TABLE_PREFIX
. "autoaction ORDER BY name ASC");
257 while ($action = $db->fetch_array($actions))
259 $admin->row_text($action['name'] . "\n<div class=\"smallfont\">$action[description]</div>", "<a href=\"autoaction.php?do=edit&actionid=$action[actionid]\">[" . $lang->string('Edit') . "]</a> <a href=\"autoaction.php?do=delete&actionid=$action[actionid]\">[" . $lang->string('Delete') . "]</a>");
267 /*=====================================================================*\
268 || ###################################################################
271 || ###################################################################
272 \*=====================================================================*/