]>
src.bluestatic.org Git - bugdar.git/blob - admin/field.php
2 /*=====================================================================*\
3 || ################################################################### ||
4 || # Bugdar [#]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' );
14 require_once ( './includes/functions_datastore.php' );
16 if (! can_perform ( 'canadminfields' ))
22 'input_text' => $lang- > string ( 'Single-Line Text Box' ),
23 'input_checkbox' => $lang- > string ( 'Checkbox Flag' ),
24 'select_single' => $lang- > string ( '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 ( $lang- > getlex ( 'error_invalid_id' ));
44 $db- > query ( "DELETE FROM " . TABLE_PREFIX
. "bugfield WHERE fieldid = $field [fieldid]" );
45 $db- > query ( "DELETE FROM " . TABLE_PREFIX
. "bugfieldpermission WHERE fieldid = $field [fieldid]" );
46 $db- > query ( "ALTER TABLE " . TABLE_PREFIX
. "bugvaluefill DROP field $field [fieldid]" );
47 $db- > query ( "OPTIMIZE TABLE " . TABLE_PREFIX
. "bugvaluefill" );
51 $admin- > redirect ( 'field.php?do=modify' );
54 // ###################################################################
56 if ( $_REQUEST [ 'do' ] == 'delete' )
58 $field = $db- > query_first ( "SELECT * FROM " . TABLE_PREFIX
. "bugfield WHERE fieldid = " . intval ( $bugsys- > in
[ 'fieldid' ]));
61 $admin- > error ( $lang- > getlex ( 'error_invalid_id' ));
64 $admin- > page_confirm ( $lang- > string ( 'Are you sure you want to delete this bug field? Doing so will remove everything for this field and it cannot be undone!' ), "field.php?do=kill&fieldid= $field [fieldid]" );
67 // ###################################################################
69 if ( $_REQUEST [ 'do' ] == 'update' )
74 $type = $bugsys- > in
[ 'type' ];
76 if ( $bugsys- > in
[ 'fieldid' ])
78 $field = $db- > query_first ( "SELECT * FROM " . TABLE_PREFIX
. "bugfield WHERE fieldid = " . intval ( $bugsys- > in
[ 'fieldid' ]));
81 $admin- > error ( $lang- > getlex ( 'error_invalid_id' ));
86 $type = $field [ 'type' ];
89 if ( empty ( $bugsys- > in
[ 'name' ]))
91 $admin- > error ( $lang- > string ( 'You must specify a display name.' ));
93 if (! isset ( $TYPES [ " $type" ]) AND $add )
95 $admin- >error( $lang- >string('Invalid field type specified.'));
101 $extrafields = 'defaultvalue, regexmatch, maxlength';
102 $extradata = " '" . $bugsys- >in[' defaultvalue
'] . "' , '" . $bugsys- >in[' regexmatch
'] . "' , " . intval( $bugsys- >in['maxlength']);
103 $extraupdate = " defaultvalue
= '" . $bugsys- >in[' defaultvalue
'] . "' , regexmatch
= '" . $bugsys- >in[' regexmatch
'] . "' , maxlength
= " . intval( $bugsys- >in['maxlength']);
106 case 'input_checkbox':
107 $extrafields = 'defaultvalue';
108 $extradata = intval( $bugsys- >in['defaultvalue']);
109 $extraupdate = " defaultvalue
= " . intval( $bugsys- >in['defaultvalue']);
112 case 'select_single':
113 $extrafields = 'selects, usedefault';
115 // can't use explode() here because explode() returns !empty() when splitting an empty string
116 // so we have to use preg_split with the PREG_SPLIT_NO_EMPTY flag to prevent this
117 $selects = preg_split(" #\n#", trim($bugsys->in['selects']), 0, PREG_SPLIT_NO_EMPTY);
118 array_walk ( $selects , 'trim' );
119 if ( count ( $selects ) < 1 )
121 $admin- > error ( $lang- > string ( 'You need to specify some select values.' ));
124 $extradata = "'" . $bugsys- > escape ( serialize ( $selects )) . "', " . intval ( $bugsys- > in
[ 'usedefault' ]);
125 $extraupdate = "selects = '" . $bugsys- > escape ( serialize ( $selects )) . "', usedefault = " . intval ( $bugsys- > in
[ 'usedefault' ]);
132 INSERT INTO " . TABLE_PREFIX
. "bugfield
133 (name, description, type, required, cansearch, $extrafields )
135 ('" . $bugsys- > in
[ 'name' ] . "',
136 '" . $bugsys- > in
[ 'description' ] . "', ' $type' , " . intval ( $bugsys- > in
[ 'required' ]) . ",
137 " . intval ( $bugsys- > in
[ 'cansearch' ]) . ", $extradata
141 $fieldid = $db- > insert_id ();
143 $db- > query ( "ALTER TABLE " . TABLE_PREFIX
. "bugvaluefill ADD field $fieldid MEDIUMTEXT NULL" );
144 $db- > query ( "OPTIMIZE TABLE " . TABLE_PREFIX
. "bugvaluefill" );
149 UPDATE " . TABLE_PREFIX
. "bugfield
150 SET name = '" . $bugsys- > in
[ 'name' ] . "',
151 description = '" . $bugsys- > in
[ 'description' ] . "',
152 required = " . intval ( $bugsys- > in
[ 'required' ]) . ",
153 cansearch = " . intval ( $bugsys- > in
[ 'cansearch' ]) . ",
155 WHERE fieldid = " . intval ( $bugsys- > in
[ 'fieldid' ])
158 $fieldid = intval ( $bugsys- > in
[ 'fieldid' ]);
161 foreach ( $bugsys- > in
[ 'custom' ] AS $usergroupid => $mask )
163 $values [] = intval ( $usergroupid ) . ", $fieldid , " . intval ( $mask );
167 REPLACE INTO " . TABLE_PREFIX
. "bugfieldpermission
168 (usergroupid, fieldid, mask)
170 (" . implode ( "), \n\t\t\t (" , $values ) . ")"
175 $admin- > redirect ( 'field.php?do=modify' , ( $add ? $lang- > string ( 'The custom field has been added' ) : $lang- > string ( 'The custom field has been updated' )));
178 // ###################################################################
180 if ( $_REQUEST [ 'do' ] == 'add' OR $_REQUEST [ 'do' ] == 'edit' )
182 $add = (( $_REQUEST [ 'do' ] == 'add' ) ? true : false );
183 $typeselect = (( $add AND empty ( $bugsys- > in
[ 'step' ])) ? true : false );
184 $edit = (( $add ) ? false : true );
186 $admin- > page_start (( $add ? $lang- > string ( 'Add New Custom Field' ) : $lang- > string ( 'Edit Custom Field' )));
187 $admin- > form_start ( 'field.php' , ( $typeselect ? 'add' : 'update' ));
188 if ( $add AND ! $typeselect )
190 $admin- > form_hidden_field ( 'type' , $bugsys- > in
[ 'type' ]);
194 $admin- > form_hidden_field ( 'step' , 1 );
195 $admin- > table_start ( true , '40%' );
196 $admin- > table_head ( $lang- > string ( 'Select Type' ), 2 , 'custom_bug_fields' );
200 $admin- > table_start ();
201 $admin- > table_head (( $add ? $lang- > string ( 'Add New Bug Field' ) . ' - ' . $TYPES [ $bugsys- > in
[ 'type' ] ] : $lang- > string ( 'Edit Field' )), 2 , 'custom_bug_fields_options' );
206 $field = $db- > query_first ( "SELECT * FROM " . TABLE_PREFIX
. "bugfield WHERE fieldid = " . intval ( $bugsys- > in
[ 'fieldid' ]));
209 $admin- > error ( $lang- > getlex ( 'error_invalid_id' ));
212 $admin- > form_hidden_field ( 'fieldid' , $field [ 'fieldid' ]);
217 $type = (( $add ) ? $bugsys- > in
[ 'type' ] : $field [ 'type' ]);
220 // show type selector
221 if ( empty ( $bugsys- > in
[ 'step' ]) AND $add )
223 foreach ( $TYPES AS $name => $description )
225 $admin- > list_item ( $description , $name );
227 $admin- > row_list ( $lang- > string ( 'Field Type' ), 'type' , false );
229 $admin- > row_submit ();
232 // have type, do that funkay thing!
235 if (! isset ( $TYPES [ " $type" ]))
237 $admin- >error( $lang- >getlex('error_invalid_id'));
241 $admin- >row_span( $lang- >string('Global Fields'), 'thead', 'center');
242 $admin- >row_text( $lang- >string('Field Type'), $TYPES [" $type" ]);
243 $admin- > row_input ( $lang- > string ( 'Display Name' ), 'name' , $field [ 'name' ]);
244 $admin- > row_textarea ( $lang- > string ( 'Description' ), 'description' , $field [ 'description' ]);
245 $admin- > row_yesno ( $lang- > string ( 'Required' ), 'required' , $field [ 'required' ]);
246 $admin- > row_yesno ( $lang- > string ( 'Can Be Searched' ), 'cansearch' , (( isset ( $field [ 'cansearch' ])) ? $field [ 'cansearch' ] : true ));
248 // type-specific fields
249 $admin- > row_span ( $lang- > string ( 'Type-Specific Fields' ), 'thead' , 'center' );
254 $admin- > row_input ( $lang- > string ( 'Default Value' ), 'defaultvalue' , $field [ 'defaultvalue' ]);
255 $admin- > row_input ( $lang- > string ( 'Regular Expression Match' ), 'regexmatch' , $field [ 'regexmatch' ]);
256 $admin- > row_input ( $lang- > string ( 'Maximum Length' ), 'maxlength' , $field [ 'maxlength' ], 2 , 10 );
259 case 'input_checkbox' :
260 $admin- > row_yesno ( $lang- > string ( 'Checked By Default' ), 'defaultvalue' , $field [ 'defaultvalue' ]);
263 case 'select_single' :
264 $admin- > row_textarea ( $lang- > string ( 'Selection Values' ), 'selects' , stripslashes ( implode ( " \n " , unserialize ( $field [ 'selects' ]))));
265 $admin- > row_yesno ( $lang- > string ( 'Make the First Option Default' ), 'usedefault' , $field [ 'usedefault' ]);
271 // custom field permissions
272 $admin- > table_start ();
273 $admin- > table_head ( $lang- > string ( 'Custom Field Permissions' ));
277 $perms = $db- > query ( "SELECT usergroupid, mask FROM " . TABLE_PREFIX
. "bugfieldpermission WHERE fieldid = $field [fieldid]" );
278 while ( $perm = $db- > fetch_array ( $perms ))
280 $permissions [ " $perm [usergroupid]" ] = $perm [ 'mask' ];
284 $usergroups = $db- > query ( "SELECT * FROM " . TABLE_PREFIX
. "usergroup ORDER BY usergroupid" );
285 while ( $usergroup = $db- > fetch_array ( $usergroups ))
288 $admin- > list_item ( $lang- > string ( 'No Permission' ), 0 , $permissions [ " $usergroup [usergroupid]" ] == 0 );
289 $admin- > list_item ( $lang- > string ( 'Can View Field' ), 1 , $permissions [ " $usergroup [usergroupid]" ] == 1 );
290 $admin- > list_item ( $lang- > string ( 'Can View, Edit Field' ), 2 , $permissions [ " $usergroup [usergroupid]" ] == 2 );
291 $admin- > row_list ( $usergroup [ 'title' ], "custom[ $usergroup [usergroupid]]" );
297 $admin- > table_start ();
298 $admin- > row_submit ((( $edit ) ? '<a href="field.php?do=delete&fieldid=' . $field [ 'fieldid' ] . '">[' . $lang- > string ( 'Delete Field' ) . ']</a>' : '' ));
306 // ###################################################################
308 if ( $_REQUEST [ 'do' ] == 'modify' )
310 $admin- > page_start ( $lang- > string ( 'Additional Bug Fields' ));
312 $admin- > table_start ();
313 $admin- > table_head ( $lang- > string ( 'Additional Bug Fields' ), 3 , 'custom_bug_fields' );
314 $admin- > table_column_head ( array ( $lang- > string ( 'Display Name/Description' ), $lang- > string ( 'Field ID' ), $lang- > string ( 'Actions' )));
316 $fields = $db- > query ( "SELECT * FROM " . TABLE_PREFIX
. "bugfield ORDER BY fieldid ASC" );
317 while ( $field = $db- > fetch_array ( $fields ))
319 $admin- > row_multi_item (
321 " $field [name]<div class= \" smallfont \" ><em> $field [description]</em></div>" => 'l' ,
322 " $field [fieldid]" => 'c' ,
323 "<a href= \" field.php?do=edit&fieldid= $field [fieldid] \" >[" . $lang- > string ( 'Edit' ) . "]</a> <a href= \" field.php?do=delete&fieldid= $field [fieldid] \" >[" . $lang- > string ( 'Delete' ) . "]</a>" => 'c'
328 $admin- > row_span ( '<a href="field.php?do=add">[' . $lang- > string ( 'Add New Bug Field' ) . ']</a>' , 'tfoot' , 'center' , 3 );
334 /*=====================================================================*\
335 || ###################################################################
338 || ###################################################################
339 \*=====================================================================*/