2005-01-24 18:00:03 +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 .
*/
?>
2004-12-20 16:35:15 +00:00
< ?
require ( " ../common.inc.php " );
2007-11-21 17:04:35 +00:00
require_once ( " ../user.inc.php " );
2007-11-19 00:33:38 +00:00
user_auth_required ( 'committee' , 'config' );
2005-02-16 22:50:43 +00:00
2007-11-19 00:33:38 +00:00
if ( $_GET [ 'action' ] == " edit " || $_GET [ 'action' ] == " new " ) {
send_header (( $_GET [ 'action' ] == " edit " ) ? 'Edit Category' : 'New Category' ,
array ( 'Committee Main' => 'committee_main.php' ,
'SFIAB Configuration' => 'config/index.php' ,
2008-08-22 20:34:38 +00:00
'Age Categories' => 'config/categories.php' ), " project_age_categories " );
2024-12-13 06:49:54 +00:00
} else {
2007-11-19 00:33:38 +00:00
send_header ( " Age Categories " ,
array ( 'Committee Main' => 'committee_main.php' ,
2008-08-22 20:34:38 +00:00
'SFIAB Configuration' => 'config/index.php' ), " project_age_categories " );
2007-11-19 00:33:38 +00:00
}
2004-12-20 16:35:15 +00:00
if ( $_POST [ 'action' ] == " edit " )
{
2006-01-28 17:53:26 +00:00
//ues isset($_POST['mingrade']) instead of just $_POST['mingrade'] to allow entering 0 for kindergarden
if ( $_POST [ 'id' ] && $_POST [ 'category' ] && isset ( $_POST [ 'mingrade' ]) && $_POST [ 'maxgrade' ])
2004-12-20 16:35:15 +00:00
{
2024-12-11 00:40:23 +00:00
$q = $pdo -> prepare ( " SELECT id FROM projectcategories WHERE id=' " . $_POST [ 'id' ] . " ' AND year=' " . $config [ 'FAIRYEAR' ] . " ' " );
$q -> execute ();
echo $pdo -> errorInfo ();
if ( $q -> rowCount () && $_POST [ 'saveid' ] != $_POST [ 'id' ])
2004-12-20 16:35:15 +00:00
{
2006-01-19 17:15:07 +00:00
echo error ( i18n ( " Category ID %1 already exists " , array ( $_POST [ 'id' ]), array ( " category ID " )));
2004-12-20 16:35:15 +00:00
}
else
{
2024-12-11 00:40:23 +00:00
$stmt = $pdo -> prepare ( " UPDATE projectcategories SET " .
2004-12-20 16:35:15 +00:00
" id=' " . $_POST [ 'id' ] . " ', " .
2024-12-11 00:40:23 +00:00
" category=' " . stripslashes ( $_POST [ 'category' ]) . " ', " .
" category_shortform=' " . stripslashes ( $_POST [ 'category_shortform' ]) . " ', " .
2004-12-20 16:35:15 +00:00
" mingrade=' " . $_POST [ 'mingrade' ] . " ', " .
" maxgrade=' " . $_POST [ 'maxgrade' ] . " ' " .
" WHERE id=' " . $_POST [ 'saveid' ] . " ' " );
echo happy ( i18n ( " Category successfully saved " ));
2024-12-11 00:40:23 +00:00
$stmt -> execute ();
2004-12-20 16:35:15 +00:00
}
}
else
{
echo error ( i18n ( " All fields are required " ));
}
}
if ( $_POST [ 'action' ] == " new " )
{
2006-01-28 17:53:26 +00:00
//ues isset($_POST['mingrade']) instead of just $_POST['mingrade'] to allow entering 0 for kindergarden
if ( $_POST [ 'id' ] && $_POST [ 'category' ] && isset ( $_POST [ 'mingrade' ]) && $_POST [ 'maxgrade' ])
2004-12-20 16:35:15 +00:00
{
2024-12-11 00:40:23 +00:00
$q = $pdo -> prepare ( " SELECT id FROM projectcategories WHERE id=' " . $_POST [ 'id' ] . " ' AND year=' " . $config [ 'FAIRYEAR' ] . " ' " );
$q -> execute ();
if ( $q -> rowCount ())
2004-12-20 16:35:15 +00:00
{
2006-01-19 17:15:07 +00:00
echo error ( i18n ( " Category ID %1 already exists " , array ( $_POST [ 'id' ]), array ( " category ID " )));
2004-12-20 16:35:15 +00:00
}
else
{
2024-12-11 00:40:23 +00:00
$pdo -> prepare ( " INSERT INTO projectcategories (id,category,category_shortform,mingrade,maxgrade,year) VALUES ( " .
2004-12-20 16:35:15 +00:00
" ' " . $_POST [ 'id' ] . " ', " .
2024-12-11 00:40:23 +00:00
" ' " . stripslashes ( $_POST [ 'category' ]) . " ', " .
" ' " . stripslashes ( $_POST [ 'category_shortform' ]) . " ', " .
2004-12-20 16:35:15 +00:00
" ' " . $_POST [ 'mingrade' ] . " ', " .
2004-12-20 17:03:48 +00:00
" ' " . $_POST [ 'maxgrade' ] . " ', " .
" ' " . $config [ 'FAIRYEAR' ] . " ') " );
2024-12-11 00:40:23 +00:00
$pdo -> execute ();
2004-12-20 16:35:15 +00:00
echo happy ( i18n ( " Category successfully added " ));
2024-12-11 00:40:23 +00:00
2004-12-20 16:35:15 +00:00
}
}
else
{
echo error ( i18n ( " All fields are required " ));
}
}
if ( $_GET [ 'action' ] == " remove " && $_GET [ 'remove' ])
{
2006-02-01 16:29:08 +00:00
//###### 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
2024-12-11 00:40:23 +00:00
$stmt = $pdo -> prepare ( " DELETE FROM projectcategoriesdivisions_link where projectcategories_id=' " . $_GET [ 'remove' ] . " ' AND year=' " . $config [ 'FAIRYEAR' ] . " ' " );
$stmt -> execute ();
2006-02-01 16:29:08 +00:00
//####
2024-12-11 00:40:23 +00:00
$stmt = $pdo -> prepare ( " DELETE FROM projectcategories WHERE id=' " . $_GET [ 'remove' ] . " ' AND year=' " . $config [ 'FAIRYEAR' ] . " ' " );
$stmt -> execute ();
2004-12-20 16:35:15 +00:00
echo happy ( i18n ( " Category successfully removed " ));
}
echo " <form method= \" post \" action= \" " . $_SERVER [ 'PHP_SELF' ] . " \" > " ;
if ( ! ( $_GET [ 'action' ] == " edit " || $_GET [ 'action' ] == " new " ) )
echo " <a href= \" " . $_SERVER [ 'PHP_SELF' ] . " ?action=new \" > " . i18n ( " Add new age category " ) . " </a> \n " ;
echo " <table class= \" summarytable \" > " ;
echo " <tr> " ;
echo " <th> " . i18n ( " Category ID " ) . " </th> \n " ;
echo " <th> " . i18n ( " Category Name " ) . " </th> \n " ;
2006-12-06 17:58:40 +00:00
echo " <th> " . i18n ( " Shortform " ) . " </th> \n " ;
2004-12-20 16:35:15 +00:00
echo " <th> " . i18n ( " Minimum Grade " ) . " </th> \n " ;
echo " <th> " . i18n ( " Maximum Grade " ) . " </th> \n " ;
echo " <th> " . i18n ( " Actions " ) . " </th> \n " ;
echo " </tr> " ;
if ( $_GET [ 'action' ] == " edit " || $_GET [ 'action' ] == " new " )
{
echo " <input type= \" hidden \" name= \" action \" value= \" " . $_GET [ 'action' ] . " \" > \n " ;
if ( $_GET [ 'action' ] == " edit " )
{
echo " <input type= \" hidden \" name= \" saveid \" value= \" " . $_GET [ 'edit' ] . " \" > \n " ;
2024-12-11 00:40:23 +00:00
$q = $pdo -> prepare ( " SELECT * FROM projectcategories WHERE id=' " . $_GET [ 'edit' ] . " ' AND year=' " . $config [ 'FAIRYEAR' ] . " ' " );
$q -> execute ();
$categoryr = $q -> fetch ( PDO :: FETCH_OBJ );
2004-12-20 16:35:15 +00:00
$buttontext = " Save " ;
}
else if ( $_GET [ 'action' ] == " new " )
{
$buttontext = " Add " ;
}
echo " <tr> " ;
echo " <td><input type= \" text \" size= \" 3 \" name= \" id \" value= \" $categoryr->id\ " ></ td > " ;
echo " <td><input type= \" text \" size= \" 20 \" name= \" category \" value= \" $categoryr->category\ " ></ td > " ;
2006-12-06 17:58:40 +00:00
echo " <td><input type= \" text \" size= \" 5 \" name= \" category_shortform \" value= \" $categoryr->category_shortform\ " ></ td > " ;
2004-12-20 16:35:15 +00:00
echo " <td><input type= \" text \" size= \" 3 \" name= \" mingrade \" value= \" $categoryr->mingrade\ " ></ td > " ;
echo " <td><input type= \" text \" size= \" 3 \" name= \" maxgrade \" value= \" $categoryr->maxgrade\ " ></ td > " ;
echo " <td><input type= \" submit \" value= \" " . i18n ( $buttontext ) . " \" ></td> " ;
echo " </tr> " ;
}
else
2024-11-25 23:06:33 +00:00
{ $q = $pdo -> prepare ( " SELECT * FROM projectcategories WHERE year=' " . $config [ 'FAIRYEAR' ] . " ' ORDER BY mingrade " );
$q -> execute ();
while ( $r = $q -> fetch ( PDO :: FETCH_OBJ ))
2004-12-20 16:35:15 +00:00
{
echo " <tr> " ;
2006-01-28 17:53:26 +00:00
echo " <td align= \" center \" > $r->id </td> " ;
2006-01-19 17:15:07 +00:00
echo " <td> " . i18n ( $r -> category ) . " </td> " ;
2006-12-06 17:58:40 +00:00
echo " <td> " . i18n ( $r -> category_shortform ) . " </td> " ;
2006-01-28 17:53:26 +00:00
echo " <td align= \" center \" > $r->mingrade </td> " ;
echo " <td align= \" center \" > $r->maxgrade </td> " ;
echo " <td align= \" center \" > " ;
2005-01-25 17:00:23 +00:00
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> " ;
2004-12-20 16:35:15 +00:00
echo " " ;
2005-01-25 17:00:23 +00:00
echo " <a title= \" Remove \" onClick= \" return confirmClick('Are you sure you want to remove this age category?'); \" href= \" " . $_SERVER [ 'PHP_SELF' ] . " ?action=remove&remove= $r->id\ " >< img src = \ " " . $config [ 'SFIABDIRECTORY' ] . " /images/16/button_cancel. " . $config [ 'icon_extension' ] . " \" border=0></a> " ;
2004-12-20 16:35:15 +00:00
echo " </td> " ;
echo " </tr> " ;
}
}
echo " </table> " ;
echo " </form> " ;
2005-01-21 17:30:28 +00:00
echo i18n ( " You should assign the 'Category ID's in numerical order, starting with 1. This Category ID is used to generate the project number " );
2004-12-20 16:35:15 +00:00
send_footer ();
?>