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 18:31:42 +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' );
2024-12-17 06:34:35 +00:00
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 Sub-Division " : " New Sub-Division " ,
2007-11-19 00:33:38 +00:00
array ( 'Committee Main' => 'committee_main.php' ,
'SFIAB Configuration' => 'config/index.php' ,
2008-08-22 20:34:38 +00:00
'Project Sub-Divisions' => 'config/subdivisions.php' ),
" project_sub_divisions " );
2007-11-19 00:33:38 +00:00
} else {
send_header ( " Project Sub-Divisions " ,
array ( 'Committee Main' => 'committee_main.php' ,
2008-08-22 20:34:38 +00:00
'SFIAB Configuration' => 'config/index.php' ),
" project_sub_divisions " );
2007-11-19 00:33:38 +00:00
}
2004-12-20 18:31:42 +00:00
2024-12-17 06:34:35 +00:00
if ( get_value_from_array ( $_POST , 'action' , " edit " ))
2004-12-20 18:31:42 +00:00
{
2024-12-17 06:34:35 +00:00
if ( get_value_from_array ( $_POST , 'id' ) && get_value_from_array ( $_POST , 'projectdivisions_id' ) && get_value_from_array ( $_POST , 'subdivision' ) )
2004-12-20 18:31:42 +00:00
{
2024-12-11 00:40:23 +00:00
$q = $pdo -> prepare ( " SELECT id FROM projectsubdivisions WHERE id=' " . $_POST [ 'id' ] . " ' AND year=' " . $config [ 'FAIRYEAR' ] . " ' " );
$q -> execute ();
if ( $q -> rowCount () && $_POST [ 'saveid' ] != $_POST [ 'id' ])
2004-12-20 18:31:42 +00:00
{
echo error ( i18n ( " Sub-Division ID %1 already exists " , array ( $_POST [ 'id' ])));
}
else
{
2024-12-11 00:40:23 +00:00
$stmt = $pdo -> prepare ( " UPDATE projectsubdivisions SET " .
2004-12-20 18:31:42 +00:00
" id=' " . $_POST [ 'id' ] . " ', " .
" projectdivisions_id=' " . $_POST [ 'projectdivisions_id' ] . " ', " .
2024-12-11 00:40:23 +00:00
" subdivision=' " . stripslashes ( $_POST [ 'subdivision' ]) . " ' " .
2004-12-20 18:31:42 +00:00
" WHERE id=' " . $_POST [ 'saveid' ] . " ' " );
2024-12-11 00:40:23 +00:00
$stmt -> execute ();
2004-12-20 18:31:42 +00:00
echo happy ( i18n ( " Sub-Division successfully saved " ));
}
}
else
{
echo error ( i18n ( " All fields are required " ));
}
}
2024-12-17 06:34:35 +00:00
if ( get_value_from_array ( $_POST , 'action' , " new " ))
2004-12-20 18:31:42 +00:00
{
2024-12-17 06:34:35 +00:00
if ( get_value_from_array ( $_POST , 'projectdivisions_id' ) && get_value_from_array ( $_POST , 'subdivision' ))
2004-12-20 18:31:42 +00:00
{
if ( ! $_POST [ 'id' ])
{
2024-12-11 00:40:23 +00:00
$idq = $pdo -> prepare ( " SELECT MAX(id) AS id FROM projectsubdivisions " );
$idq -> execute ();
$idr = $idq -> fetch ( PDO :: fETCH_OBJ );
2004-12-20 18:31:42 +00:00
$newid = $idr -> id + 1 ;
}
else
$newid = $_POST [ 'id' ];
2024-12-11 00:40:23 +00:00
$q = $pdo -> prepare ( " SELECT id FROM projectsubdivisions WHERE id=' $newid ' AND year=' " . $config [ 'FAIRYEAR' ] . " ' " );
$q -> execute ();
if ( $q -> rowCount ())
2004-12-20 18:31:42 +00:00
{
echo error ( i18n ( " Sub-Division ID %1 already exists " , array ( $newid )));
}
else
{
2024-12-11 00:40:23 +00:00
$stmt = $pdo -> prepare ( " INSERT INTO projectsubdivisions (id,projectdivisions_id,subdivision,year) VALUES ( " .
2004-12-20 18:31:42 +00:00
" ' $newid ', " .
" ' " . $_POST [ 'projectdivisions_id' ] . " ', " .
2024-12-11 00:40:23 +00:00
" ' " . stripslashes ( $_POST [ 'subdivision' ]) . " ', " .
2004-12-20 18:31:42 +00:00
" ' " . $config [ 'FAIRYEAR' ] . " ') " );
2024-12-11 00:40:23 +00:00
$stmt -> execute ();
2004-12-20 18:31:42 +00:00
echo happy ( i18n ( " Sub-Division successfully added " ));
}
}
else
{
echo error ( i18n ( " All fields except ID are required " ));
}
}
2024-12-17 06:34:35 +00:00
if ( get_value_from_array ( $_GET , 'action' , " remove " ) && get_value_from_array ( $_GET , 'remove' ))
2004-12-20 18:31:42 +00:00
{
2024-12-11 00:40:23 +00:00
$stmt = $pdo -> prepare ( " DELETE FROM projectsubdivisions WHERE id=' " . $_GET [ 'remove' ] . " ' " );
$stmt -> execute ();
2004-12-20 18:31:42 +00:00
echo happy ( i18n ( " Sub-Division successfully removed " ));
}
echo " <form method= \" post \" action= \" " . $_SERVER [ 'PHP_SELF' ] . " \" > " ;
2024-12-17 06:34:35 +00:00
if ( ! ( get_value_from_array ( $_GET , 'action' , " edit " ) || get_value_from_array ( $_GET , 'action' , " new " )) )
2004-12-20 18:31:42 +00:00
echo " <a href= \" " . $_SERVER [ 'PHP_SELF' ] . " ?action=new \" > " . i18n ( " Add new sub-division " ) . " </a> \n " ;
echo " <table class= \" summarytable \" > " ;
echo " <tr> " ;
echo " <th> " . i18n ( " Parent Division " ) . " </th> \n " ;
echo " <th> " . i18n ( " ID " ) . " </th> \n " ;
echo " <th> " . i18n ( " Sub-Division " ) . " </th> \n " ;
echo " <th> " . i18n ( " Actions " ) . " </th> \n " ;
echo " </tr> " ;
2024-12-17 06:34:35 +00:00
if ( get_value_from_array ( $_GET , 'action' , " edit " ) || get_value_from_array ( $_GET , 'action' , " new " ))
2004-12-20 18:31:42 +00:00
{
2024-12-17 06:34:35 +00:00
echo " <input type= \" hidden \" name= \" action \" value= \" " . get_value_from_array ( $_GET , 'action' ) . " \" > \n " ;
if ( get_value_from_array ( $_GET , 'action' , " edit " ))
2004-12-20 18:31:42 +00:00
{
2024-12-17 06:34:35 +00:00
echo " <input type= \" hidden \" name= \" saveid \" value= \" " . get_value_from_array ( $_GET , 'edit' ) . " \" > \n " ;
$q = $pdo -> prepare ( " SELECT * FROM projectsubdivisions WHERE id=' " . get_value_from_array ( $_GET , 'edit' ) . " ' AND year=' " . $config [ 'FAIRYEAR' ] . " ' " );
2024-12-11 00:40:23 +00:00
$q -> execute ();
$divisionr = $q -> fetch ( PDO :: FETCH_OBJ );
2004-12-20 18:31:42 +00:00
$buttontext = " Save " ;
}
else if ( $_GET [ 'action' ] == " new " )
{
$buttontext = " Add " ;
}
echo " <tr> " ;
echo " <td> " ;
echo " <select name= \" projectdivisions_id \" > " ;
2024-12-11 00:40:23 +00:00
$dq = $pdo -> prepare ( " SELECT * FROM projectdivisions WHERE year=' " . $config [ 'FAIRYEAR' ] . " ' ORDER BY division " );
$dq -> execute ();
while ( $dr = $dq -> fetch ( PDO :: FETCH_OBJ ))
2004-12-20 18:31:42 +00:00
{
if ( $dr -> id == $divisionr -> projectdivisions_id ) $sel = " selected= \" selected \" " ; else $sel = " " ;
echo " <option $sel value= \" $dr->id\ " > $dr -> division </ option > \n " ;
}
echo " </select> " ;
echo " </td> " ;
echo " <td><input type= \" text \" size= \" 3 \" name= \" id \" value= \" $divisionr->id\ " ></ td > " ;
echo " <td><input type= \" text \" size= \" 30 \" name= \" subdivision \" value= \" $divisionr->subdivision\ " ></ 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 projectsubdivisions.id,
2004-12-20 18:31:42 +00:00
projectsubdivisions . projectdivisions_id ,
projectsubdivisions . subdivision ,
projectdivisions . division
FROM
projectsubdivisions ,
projectdivisions
WHERE
projectsubdivisions . year = '".$config[' FAIRYEAR ']."'
2006-02-06 17:22:25 +00:00
AND projectdivisions . year = '".$config[' FAIRYEAR ']."'
2004-12-20 18:31:42 +00:00
AND projectsubdivisions . projectdivisions_id = projectdivisions . id
ORDER BY
division , subdivision " );
2024-11-25 23:06:33 +00:00
$q -> execute ();
echo $pdo -> errorInfo ();
while ( $r = $q -> fetch ( PDO :: FETCH_OBJ ))
2004-12-20 18:31:42 +00:00
{
echo " <tr> " ;
echo " <td> $r->division </td> " ;
2004-12-20 18:54:41 +00:00
echo " <td> $r->id </td> " ;
2004-12-20 18:31:42 +00:00
echo " <td> $r->subdivision </td> " ;
echo " <td> " ;
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 18:31:42 +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 division?'); \" 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 18:31:42 +00:00
echo " </td> " ;
echo " </tr> " ;
}
}
echo " </table> " ;
2024-12-17 06:34:35 +00:00
if ( get_value_from_array ( $_GET , 'action' , " new " ))
2004-12-20 18:31:42 +00:00
echo " " . i18n ( " Leave ID field blank to auto-assign next available ID " );
echo " </form> " ;
send_footer ();
?>