df6333530f313c9c56f80583553b0fa0d2344f5a
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 require_once('./global.php');
15 if (!can_perform('canadminfields'))
21 'input_text' => 'Single-Line Text Box',
22 'textarea' => 'Multi-Line Text Area',
23 'input_checkbox' => 'Checkbox Flag',
24 'select_single' => 'Drop-Down Menu',
27 // ###################################################################
29 if (empty($_REQUEST['do']))
31 $_REQUEST['do'] = 'modify';
34 // ###################################################################
36 if ($_REQUEST['do'] == 'kill')
38 $field = $db->query_first("SELECT * FROM " . TABLE_PREFIX
. "bugfield WHERE fieldid = " . intval($bugsys->in
['fieldid']));
41 $admin->error(phrase('error_invalid_id'));
44 $db->query("DELETE FROM " . TABLE_PREFIX
. "bugfield WHERE fieldid = $field[fieldid]");
45 $db->query("ALTER TABLE " . TABLE_PREFIX
. "bugvaluefill DROP $field[shortname]");
46 $db->query("OPTIMIZE TABLE " . TABLE_PREFIX
. "bugvaluefill");
48 $admin->redirect('fields.php?do=modify', 'The field has been successfully removed from the system.');
51 // ###################################################################
53 if ($_REQUEST['do'] == 'delete')
55 $field = $db->query_first("SELECT * FROM " . TABLE_PREFIX
. "bugfield WHERE fieldid = " . intval($bugsys->in
['fieldid']));
58 $admin->error(phrase('error_invalid_id'));
61 $admin->page_confirm('Are you sure you want to delete this bug field? Doing so will remove everything for this field and it cannot be undone!', "fields.php?do=kill&fieldid=$field[fieldid]");
64 // ###################################################################
66 if ($_REQUEST['do'] == 'update')
71 $type = $bugsys->in
['type'];
73 if ($bugsys->in
['fieldid'])
75 $field = $db->query_first("SELECT * FROM " . TABLE_PREFIX
. "bugfield WHERE fieldid = " . intval($bugsys->in
['fieldid']));
78 $admin->error(phrase('error_invalid_id'));
83 $type = $field['type'];
86 if (empty($bugsys->in
['shortname']) AND $add)
88 $admin->error('You must specify a short name/call name.');
90 if ((preg_match('#[^a-z0-9_]#', $bugsys->in
['shortname']) OR !preg_match('#^[a-z]#', $bugsys->in
['shortname']) OR preg_match('#[^a-z0-9]$#', $bugsys->in
['shortname'])) AND $add)
92 $admin->error('The short name can only contain lowercase letters, numbers, and underscores; it must also begin with a letter and cannot end in anything but a letter or a number.');
95 if (empty($bugsys->in
['name']))
97 $admin->error('You must specify a display name.');
99 if (!isset($TYPES["$type"]) AND $add)
101 $admin->error('Invalid field type specified.');
108 $extrafields = 'defaultvalue, regexmatch, maxlength';
109 $extradata = "'" . $bugsys->in
['defaultvalue'] . "', '" . $bugsys->in
['regexmatch'] . "', " . intval($bugsys->in
['maxlength']);
110 $extraupdate = "defaultvalue = '" . $bugsys->in
['defaultvalue'] . "', regexmatch = '" . $bugsys->in
['regexmatch'] . "', maxlength = " . intval($bugsys->in
['maxlength']);
113 case 'input_checkbox':
114 $extrafields = 'defaultvalue';
115 $extradata = intval($bugsys->in
['defaultvalue']);
116 $extraupdate = "defaultvalue = " . intval($bugsys->in
['defaultvalue']);
119 case 'select_single':
120 $extrafields = 'selects, usedefault';
122 // can't use explode() here because explode() returns !empty() when splitting an empty string
123 // so we have to use preg_split with the PREG_SPLIT_NO_EMPTY flag to prevent this
124 $selects = preg_split("#\n#", trim($bugsys->in
['selects']), 0, PREG_SPLIT_NO_EMPTY
);
125 array_walk($selects, 'trim');
126 if (count($selects) < 1)
128 $admin->error('You need to specify some select values.');
131 $extradata = "'" . $bugsys->escape(serialize($selects)) . "', " . intval($bugsys->in
['usedefault']);
132 $extraupdate = "selects = '" . $bugsys->escape(serialize($selects)) . "', usedefault = " . intval($bugsys->in
['usedefault']);
138 if ($db->query_first("SELECT * FROM " . TABLE_PREFIX
. "bugfield WHERE shortname = '" . $bugsys->in
['shortname'] . "'") OR $bugsys->in
['shortname'] == 'bugid')
140 $admin->error('That short name is already in use, please change it so it is unique.');
145 (shortname, name, description, type, required, private, $extrafields)
147 ('" . $bugsys->in
['shortname'] . "', '" . $bugsys->in
['name'] . "',
148 '" . $bugsys->in
['description'] . "', '$type', " . intval($bugsys->in
['required']) . ",
149 " . intval($bugsys->in
['private']) . ", $extradata
153 $db->query("ALTER TABLE " . TABLE_PREFIX
. "bugvaluefill ADD " . $bugsys->in
['shortname'] . " MEDIUMTEXT NULL");
154 $db->query("OPTIMIZE TABLE " . TABLE_PREFIX
. "bugvaluefill");
159 UPDATE " . TABLE_PREFIX
. "bugfield
160 SET name = '" . $bugsys->in
['name'] . "',
161 description = '" . $bugsys->in
['description'] . "',
162 required = " . intval($bugsys->in
['required']) . ",
163 private = " . intval($bugsys->in
['private']) . ",
165 WHERE fieldid = " . intval($bugsys->in
['fieldid'])
169 $admin->redirect('fields.php?do=modify', (($add) ?
'The custom bug field has been added.' : 'The bug field has been updated.'));
172 // ###################################################################
174 if ($_REQUEST['do'] == 'add' OR $_REQUEST['do'] == 'edit')
176 $add = (($_REQUEST['do'] == 'add') ? true
: false
);
177 $typeselect = (($add AND empty($bugsys->in
['step'])) ? true
: false
);
178 $edit = (($add) ? false
: true
);
180 $admin->page_start(phrase((($add) ?
'add_new_field' : 'edit_field')));
181 $admin->form_start('fields.php', (($typeselect) ?
'add' : 'update'));
182 if ($add AND !$typeselect)
184 $admin->form_hidden_field('type', $bugsys->in
['type']);
188 $admin->form_hidden_field('step', 1);
189 $admin->table_start(true
, '40%');
190 $admin->table_head('Select Type');
194 $admin->table_start();
195 $admin->table_head((($add) ?
phrase('add_new_field') . ' - ' . $TYPES[ $bugsys->in
['type'] ] : phrase('edit_field')));
200 $field = $db->query_first("SELECT * FROM " . TABLE_PREFIX
. "bugfield WHERE fieldid = " . intval($bugsys->in
['fieldid']));
203 $admin->error(phrase('error_invalid_id'));
206 $admin->form_hidden_field('fieldid', $field['fieldid']);
211 $type = (($add) ?
$bugsys->in
['type'] : $field['type']);
214 // show type selector
215 if (empty($bugsys->in
['step']) AND $add)
217 foreach ($TYPES AS $name => $description)
219 $admin->list_item($description, $name);
221 $admin->row_list('Select field type', 'type', false
);
223 $admin->row_submit();
226 // have type, do that funkay thing!
229 if (!isset($TYPES["$type"]))
231 $admin->error(phrase('error_invalid_id'));
235 $admin->row_span('Global Fields', 'thead', 'center');
236 $admin->row_text('Field Type', $TYPES["$type"]);
237 $admin->row_input('Short Name/Call Name', 'shortname', $field['shortname']);
238 $admin->row_input('Display Name', 'name', $field['name']);
239 $admin->row_textarea('Description', 'description', $field['description']);
240 $admin->row_yesno('Required', 'required', $field['required']);
241 $admin->row_yesno('Private Field', 'private', $field['private']);
243 // type-specific fields
244 $admin->row_span('Type-Specific Fields', 'thead', 'center');
249 $admin->row_input('Default Value', 'defaultvalue', $field['defaultvalue']);
250 $admin->row_input('Regular Expression Match', 'regexmatch', $field['regexmatch']);
251 $admin->row_input('Maximum Length', 'maxlength', $field['maxlength'], 2, 10);
255 $admin->row_textarea('Default Value', 'defaultvalue', $field['defaultvalue']);
256 $admin->row_input('Regular Expression Match', 'regexmatch', $field['regexmatch']);
257 $admin->row_input('Maximum Length', 'maxlength', $field['maxlength'], 2, 10);
260 case 'input_checkbox':
261 $admin->row_yesno('Checked By Default', 'defaultvalue', $field['defaultvalue']);
264 case 'select_single':
265 $admin->row_textarea('Selection Values', 'selects', implode("\n", unserialize($field['selects'])));
266 $admin->row_yesno('Make the First Option Default', 'usedefault', $field['usedefault']);
271 $admin->row_submit((($edit) ?
'<a href="fields.php?do=delete&fieldid=' . $field['fieldid'] . '">[Delete Field]</a>' : ''));
279 // ###################################################################
281 if ($_REQUEST['do'] == 'modify')
283 $admin->page_start(phrase('additional_bug_fields'));
285 $admin->table_start();
286 $admin->table_head(phrase('additional_bug_fields'), 3);
287 $admin->table_column_head(array('Display Name/Description', 'Short Name/Field ID', 'Actions'));
289 $fields = $db->query("SELECT * FROM " . TABLE_PREFIX
. "bugfield ORDER BY fieldid ASC");
290 while ($field = $db->fetch_array($fields))
292 $admin->row_multi_item(
294 "$field[name]<div class=\"smallfont\"><em>$field[description]</em></div>" => 'l',
295 "$field[shortname] (fieldid: $field[fieldid])" => 'c',
296 "<a href=\"fields.php?do=edit&fieldid=$field[fieldid]\">[Edit]</a> <a href=\"fields.php?do=delete&fieldid=$field[fieldid]\">[Delete]</a>" => 'c'
301 $admin->row_span('<input type="button" name="addug" value=" ' . phrase('add_new_field') . ' " onclick="window.location = \'fields.php?do=add\';" />', 'tfoot', 'center', 3);
307 /*=====================================================================*\
308 || ###################################################################
311 || ###################################################################
312 \*=====================================================================*/