]>
src.bluestatic.org Git - bugdar.git/blob - admin/fields.php
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 NOT 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 \*=====================================================================*/