2005-01-24 18:00:03 +00:00
< ?
2025-01-29 03:30:48 +00:00
/*
* This file is part of the 'Science Fair In A Box' project
* SFIAB Website : http :// www . sfiab . ca
*
* Copyright ( C ) 2005 Sci - Tech Ontario Inc < info @ scitechontario . org >
* Copyright ( C ) 2005 James Grant < james @ lightbox . org >
*
* This program is free software ; you can redistribute it and / or
* modify it under the terms of the GNU General Public
* License as published by the Free Software Foundation , version 2.
*
* This program is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the GNU
* General Public License for more details .
*
* You should have received a copy of the GNU General Public License
* along with this program ; see the file COPYING . If not , write to
* the Free Software Foundation , Inc . , 59 Temple Place - Suite 330 ,
* Boston , MA 02111 - 1307 , USA .
*/
2005-01-24 18:00:03 +00:00
?>
2004-12-20 16:35:15 +00:00
< ?
2025-01-29 03:30:48 +00:00
require ( '../common.inc.php' );
require_once ( '../user.inc.php' );
require_once ( '../helper.inc.php' );
user_auth_required ( 'committee' , 'config' );
$divisionr = null ;
if ( get_value_from_array ( $_GET , 'action' ) == 'edit' || get_value_from_array ( $_GET , 'action' ) == 'new' ) {
send_header ( get_value_from_array ( $_GET , 'action' ) == 'edit' ? 'Edit Division' : 'New Division' ,
array ( 'Committee Main' => 'committee_main.php' ,
'SFIAB Configuration' => 'config/index.php' ,
'Project Divisions' => 'config/divisions.php' ),
'project_divisions' );
} else {
send_header ( 'Project Divisions' ,
array ( 'Committee Main' => 'committee_main.php' ,
'SFIAB Configuration' => 'config/index.php' ),
'project_divisions' );
}
if ( get_value_from_array ( $_POST , 'action' ) == 'edit' ) {
if ( get_value_from_array ( $_POST , 'id' ) && get_value_from_array ( $_POST , 'division' )) {
2025-02-09 17:24:37 +00:00
$q = $pdo -> prepare ( " SELECT id FROM projectdivisions WHERE id=? AND year=? " );
$q -> execute ([ $_POST [ 'id' ], $config [ 'FAIRYEAR' ]]);
2025-01-29 03:30:48 +00:00
if ( $q -> rowCount () && $_POST [ 'saveid' ] != $_POST [ 'id' ]) {
echo error ( i18n ( 'Division ID %1 already exists' , array ( $_POST [ 'id' ]), array ( 'division ID' )));
} else {
$stmt = $pdo -> prepare ( 'UPDATE projectdivisions SET '
2025-02-09 17:24:37 +00:00
. " id=?, "
. " division=?, "
. " division_shortform=? "
. " WHERE id=? AND year=? " );
$stmt -> execute ([ $_POST [ 'id' ], stripslashes ( $_POST [ 'division' ]), stripslashes ( $_POST [ 'division_shortform' ]), $_POST [ 'saveid' ], $config [ 'FAIRYEAR' ]]);
2025-01-29 03:30:48 +00:00
// ###### Feature Specific - filtering divisions by category
if ( $config [ 'filterdivisionbycategory' ] == 'yes' ) {
2025-02-09 17:24:37 +00:00
$stmt = $pdo -> prepare ( " DELETE FROM projectcategoriesdivisions_link WHERE projectdivisions_id=? AND year=? " );
$stmt -> execute ([ $_POST [ 'saveid' ], $config [ 'FAIRYEAR' ]]);
2025-01-29 03:30:48 +00:00
if ( is_array ( $_POST [ 'divcat' ])) {
foreach ( $_POST [ 'divcat' ] as $tempcat ) {
2025-02-09 17:24:37 +00:00
$stmt = $pdo -> prepare ( 'INSERT INTO projectcategoriesdivisions_link (projectdivisions_id,projectcategories_id,year) VALUES (?,?,?)' );
$stmt -> execute ([ $_POST [ 'id' ], $tempcat , $config [ 'FAIRYEAR' ]]);
2006-02-06 17:22:25 +00:00
}
2006-02-01 16:29:08 +00:00
}
}
2025-01-29 03:30:48 +00:00
// ###########
echo happy ( i18n ( 'Division successfully saved' ));
2004-12-20 17:03:48 +00:00
}
2025-01-29 03:30:48 +00:00
} else {
echo error ( i18n ( 'All fields are required' ));
2004-12-20 17:03:48 +00:00
}
2025-01-29 03:30:48 +00:00
}
2004-12-20 17:03:48 +00:00
2025-01-29 03:30:48 +00:00
if ( get_value_from_array ( $_POST , 'action' ) == 'new' ) {
if ( get_value_from_array ( $_POST , 'id' ) && get_value_from_array ( $_POST , 'division' )) {
2025-02-09 17:24:37 +00:00
$q = $pdo -> prepare ( " SELECT id FROM projectdivisions WHERE id=? AND year=? " );
$q -> execute ([ $_POST [ 'id' ], $config [ 'FAIRYEAR' ]]);
2025-01-29 03:30:48 +00:00
if ( $q -> rowCount ()) {
echo error ( i18n ( 'Division ID %1 already exists' , array ( $_POST [ 'id' ]), array ( 'division ID' )));
} else {
2025-02-09 17:24:37 +00:00
$stmt = $pdo -> prepare ( 'INSERT INTO projectdivisions (id,division,division_shortform,year) VALUES (?,?,?,?)' );
$stmt -> execute ([ $_POST [ 'id' ], stripslashes ( $_POST [ 'division' ]), stripslashes ( $_POST [ 'division_shortform' ]), $config [ 'FAIRYEAR' ]]);
2025-01-29 03:30:48 +00:00
// ###### Feature Specific - filtering divisions by category
if ( $config [ 'filterdivisionbycategory' ] == 'yes' ) {
foreach ( $_POST [ 'divcat' ] as $tempcat ) {
2025-02-09 17:24:37 +00:00
$stmt = $pdo -> prepare ( 'INSERT INTO projectcategoriesdivisions_link (projectdivisions_id,projectcategories_id,year) VALUES (?,?)' );
$stmt -> execute ([ $tempcat , $conference [ 'id' ]]);
2006-02-01 16:29:08 +00:00
}
}
2025-01-29 03:30:48 +00:00
// #######
echo happy ( i18n ( 'Division successfully added' ));
2004-12-20 17:03:48 +00:00
}
2025-01-29 03:30:48 +00:00
} else {
echo error ( i18n ( 'All fields are required' ));
2004-12-20 17:03:48 +00:00
}
2025-01-29 03:30:48 +00:00
}
2004-12-20 17:03:48 +00:00
2025-01-29 03:30:48 +00:00
if ( get_value_from_array ( $_GET , 'action' ) == 'remove' && get_value_from_array ( $_GET , 'remove' )) {
// ###### Feature Specific - filtering divisions by category - not conditional, cause even if they have the filtering turned off..if any links
// for this division exist they should be deleted
2025-02-09 17:24:37 +00:00
$stmt = $pdo -> prepare ( " DELETE FROM projectcategoriesdivisions_link where projectdivisions_id=? AND year=? " );
$stmt -> execute ([ $_GET [ 'remove' ], $config [ 'FAIRYEAR' ]]);
$stmt = $pdo -> prepare ( " DELETE FROM projectdivisions WHERE id=? AND year=? " );
$stmt -> execute ([ $_GET [ 'remove' ], $config [ 'FAIRYEAR' ]]);
2025-01-29 03:30:48 +00:00
echo happy ( i18n ( 'Division successfully removed' ));
}
echo '<form method="post" action="' . $_SERVER [ 'PHP_SELF' ] . '">' ;
if ( ! get_value_from_array ( $_GET , 'action' ) == 'edit' || get_value_from_array ( $_GET , 'action' ) == 'new' )
echo '<a href="' . $_SERVER [ 'PHP_SELF' ] . '?action=new">' . i18n ( 'Add new division' ) . " </a> \n " ;
echo '<table class="summarytable">' ;
echo '<tr>' ;
echo '<th>' . i18n ( 'Division ID' ) . " </th> \n " ;
echo '<th>' . i18n ( 'Division Name' ) . " </th> \n " ;
echo '<th>' . i18n ( 'Short Form' ) . " </th> \n " ;
// ###### Feature Specific - filtering divisions by category
if ( $config [ 'filterdivisionbycategory' ] == 'yes' )
echo '<th>' . i18n ( 'Categories' ) . " </th> \n " ;
// #####
echo '<th>' . i18n ( 'Actions' ) . " </th> \n " ;
echo '</tr>' ;
if ( get_value_from_array ( $_GET , 'action' ) == 'edit' || get_value_from_array ( $_GET , 'action' ) == 'new' ) {
echo '<input type="hidden" name="action" value="' . get_value_from_array ( $_GET , 'action' ) . " \" > \n " ;
if ( get_value_from_array ( $_GET , 'action' ) == 'edit' ) {
echo '<input type="hidden" name="saveid" value="' . get_value_from_array ( $_GET , 'edit' ) . " \" > \n " ;
2025-02-09 17:24:37 +00:00
$q = $pdo -> prepare ( " SELECT * FROM projectdivisions WHERE id=? AND year=? " );
$q -> execute ([ get_value_from_array ( $_GET , 'edit' ), $config [ 'FAIRYEAR' ]]);
2025-01-29 03:30:48 +00:00
$divisionr = $q -> fetch ( PDO :: FETCH_OBJ );
$buttontext = 'Save' ;
} else if ( get_value_from_array ( $_GET , 'action' ) == 'new' ) {
$buttontext = 'Add' ;
2004-12-20 17:03:48 +00:00
}
2025-01-29 03:30:48 +00:00
echo '<tr>' ;
echo ' <td><input type="text" size="3" name="id" value="' . get_value_property_or_default ( $divisionr , 'id' ) . '" /></td>' ;
echo ' <td><input type="text" size="40" name="division" value="' . get_value_property_or_default ( $divisionr , 'division' ) . '" /></td>' ;
echo ' <td align="center"><input type="text" size="5" name="division_shortform" value="' . get_value_property_or_default ( $divisionr , 'division_shortform' ) . '" /></td>' ;
// ###### Feature Specific - filtering divisions by category
if ( $config [ 'filterdivisionbycategory' ] == 'yes' ) {
echo ' <td>' ;
2025-02-09 17:24:37 +00:00
$q = $pdo -> prepare ( " SELECT * FROM projectcategories WHERE year=? ORDER BY mingrade " );
$q -> execute ([ $config [ 'FAIRYEAR' ]]);
2025-01-29 03:30:48 +00:00
while ( $categoryr = $q -> fetch ( PDO :: FETCH_OBJ )) {
2025-02-09 17:24:37 +00:00
$query = 'SELECT * FROM projectcategoriesdivisions_link WHERE projectdivisions_id=? AND projectcategories_id=? AND year=?' ;
2025-01-29 03:30:48 +00:00
$t = $pdo -> prepare ( $query );
2025-02-09 17:24:37 +00:00
$t -> execute ([ $divisionr -> id , $categoryr -> id , $config [ 'FAIRYEAR' ]]);
2025-01-29 03:30:48 +00:00
if ( $t && $t -> rowCount () > 0 )
2006-02-01 16:32:41 +00:00
echo " <nobr><input type= \" checkbox \" name= \" divcat[] \" value= \" $categoryr->id\ " checked = \ " checked \" /> $categoryr->category </nobr><br/> " ;
2006-02-01 16:29:08 +00:00
else
2006-02-01 16:32:41 +00:00
echo " <nobr><input type= \" checkbox \" name= \" divcat[] \" value= \" $categoryr->id\ " /> $categoryr -> category </ nobr >< br /> " ;
2006-02-01 16:29:08 +00:00
}
2025-01-29 03:30:48 +00:00
echo '</td>' ;
2006-02-01 16:29:08 +00:00
}
2025-01-29 03:30:48 +00:00
echo ' <td><input type="submit" value="' . i18n ( $buttontext ) . '" /></td>' ;
echo '</tr>' ;
} else {
2025-02-09 17:24:37 +00:00
$q = $pdo -> prepare ( " SELECT * FROM projectdivisions WHERE year=? ORDER BY id " );
$q -> execute ([ $config [ 'FAIRYEAR' ]]);
2025-01-29 03:30:48 +00:00
while ( $r = $q -> fetch ( PDO :: FETCH_OBJ )) {
echo '<tr>' ;
2004-12-20 17:03:48 +00:00
echo " <td> $r->id </td> " ;
2025-01-29 03:30:48 +00:00
echo ' <td>' . i18n ( $r -> division ) . '</td>' ;
2005-01-13 23:59:22 +00:00
echo " <td align= \" center \" > $r->division_shortform </td> " ;
2025-01-29 03:30:48 +00:00
// ###### Feature Specific - filtering divisions by category
if ( $config [ 'filterdivisionbycategory' ] == 'yes' ) {
$c = $pdo -> prepare ( " SELECT category FROM projectcategoriesdivisions_link, projectcategories
2006-02-01 16:29:08 +00:00
WHERE projectcategoriesdivisions_link . projectcategories_id = projectcategories . id
2025-02-09 17:24:37 +00:00
AND projectdivisions_id = ?
AND projectcategoriesdivisions_link . year = ?
AND projectcategories . year = ?
2006-02-01 16:29:08 +00:00
ORDER BY projectcategories . mingrade " );
2025-02-09 17:24:37 +00:00
$c -> execute ([ $r -> id , $config [ 'FAIRYEAR' ], $config [ 'FAIRYEAR' ]]);
2024-12-19 22:29:06 -05:00
show_pdo_errors_if_any ( $pdo );
2025-01-29 03:30:48 +00:00
if ( ! $c ) {
$tempcat = ' ' ;
} else {
$tempcat = '' ;
while ( $categoryr = $c -> fetch ( PDO :: FETCH_OBJ )) {
$tempcat .= ',' . $categoryr -> category ;
2006-02-01 16:29:08 +00:00
}
2025-01-29 03:30:48 +00:00
$tempcat = substr ( $tempcat , 1 );
2006-02-01 16:29:08 +00:00
}
echo " <td> { $tempcat } </td> " ;
}
2025-01-29 03:30:48 +00:00
// ############
echo ' <td>' ;
echo '<a title="Edit" href="' . $_SERVER [ 'PHP_SELF' ] . " ?action=edit&edit= $r->id\ " >< img src = \ " " . $config [ 'SFIABDIRECTORY' ] . '/images/16/edit.' . $config [ 'icon_extension' ] . '" border=0></a>' ;
echo ' ' ;
echo '<a title="Remove" onClick="return confirmClick(\'Are you sure you want to remove this division?\');" href="' . $_SERVER [ 'PHP_SELF' ] . " ?action=remove&remove= $r->id\ " >< img src = \ " " . $config [ 'SFIABDIRECTORY' ] . '/images/16/button_cancel.' . $config [ 'icon_extension' ] . '" border=0></a>' ;
echo ' </td>' ;
echo '</tr>' ;
}
}
echo '</table>' ;
echo '</form>' ;
echo i18n ( " You should assign the 'Division ID's in numerical order, starting with 1. This Division ID is used to generate the project number " );
send_footer ();
2004-12-20 16:35:15 +00:00
?>