Fix participant registration and fundraising

This commit is contained in:
arman 2025-02-04 20:35:59 +00:00
parent e77fc688f0
commit b6494034ad
15 changed files with 1597 additions and 5270 deletions

View File

@ -1,8 +1,8 @@
-- MariaDB dump 10.19-11.5.2-MariaDB, for debian-linux-gnu (x86_64)
-- MariaDB dump 10.19 Distrib 10.11.6-MariaDB, for debian-linux-gnu (x86_64)
--
-- Host: localhost Database: sfiab
-- Host: 127.0.0.1 Database: mariadb
-- ------------------------------------------------------
-- Server version 11.5.2-MariaDB-ubu2404
-- Server version 11.6.2-MariaDB-ubu2404
/*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */;
/*!40101 SET @OLD_CHARACTER_SET_RESULTS=@@CHARACTER_SET_RESULTS */;
@ -13,7 +13,7 @@
/*!40014 SET @OLD_UNIQUE_CHECKS=@@UNIQUE_CHECKS, UNIQUE_CHECKS=0 */;
/*!40014 SET @OLD_FOREIGN_KEY_CHECKS=@@FOREIGN_KEY_CHECKS, FOREIGN_KEY_CHECKS=0 */;
/*!40101 SET @OLD_SQL_MODE=@@SQL_MODE, SQL_MODE='NO_AUTO_VALUE_ON_ZERO' */;
/*M!100616 SET @OLD_NOTE_VERBOSITY=@@NOTE_VERBOSITY, NOTE_VERBOSITY=0 */;
/*!40111 SET @OLD_SQL_NOTES=@@SQL_NOTES, SQL_NOTES=0 */;
--
-- Table structure for table `award_awards`
@ -903,7 +903,7 @@ LOCK TABLES `emailqueue_recipients` WRITE;
UNLOCK TABLES;
--
-- Table structure for table `git
-- Table structure for table `emails`
--
DROP TABLE IF EXISTS `emails`;
@ -932,22 +932,22 @@ CREATE TABLE `emails` (
LOCK TABLES `emails` WRITE;
/*!40000 ALTER TABLE `emails` DISABLE KEYS */;
INSERT INTO `emails` VALUES
(1,'register_participants_resend_regnum','Participant Registration - Resend Registration Number','Resend the password to the participant if they submit a \'forgot regnum\' request','','Registration for [FAIRNAME]','We have received a request for the retrieval of your registration number from this email address. Please find your existing registration number below\r\n\r\nRegistration Number: [REGNUM]\r\n','','system',NULL,NULL),
(2,'new_participant','New Participant','Email that new participants receive when they are added to the system','','Registration for [FAIRNAME]','A new registration account has been created for you. To access your registration account, please enter the following registration number into the registration website:\r\n\r\nEmail Address: [EMAIL]\r\nRegistration Number: [REGNUM]\r\n','','system',NULL,NULL),
(5,'register_participants_received','Participant Registration - Form Received','Sent to the participant when the admin flags their signature form as received','','Registration for [FAIRNAME] Complete','Dear [FIRSTNAME],\r\nYour registration for the [FAIRNAME] is now complete.\r\nYour project number is [PROJECTNUMBER]. Please write down your project number and bring it with you to the fair in order to expedite the check-in process.\r\n\r\nSincerely,\r\n [FAIRNAME]','','system',NULL,NULL),
(6,'register_participants_paymentpending','Participant Registration - Payment Pending','Sent to the participant when the admin flags their signature form as received but payment pending','','Registration for [FAIRNAME] Not Complete - Payment Pending','Dear [FIRSTNAME],\r\nYour registration for the [FAIRNAME] is not yet complete. We received your registration form however it was missing the required registration fee. Please send the required registration fee in aso soon as possible in order to complete your registration.\r\n\r\nYour project number is [PROJECTNUMBER]. Please write down your project number and bring it with you to the fair in order to expedite the check-in process.\r\n\r\nSincerely,\r\n [FAIRNAME]','','system',NULL,NULL),
(7,'volunteer_welcome','Volunteer Registration - Welcome','Welcome email sent to a volunteer after they have registered for the first time. This email includes their temporary password.','','Volunteer Registration for [FAIRNAME]','Thank you for registering as a volunteer at our fair. Please find your temporary password below. After logging in for the first time you will be prompted to change your password.\n\nVolunteer Email Address: [EMAIL]\nVolunteer Password: [PASSWORD]','','system',NULL,NULL),
(8,'volunteer_recover_password','Volunteer Registration - Recover Password','Recover the password for a volunteer if they submit a \'forgot password\' request','','Volunteer Registration for [FAIRNAME]','We have received a request for the recovery of your password from this email address. Please find your new password below:\n\nVolunteer Email Address: [EMAIL]\nVolunteer Password: [PASSWORD] ','','system',NULL,NULL),
(9,'committee_recover_password','Committee Members - Recover Password','Recover the password for a committee member if they submit a \'forgot password\' request','','Committee Member for [FAIRNAME]','We have received a request for the recovery of your password from this email address. Please find your new password below:\n\nCommittee Member Email Address: [EMAIL]\nCommittee Member Password: [PASSWORD] ','','system',NULL,NULL),
(10,'volunteer_new_invite','Volunteers - New Volunteer Invitation','This is sent to a new volunteer when they are invited using the invite volunteers administration section, only available when the Volunteer Registration Type is set to Invite','','Volunteer Registration for [FAIRNAME]','You have been invited to be a volunteer for the [FAIRNAME]. An account has been created for you to login with and complete your information. You can login to the volunteer registration site with:\n\nEmail Address: [EMAIL]\nPassword: [PASSWORD]\n\nYou can change your password once you login.','','system',NULL,NULL),
(11,'volunteer_add_invite','Volunteers - Add Volunteer Invitation','This is sent to existing users when they are invited using the invite volunteers administration section, only available when the Volunteer Registration Type is set to Invite','','Volunteer Registration for [FAIRNAME]','The role of volunteer for the [FAIRNAME] has been added to your account by a committee member. When you login again, there will be a [Switch Roles] link in the upper right hand area of the page. Clicking on [Switch Roles] will let you switch between being a Volunteer and your other roles without needing to logout.\n','','system',NULL,NULL),
(12,'judge_recover_password','Judges - Recover Password','Recover the password for a judge if they submit a \'forgot password\' request','','Password Recovery for [FAIRNAME]','We have received a request for the recovery of your password from this email address. Please find your new password below:\n\nJudge Email Address: [EMAIL]\nJudge Password: [PASSWORD] ','','system',NULL,NULL),
(13,'judge_welcome','Judges - Welcome','Welcome email sent to a judge after they have registered for the first time. This email includes their temporary password.','','Judge Registration for [FAIRNAME]','Thank you for registering as a judge at our fair. Please find your temporary password below. After logging in for the first time you will be prompted to change your password.\n\nJudge Email Address: [EMAIL]\nJudge Password: [PASSWORD]','','system',NULL,NULL),
(14,'judge_new_invite','Judges - New Judge Invitation','This is sent to a new judge when they are invited using the invite users administration option.','','Judge Registration for [FAIRNAME]','You have been invited to be a judge for the [FAIRNAME]. An account has been created for you to login with and complete your information. You can login to the judge registration site with:\n\nEmail Address: [EMAIL]\nPassword: [PASSWORD]\nYou can change your password once you login.','','system',NULL,NULL),
(15,'judge_add_invite','Judges - Add Judge Invitation','This is sent to existing users when they are invited using the invite users administration option.','','Judge Registration for [FAIRNAME]','The role of judge for the [FAIRNAME] has been added to your account by a committee member. When you login again, there will be a [Switch Roles] link in the upper right hand area of the page. Clicking on [Switch Roles] will let you switch between being a Judge and your other roles without needing to logout.\n','','system',NULL,NULL),
(16,'judge_activate_reminder','Judges - Activation Reminder','This is sent to existing judges who have not yet activated their account for the current fair year.','','Judge Registration for [FAIRNAME]','This message is to let you know that Judge registration for the [FAIRNAME] is now open. If you would like to participate in the fair this year please log in to the registration site using your email address ([EMAIL]) an\n','','system',NULL,NULL),
(17,'volunteer_activate_reminder','Volunteer Registration - Activation Reminder','This is sent to existing volunteers who have not yet activated their account for the current fair year.','','Volunteer Registration for [FAIRNAME]','This message is to let you know that Volunteer registration for the [FAIRNAME] is now open. If you would like to participate in the fair this year please log in to the registration site using your email address ([EMAIL]).\n','','system',NULL,NULL),
(18,'fundraising_thankyou_template','Fundraising Thank You Template','Fundraising thank you template to be used to send thank you emails to individual sponsor/donors once a donation is received','','Thank You for your Contribution','Dear [FIRSTNAME],\r\n\r\nThank you for your contribution to the [FAIRNAME]\r\n\r\nSincerely,\r\n [FAIRNAME] Committee\r\n','','system',NULL,NULL);
(1,'register_participants_resend_regnum','Participant Registration - Resend Registration Number','Resend the password to the participant if they submit a \'forgot regnum\' request','contact@science-ation.ca','Registration for [FAIRNAME]','We have received a request for the retrieval of your registration number from this email address. Please find your existing registration number below\r\n\r\nRegistration Number: [REGNUM]\r\n','','system',NULL,NULL),
(2,'new_participant','New Participant','Email that new participants receive when they are added to the system','contact@science-ation.ca','Registration for [FAIRNAME]','A new registration account has been created for you. To access your registration account, please enter the following registration number into the registration website:\r\n\r\nEmail Address: [EMAIL]\r\nRegistration Number: [REGNUM]\r\n','','system',NULL,NULL),
(5,'register_participants_received','Participant Registration - Form Received','Sent to the participant when the admin flags their signature form as received','contact@science-ation.ca','Registration for [FAIRNAME] Complete','Dear [FIRSTNAME],\r\nYour registration for the [FAIRNAME] is now complete.\r\nYour project number is [PROJECTNUMBER]. Please write down your project number and bring it with you to the fair in order to expedite the check-in process.\r\n\r\nSincerely,\r\n [FAIRNAME]','','system',NULL,NULL),
(6,'register_participants_paymentpending','Participant Registration - Payment Pending','Sent to the participant when the admin flags their signature form as received but payment pending','contact@science-ation.ca','Registration for [FAIRNAME] Not Complete - Payment Pending','Dear [FIRSTNAME],\r\nYour registration for the [FAIRNAME] is not yet complete. We received your registration form however it was missing the required registration fee. Please send the required registration fee in aso soon as possible in order to complete your registration.\r\n\r\nYour project number is [PROJECTNUMBER]. Please write down your project number and bring it with you to the fair in order to expedite the check-in process.\r\n\r\nSincerely,\r\n [FAIRNAME]','','system',NULL,NULL),
(7,'volunteer_welcome','Volunteer Registration - Welcome','Welcome email sent to a volunteer after they have registered for the first time. This email includes their temporary password.','contact@science-ation.ca','Volunteer Registration for [FAIRNAME]','Thank you for registering as a volunteer at our fair. Please find your temporary password below. After logging in for the first time you will be prompted to change your password.\n\nVolunteer Email Address: [EMAIL]\nVolunteer Password: [PASSWORD]','','system',NULL,NULL),
(8,'volunteer_recover_password','Volunteer Registration - Recover Password','Recover the password for a volunteer if they submit a \'forgot password\' request','contact@science-ation.ca','Volunteer Registration for [FAIRNAME]','We have received a request for the recovery of your password from this email address. Please find your new password below:\n\nVolunteer Email Address: [EMAIL]\nVolunteer Password: [PASSWORD] ','','system',NULL,NULL),
(9,'committee_recover_password','Committee Members - Recover Password','Recover the password for a committee member if they submit a \'forgot password\' request','contact@science-ation.ca','Committee Member for [FAIRNAME]','We have received a request for the recovery of your password from this email address. Please find your new password below:\n\nCommittee Member Email Address: [EMAIL]\nCommittee Member Password: [PASSWORD] ','','system',NULL,NULL),
(10,'volunteer_new_invite','Volunteers - New Volunteer Invitation','This is sent to a new volunteer when they are invited using the invite volunteers administration section, only available when the Volunteer Registration Type is set to Invite','contact@science-ation.ca','Volunteer Registration for [FAIRNAME]','You have been invited to be a volunteer for the [FAIRNAME]. An account has been created for you to login with and complete your information. You can login to the volunteer registration site with:\n\nEmail Address: [EMAIL]\nPassword: [PASSWORD]\n\nYou can change your password once you login.','','system',NULL,NULL),
(11,'volunteer_add_invite','Volunteers - Add Volunteer Invitation','This is sent to existing users when they are invited using the invite volunteers administration section, only available when the Volunteer Registration Type is set to Invite','contact@science-ation.ca','Volunteer Registration for [FAIRNAME]','The role of volunteer for the [FAIRNAME] has been added to your account by a committee member. When you login again, there will be a [Switch Roles] link in the upper right hand area of the page. Clicking on [Switch Roles] will let you switch between being a Volunteer and your other roles without needing to logout.\n','','system',NULL,NULL),
(12,'judge_recover_password','Judges - Recover Password','Recover the password for a judge if they submit a \'forgot password\' request','contact@science-ation.ca','Password Recovery for [FAIRNAME]','We have received a request for the recovery of your password from this email address. Please find your new password below:\n\nJudge Email Address: [EMAIL]\nJudge Password: [PASSWORD] ','','system',NULL,NULL),
(13,'judge_welcome','Judges - Welcome','Welcome email sent to a judge after they have registered for the first time. This email includes their temporary password.','contact@science-ation.ca','Judge Registration for [FAIRNAME]','Thank you for registering as a judge at our fair. Please find your temporary password below. After logging in for the first time you will be prompted to change your password.\n\nJudge Email Address: [EMAIL]\nJudge Password: [PASSWORD]','','system',NULL,NULL),
(14,'judge_new_invite','Judges - New Judge Invitation','This is sent to a new judge when they are invited using the invite users administration option.','contact@science-ation.ca','Judge Registration for [FAIRNAME]','You have been invited to be a judge for the [FAIRNAME]. An account has been created for you to login with and complete your information. You can login to the judge registration site with:\n\nEmail Address: [EMAIL]\nPassword: [PASSWORD]\nYou can change your password once you login.','','system',NULL,NULL),
(15,'judge_add_invite','Judges - Add Judge Invitation','This is sent to existing users when they are invited using the invite users administration option.','contact@science-ation.ca','Judge Registration for [FAIRNAME]','The role of judge for the [FAIRNAME] has been added to your account by a committee member. When you login again, there will be a [Switch Roles] link in the upper right hand area of the page. Clicking on [Switch Roles] will let you switch between being a Judge and your other roles without needing to logout.\n','','system',NULL,NULL),
(16,'judge_activate_reminder','Judges - Activation Reminder','This is sent to existing judges who have not yet activated their account for the current fair year.','contact@science-ation.ca','Judge Registration for [FAIRNAME]','This message is to let you know that Judge registration for the [FAIRNAME] is now open. If you would like to participate in the fair this year please log in to the registration site using your email address ([EMAIL]) an\n','','system',NULL,NULL),
(17,'volunteer_activate_reminder','Volunteer Registration - Activation Reminder','This is sent to existing volunteers who have not yet activated their account for the current fair year.','contact@science-ation.ca','Volunteer Registration for [FAIRNAME]','This message is to let you know that Volunteer registration for the [FAIRNAME] is now open. If you would like to participate in the fair this year please log in to the registration site using your email address ([EMAIL]).\n','','system',NULL,NULL),
(18,'fundraising_thankyou_template','Fundraising Thank You Template','Fundraising thank you template to be used to send thank you emails to individual sponsor/donors once a donation is received','contact@science-ation.ca','Thank You for your Contribution','Dear [FIRSTNAME],\r\n\r\nThank you for your contribution to the [FAIRNAME]\r\n\r\nSincerely,\r\n [FAIRNAME] Committee\r\n','','system',NULL,NULL);
/*!40000 ALTER TABLE `emails` ENABLE KEYS */;
UNLOCK TABLES;
@ -972,7 +972,7 @@ CREATE TABLE `emergencycontact` (
`email` varchar(128) NOT NULL DEFAULT '',
`year` int(10) unsigned NOT NULL DEFAULT 0,
PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=latin1 COLLATE=latin1_swedish_ci;
) ENGINE=MyISAM AUTO_INCREMENT=2 DEFAULT CHARSET=latin1 COLLATE=latin1_swedish_ci;
/*!40101 SET character_set_client = @saved_cs_client */;
--
@ -981,6 +981,8 @@ CREATE TABLE `emergencycontact` (
LOCK TABLES `emergencycontact` WRITE;
/*!40000 ALTER TABLE `emergencycontact` DISABLE KEYS */;
INSERT INTO `emergencycontact` VALUES
(1,2,1,'sfa','rsf','Grandparent','ds','','','','',2025);
/*!40000 ALTER TABLE `emergencycontact` ENABLE KEYS */;
UNLOCK TABLES;
@ -1768,6 +1770,10 @@ CREATE TABLE `projectcategories` (
LOCK TABLES `projectcategories` WRITE;
/*!40000 ALTER TABLE `projectcategories` DISABLE KEYS */;
INSERT INTO `projectcategories` VALUES
(1,'junor','',7,8,2025),
(2,'senior','',11,12,2025),
(3,'int','',9,10,2025);
/*!40000 ALTER TABLE `projectcategories` ENABLE KEYS */;
UNLOCK TABLES;
@ -1861,29 +1867,29 @@ CREATE TABLE `projects` (
`registrations_id` int(10) unsigned NOT NULL DEFAULT 0,
`projectnumber` varchar(16) DEFAULT NULL,
`projectsort` varchar(16) DEFAULT NULL,
`projectnumber_seq` int(11) NOT NULL,
`projectsort_seq` int(11) NOT NULL,
`floornumber` int(11) NOT NULL,
`projectnumber_seq` int(11) NOT NULL DEFAULT 0,
`projectsort_seq` int(11) NOT NULL DEFAULT 0,
`floornumber` int(11) NOT NULL DEFAULT 0,
`projectcategories_id` int(10) unsigned NOT NULL DEFAULT 0,
`projectdivisions_id` int(10) unsigned NOT NULL DEFAULT 0,
`cwsfdivisionid` int(11) DEFAULT NULL,
`title` varchar(255) NOT NULL DEFAULT '',
`shorttitle` varchar(255) NOT NULL,
`shorttitle` varchar(255) NOT NULL DEFAULT '',
`summarycountok` tinyint(1) NOT NULL DEFAULT 1,
`summary` text NOT NULL,
`summary` text NOT NULL DEFAULT '',
`year` int(11) NOT NULL DEFAULT 0,
`req_electricity` enum('no','yes') NOT NULL DEFAULT 'no',
`req_table` enum('no','yes') NOT NULL DEFAULT 'yes',
`req_special` varchar(128) NOT NULL DEFAULT '',
`language` char(2) NOT NULL DEFAULT '',
`fairs_id` int(11) NOT NULL,
`fairs_id` int(11) NOT NULL DEFAULT 0,
`projecttype` varchar(64) DEFAULT NULL,
`feedback` text DEFAULT NULL,
`flagged` tinyint(1) DEFAULT NULL,
`human_participants` enum('no','yes') DEFAULT NULL,
`animal_participants` enum('no','yes') DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=latin1 COLLATE=latin1_swedish_ci;
) ENGINE=MyISAM AUTO_INCREMENT=2 DEFAULT CHARSET=latin1 COLLATE=latin1_swedish_ci;
/*!40101 SET character_set_client = @saved_cs_client */;
--
@ -3390,9 +3396,9 @@ DROP TABLE IF EXISTS `users`;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `users` (
`id` int(10) unsigned NOT NULL AUTO_INCREMENT,
`uid` int(11) NOT NULL,
`uid` int(11) NOT NULL DEFAULT 0,
`types` set('student','judge','committee','volunteer','fair','sponsor','principal','teacher','parent','mentor','alumni') NOT NULL,
`salutation` varchar(8) NOT NULL,
`salutation` varchar(8) NOT NULL DEFAULT '',
`firstname` varchar(32) NOT NULL DEFAULT '',
`lastname` varchar(32) NOT NULL DEFAULT '',
`sex` enum('male','female') DEFAULT NULL,
@ -3530,18 +3536,18 @@ CREATE TABLE `users_judge` (
`users_id` int(11) NOT NULL,
`judge_active` enum('no','yes') NOT NULL DEFAULT 'no',
`judge_complete` enum('no','yes') NOT NULL DEFAULT 'no',
`years_school` tinyint(4) NOT NULL,
`years_regional` tinyint(4) NOT NULL,
`years_national` tinyint(4) NOT NULL,
`years_school` tinyint(4) NOT NULL DEFAULT 0,
`years_regional` tinyint(4) NOT NULL DEFAULT 0,
`years_national` tinyint(4) NOT NULL DEFAULT 0,
`willing_chair` enum('yes','no') NOT NULL DEFAULT 'no',
`special_award_only` enum('yes','no') NOT NULL DEFAULT 'no',
`cat_prefs` tinytext NOT NULL,
`div_prefs` text NOT NULL,
`divsub_prefs` tinytext NOT NULL,
`languages` tinytext NOT NULL,
`highest_psd` tinytext NOT NULL,
`expertise_other` tinytext NOT NULL,
`private_info` text DEFAULT NULL,
`cat_prefs` tinytext NOT NULL DEFAULT '',
`div_prefs` text NOT NULL DEFAULT '',
`divsub_prefs` tinytext NOT NULL DEFAULT '',
`languages` tinytext NOT NULL DEFAULT '',
`highest_psd` tinytext NOT NULL DEFAULT '',
`expertise_other` tinytext NOT NULL DEFAULT '',
`private_info` text DEFAULT NULL ,
`flagged_judge` tinyint(1) DEFAULT NULL,
PRIMARY KEY (`users_id`)
) ENGINE=MyISAM DEFAULT CHARSET=latin1 COLLATE=latin1_swedish_ci;
@ -3787,6 +3793,6 @@ UNLOCK TABLES;
/*!40101 SET CHARACTER_SET_CLIENT=@OLD_CHARACTER_SET_CLIENT */;
/*!40101 SET CHARACTER_SET_RESULTS=@OLD_CHARACTER_SET_RESULTS */;
/*!40101 SET COLLATION_CONNECTION=@OLD_COLLATION_CONNECTION */;
/*M!100616 SET NOTE_VERBOSITY=@OLD_NOTE_VERBOSITY */;
/*!40111 SET SQL_NOTES=@OLD_SQL_NOTES */;
-- Dump completed on 2024-11-22 2:44:22
-- Dump completed on 2025-02-03 18:47:42

File diff suppressed because it is too large Load Diff

View File

@ -394,8 +394,10 @@ send_header('Awards Management',
var award_id = 0;
var award_tab_update = new Array();
function update_awardinfo()
{
{
if(award_tab_update['awardinfo'] == award_id) return;
award_tab_update['awardinfo'] = award_id;
// alert(award_id);
@ -634,7 +636,7 @@ function update_feeder_enable()
/* Setup the popup window */
$(document).ready(function() {
console.log('first');
$("#popup_editor").dialog({
bgiframe: true, autoOpen: false,
modal: true, resizable: false,
@ -649,7 +651,7 @@ $(document).ready(function() {
});
$("#editor_tabs").tabs({
create: function( event, ui ) {
activate: function( event, ui ) {
update_awardinfo();
update_eligibility();
update_prizeinfo();
@ -680,6 +682,7 @@ $(document).ready(function() {
// collapsible: true,
// selected: -1 /* None selected */
// });
})
</script>
@ -912,15 +915,15 @@ function popup_editor(id, mode)
switch(mode) {
case 'new':
$('#editor_tabs').tabs('option', 'disabled', [1, 2, 3]);
$('#editor_tabs').tabs('select', 0);
$('#editor_tabs').tabs('option','active', 0);
break;
case 'template':
$('#editor_tabs').tabs('option', 'disabled', [0, 1, 3]);
$('#editor_tabs').tabs('select', 2);
$('#editor_tabs').tabs('option', 'active', 2);
break;
default:
$('#editor_tabs').tabs('option', 'disabled', []);
$('#editor_tabs').tabs('select', 0);
$('#editor_tabs').tabs('option','active', 0);
break;
}
/* Don't let anything collapse */

File diff suppressed because it is too large Load Diff

View File

@ -178,7 +178,7 @@ case 'managelist':
$recq = $pdo->prepare("SELECT SUM(value) AS received FROM fundraising_donations WHERE fundraising_campaigns_id='$r->id' AND fiscalyear='{$config['FISCALYEAR']}' AND status='received'");
$recq->execute();
show_pdo_errors_if_any($pdo);
$recr = recq->fetch(PDO::FETCH_OBJ);
$recr = $recq->fetch(PDO::FETCH_OBJ);
$received = $recr->received;
if ($r->target)
$percent = round($received / $r->target * 100, 1);
@ -223,8 +223,8 @@ case 'managelist':
echo '</tr>';
echo "</thead>\n";
$q = $pdo->prepare("SELECT * FROM fundraising_donations WHERE fundraising_campaigns_id='$campaign_id'
\t\t\tAND status='received' ORDER BY datereceived DESC");
$q = $pdo->prepare("SELECT * FROM fundraising_donations WHERE fundraising_campaigns_id='$campaign_id' AND status='received' ORDER BY datereceived DESC");
$q->execute();
while ($r = $q->fetch(PDO::FETCH_OBJ)) {
$goal = getGoal($r->fundraising_goal);
$sq = $pdo->prepare("SELECT * FROM sponsors WHERE id='{$r->sponsors_id}'");
@ -438,7 +438,7 @@ case 'managelist':
echo "<input type=\"button\" onclick=\"return opensendemaildialog($campaign_id,$email->id)\" value=\"" . i18n('Send as email') . '" />';
echo "<br />\n";
if ($email->lastsent) {
list($date, $time) = split(' ', $email->lastsent);
list($date, $time) = explode(' ', $email->lastsent);
echo i18n('Last Sent');
echo '<br />' . format_date($date);
echo '<br />' . format_time($time);
@ -590,13 +590,9 @@ function modifycampaignsfinish(){
});
}
function managecampaignsfinish() {
}
function managecampaignfinish() {
$("#editor_tabs").tabs({
create: function( event, ui ) {
$("#campaign_tabs").tabs({
activate: function( event, ui ) {
update_tab_overview();
update_tab_donations();
update_tab_prospects();

View File

@ -346,7 +346,7 @@ send_header('Fundraising Setup',
$(document).ready(function() {
$("#editor_tabs").tabs({
create: function( event, ui ) {
activate: function( event, ui ) {
update_levels();
update_goals();
update_setup();

View File

@ -81,11 +81,12 @@ switch ($action) {
show_pdo_errors_if_any($pdo);
list($pn, $ps, $pns, $pss) = generateProjectNumber($registrations_id);
// print("Generated Project Number [$pn]");
$stmt = $pdo->prepare("UPDATE projects SET projectnumber='$pn',projectsort='$ps',
$stmt = $pdo->prepare("UPDATE projects SET projectnumber='$pn',projectsort='$ps',
projectnumber_seq='$pns',projectsort_seq='$pss'
WHERE id='$id'");
$stmt->execute();
happy_("Generated and Saved Project Number: $pn");
break;
case 'project_save':
@ -105,7 +106,7 @@ function project_save()
$q = $pdo->prepare("SELECT * FROM projects WHERE registrations_id='{$registrations_id}' AND year='{$config['FAIRYEAR']}'");
$q->execute();
$projectinfo = $q->fetch(PDO::FETCH_OBJ);
if (!projectinfo) {
if (!$projectinfo) {
echo error(i18n('Invalid project to update'));
}
@ -137,7 +138,7 @@ function project_save()
error_('Project title truncated to %1 characters', array($config['participant_project_title_charmax']));
} else
$title = stripslashes($_POST['title']);
$stmt = $pdo->prepare('UPDATE projects SET '
. "title='" . iconv('UTF-8', 'ISO-8859-1//TRANSLIT', $title) . "', "
. "projectdivisions_id='" . intval($_POST['projectdivisions_id'] . "', "
@ -153,6 +154,9 @@ function project_save()
. "feedback='" . iconv('UTF-8', 'ISO-8859-1//TRANSLIT', stripslashes($_POST['feedback'])) . "', "
. "projectsort='" . stripslashes($_POST['projectsort']) . "'"
. "WHERE id='" . intval($_POST['id'])) . "'");
$stmt->execute();
show_pdo_errors_if_any($pdo);
happy_('Project information successfully updated');
@ -175,7 +179,8 @@ function project_save()
function project_load()
{
global $registrations_id, $config, $pdo, $projectcategories_id;
global $registrations_id, $config, $pdo;
// $projectcategories_id=null;
// now lets find out their MAX grade, so we can pre-set the Age Category
$q = $pdo->prepare("SELECT MAX(grade) AS maxgrade FROM students WHERE registrations_id='" . $registrations_id . "'");
@ -297,9 +302,10 @@ function countwords()
$q->execute();
show_pdo_errors_if_any($pdo);
// ###
} else
} else {
$q = $pdo->prepare("SELECT * FROM projectdivisions WHERE year='" . $config['FAIRYEAR'] . "' ORDER BY division");
$q->execute();
$q->execute();
}
echo '<select name="projectdivisions_id">';
echo '<option value="">' . i18n('Select a division') . "</option>\n";

View File

@ -313,7 +313,7 @@ $(document).ready(function() {
$("#editor_tabs").tabs({
create: function( event, ui ) {
activate: function( event, ui ) {
update_students();
update_project();
update_reg();

View File

@ -208,7 +208,8 @@ if (get_value_from_array($_POST, 'action') == 'received' && get_value_from_array
list($projectnumber, $ps, $pns, $pss) = generateProjectNumber($reg_id);
$stmt = $pdo->prepare("UPDATE projects SET projectnumber='$projectnumber',
projectsort='$ps',projectnumber_seq='$pns',projectsort_seq='$pss'
WHERE registrations_id='$reg_id' AND year='{$config['FAIRYEAR']}'");
WHERE registrations_id='$reg_id' AND year=$config{['FAIRYEAR']}");
$stmt->execute();
echo happy(i18n('Assigned Project Number: %1', array($projectnumber)));
} else
$projectnumber = $projectnum;
@ -261,7 +262,7 @@ if (get_value_from_array($_POST, 'action') == 'received' && get_value_from_array
echo notice(i18n('Registration of form %1 cancelled', array($_POST['registration_number'])));
} else if (get_value_from_array($_GET, 'action') == 'unregister' && get_value_from_array($_GET, 'registration_number')) {
$reg_num = intval(trim($_GET['registration_number']));
$q = $pdo - prepare("SELECT registrations.id AS reg_id, projects.id AS proj_id FROM projects,registrations WHERE projects.registrations_id=registrations.id AND registrations.year='{$config['FAIRYEAR']}' AND registrations.num='$reg_num'");
$q = $pdo->prepare("SELECT registrations.id AS reg_id, projects.id AS proj_id FROM projects,registrations WHERE projects.registrations_id=registrations.id AND registrations.year='{$config['FAIRYEAR']}' AND registrations.num='$reg_num'");
$q->execute();
$r = $q->fetch(PDO::FETCH_OBJ);
$stmt = $pdo->prepare("UPDATE projects SET projectnumber=null, projectsort=null, projectnumber_seq=0, projectsort_seq=0 WHERE id='$r->proj_id' AND year='{$config['FAIRYEAR']}'");
@ -298,9 +299,9 @@ if ($showformatbottom) {
echo '</table>';
echo '<br>';
echo i18n(" <lh>'Receive All' notes:</lh> <ul><li>The button will mark all open-status students that have completed registration as having their $signatureformpermissionform received.
\t \t\t\t\t\t\t\t\t\t\t\t\t <li> Students with above status will be emailed a \"$signatureformpermissionform received\" confirmation.
\t \t\t\t\t\t\t\t\t\t\t\t\t <li> Project numbers will be assigned to these students' projects.
\t \t\t\t\t\t\t\t\t\t\t\t\t</ul>");
<li> Students with above status will be emailed a \"$signatureformpermissionform received\" confirmation.
<li> Project numbers will be assigned to these students' projects.
</ul>");
}
if (get_value_from_array($_POST, 'action') == 'receive_all') {

View File

@ -93,9 +93,10 @@ switch ($action) {
$q = $pdo->prepare("SELECT id FROM emergencycontact WHERE students_id='$remove_id' AND registrations_id='$registrations_id' AND year='{$config['FAIRYEAR']}'");
$q->execute();
// no need to error message if this doesnt exist
if ($q->rowCount() == 1)
$stmt = $do->prepare("DELETE FROM emergencycontact WHERE students_id='$remove_id' AND registrations_id='$registrations_id' AND year='{$config['FAIRYEAR']}'");
$stmt->execute();
if ($q->rowCount() == 1) {
$stmt = $pdo->prepare("DELETE FROM emergencycontact WHERE students_id='$remove_id' AND registrations_id='$registrations_id' AND year='{$config['FAIRYEAR']}'");
$stmt->execute();
}
if ($q->rowCount() != 1) {
error_('Invalid student to remove');
exit;
@ -108,9 +109,10 @@ switch ($action) {
$q = $pdo->prepare("SELECT id FROM emergencycontact WHERE students_id='$remove_id' AND registrations_id='$registrations_id' AND year='{$config['FAIRYEAR']}'");
$q->execute();
// no need to error message if this doesnt exist
if ($q->rowCount() == 1)
$stmt = $do->prepare("DELETE FROM emergencycontact WHERE students_id='$remove_id' AND registrations_id='$registrations_id' AND year='{$config['FAIRYEAR']}'");
$stmt->execute();
if ($q->rowCount() == 1) {
$stmt = $pdo->prepare("DELETE FROM emergencycontact WHERE students_id='$remove_id' AND registrations_id='$registrations_id' AND year='{$config['FAIRYEAR']}'");
$stmt->execute();
}
$stmt = $pdo->prepare("DELETE FROM students WHERE id='$remove_id' AND registrations_id='$registrations_id'");
$stmt->execute();
@ -119,9 +121,10 @@ switch ($action) {
$q = $pdo->prepare("SELECT id FROM emergencycontact WHERE students_id='$remove_id' AND registrations_id='$registrations_id' AND year='{$config['FAIRYEAR']}'");
$q->execute();
// no need to error message if this doesnt exist
if ($q->rowCount() == 1)
$stmt = $do->prepare("DELETE FROM emergencycontact WHERE students_id='$remove_id' AND registrations_id='$registrations_id' AND year='{$config['FAIRYEAR']}'");
$stmt->execute();
if ($q->rowCount() == 1) {
$stmt = $pdo->prepare("DELETE FROM emergencycontact WHERE students_id='$remove_id' AND registrations_id='$registrations_id' AND year='{$config['FAIRYEAR']}'");
$stmt->execute();
}
happy_('Student successfully removed');
exit;
@ -171,6 +174,7 @@ function students_save()
. "'" . iconv('UTF-8', 'ISO-8859-1//TRANSLIT', stripslashes($_POST['teachername'][$x])) . "', "
. "'" . iconv('UTF-8', 'ISO-8859-1//TRANSLIT', stripslashes($_POST['teacheremail'][$x])) . "', "
. "'" . $config['FAIRYEAR'] . "')");
$stmt->execute();
happy_('%1 %2 successfully added', array($_POST['firstname'][$x], $_POST['lastname'][$x]));
} else {
@ -471,11 +475,12 @@ function registration_load()
/* Find a reg num */
do {
$regnum = rand(100000, 999999);
$q = $pdo->prepare("SELECT * FROM registrations WHERE num='$regnum' AND year={$config['FAIRYEAR']}");
$q->execute();
$q = $pdo->prepare("SELECT * FROM registrations WHERE num=? AND year=?");
$q->execute([$regnum, $config['FAIRYEAR']]);
} while ($q->rowCount() > 0);
$r['num'] = $regnum;
echo notice(i18n('New registration number generated.'));
echo notice(i18n('This new registration will added when the "Save Registration Information" button is pressed below. At that time the other tabs will become available.'));
} else {

File diff suppressed because it is too large Load Diff

View File

@ -146,7 +146,7 @@ function getSpecialAwardsEligibleForProject($projectid)
AND award_types.id=award_awards.award_types_id
AND award_awards.id=award_awards_projectcategories.award_awards_id
AND award_awards.id=award_awards_projectdivisions.award_awards_id
AND projects.projectcategories_ipreparequeryd=award_awards_projectcategories.projectcategories_id
AND projects.projectcategories_id=award_awards_projectcategories.projectcategories_id
AND projects.projectdivisions_id=award_awards_projectdivisions.projectdivisions_id
AND award_awards.id is not null
AND projects.year='" . $config['FAIRYEAR'] . "'
@ -328,7 +328,7 @@ function getSpecialAwardsNominatedByRegistrationID($id)
");
$awardq->execute();
$projects = array();
while ($prjr = $prjq->fetch(PDO::FETCH_OBJ)) {
while ($prjr = $awardq->fetch(PDO::FETCH_OBJ)) {
$projects[$prjr->projectnumber] = array(
'id' => $prjr->projects_id,
'projectnumber' => $prjr->projectnumber,

View File

@ -22,64 +22,58 @@
*/
?>
<?
function registrationFormsReceived($reg_id="")
{ global $pdo;
if($reg_id) $rid=$reg_id;
else $rid=$_SESSION['registration_id'];
$q=$pdo->prepare("SELECT status FROM registrations WHERE id='$rid'");
function registrationFormsReceived($reg_id = "")
{
global $pdo;
if ($reg_id) $rid = $reg_id;
else $rid = $_SESSION['registration_id'];
$q = $pdo->prepare("SELECT status FROM registrations WHERE id='$rid'");
$q->execute();
$r=$q->fetch(PDO::FETCH_OBJ);
if($r->status=="complete" || $r->status=="paymentpending")
$r = $q->fetch(PDO::FETCH_OBJ);
if ($r->status == "complete" || $r->status == "paymentpending")
return true;
else
return false;
}
function registrationDeadlinePassed()
{
global $config, $pdo;
$q=$pdo->prepare("SELECT (NOW()<'".$config['dates']['regclose']."') AS datecheck");
$q = $pdo->prepare("SELECT (NOW()<'" . $config['dates']['regclose'] . "') AS datecheck");
$q->execute();
$datecheck=$q->fetch(PDO::FETCH_OBJ);
if($datecheck->datecheck==1)
$datecheck = $q->fetch(PDO::FETCH_OBJ);
if ($datecheck->datecheck == 1)
return false;
else
return true;
}
function studentStatus($reg_id="")
function studentStatus($reg_id = "")
{
global $config, $pdo;
if($config['participant_student_personal']=="yes")
$required_fields=array("firstname","lastname","address","city","postalcode","phone","email","grade","dateofbirth","schools_id","sex");
if ($config['participant_student_personal'] == "yes")
$required_fields = array("firstname", "lastname", "address", "city", "postalcode", "phone", "email", "grade", "dateofbirth", "schools_id", "sex");
else
$required_fields=array("firstname","lastname","email","grade","schools_id");
$required_fields = array("firstname", "lastname", "email", "grade", "schools_id");
if($config['participant_student_tshirt']=="yes")
$required_fields[]="tshirt";
if ($config['participant_student_tshirt'] == "yes")
$required_fields[] = "tshirt";
if($reg_id) $rid=$reg_id;
else $rid=$_SESSION['registration_id'];
if ($reg_id) $rid = $reg_id;
else $rid = $_SESSION['registration_id'];
$q=$pdo->prepare("SELECT * FROM students WHERE registrations_id='$rid' AND year='".$config['FAIRYEAR']."'");
$q = $pdo->prepare("SELECT * FROM students WHERE registrations_id='$rid' AND year='" . $config['FAIRYEAR'] . "'");
$q->execute();
//if we dont have the minimum, return incomplete
if($q->rowCount()<$config['minstudentsperproject'])
if ($q->rowCount() < $config['minstudentsperproject'])
return "incomplete";
while($r=$q->fetch(PDO::FETCH_OBJ))
{
foreach ($required_fields AS $req)
{
if($req=="dateofbirth")
{
if($r->$req=="0000-00-00" || !$r->$req)
while ($r = $q->fetch(PDO::FETCH_OBJ)) {
foreach ($required_fields as $req) {
if ($req == "dateofbirth") {
if ($r->$req == "0000-00-00" || !$r->$req)
return "incomplete";
}
else
{
if(!$r->$req)
} else {
if (!$r->$req)
return "incomplete";
}
}
@ -89,28 +83,25 @@ function studentStatus($reg_id="")
return "complete";
}
function emergencycontactStatus($reg_id="")
function emergencycontactStatus($reg_id = "")
{
global $config, $pdo;
$required_fields=array("firstname","lastname","relation","phone1");
$required_fields = array("firstname", "lastname", "relation", "phone1");
if($reg_id) $rid=$reg_id;
else $rid=$_SESSION['registration_id'];
if ($reg_id) $rid = $reg_id;
else $rid = $_SESSION['registration_id'];
$sq=$pdo->prepare("SELECT id FROM students WHERE registrations_id='$rid' AND year='".$config['FAIRYEAR']."'");
$sq = $pdo->prepare("SELECT id FROM students WHERE registrations_id='$rid' AND year='" . $config['FAIRYEAR'] . "'");
$sq->execute();
$numstudents=$sq->rowCount();
$numstudents = $sq->rowCount();
while($sr=$sq->fetch(PDO::FETCH_OBJ))
{
$q=$pdo->prepare("SELECT * FROM emergencycontact WHERE registrations_id='$rid' AND year='".$config['FAIRYEAR']."' AND students_id='$sr->id'");
while ($sr = $sq->fetch(PDO::FETCH_OBJ)) {
$q = $pdo->prepare("SELECT * FROM emergencycontact WHERE registrations_id='$rid' AND year='" . $config['FAIRYEAR'] . "' AND students_id='$sr->id'");
$q->execute();
$r=$q->fetch(PDO::FETCH_OBJ);
$r = $q->fetch(PDO::FETCH_OBJ);
foreach ($required_fields AS $req)
{
if(!$r->$req)
{
foreach ($required_fields as $req) {
if (!$r->$req) {
return "incomplete";
}
}
@ -120,36 +111,34 @@ function emergencycontactStatus($reg_id="")
return "complete";
}
function projectStatus($reg_id="")
function projectStatus($reg_id = "")
{
global $config, $pdo;
$required_fields=array("title","projectcategories_id","projectdivisions_id","language","req_table","req_electricity","summarycountok");
$required_fields = array("title", "projectcategories_id", "projectdivisions_id", "language", "req_table", "req_electricity", "summarycountok");
if($config['participant_short_title_enable'] == 'yes')
if ($config['participant_short_title_enable'] == 'yes')
$required_fields[] = 'shorttitle';
if($config['ethics_questions'] == 'yes'){
if ($config['ethics_questions'] == 'yes') {
$required_fields[] = 'human_participants';
$required_fields[] = 'animal_participants';
}
if($config['participant_project_summary_wordmin'] > 0)
if ($config['participant_project_summary_wordmin'] > 0)
$required_fields[] = 'summary';
if($reg_id) $rid=$reg_id;
else $rid=$_SESSION['registration_id'];
if ($reg_id) $rid = $reg_id;
else $rid = $_SESSION['registration_id'];
$q=$pdo->prepare("SELECT * FROM projects WHERE registrations_id='$rid' AND year='".$config['FAIRYEAR']."'");
$q = $pdo->prepare("SELECT * FROM projects WHERE registrations_id='$rid' AND year='" . $config['FAIRYEAR'] . "'");
$q->execute();
//if we dont have a project entry yet, return empty
if(!$q->rowCount())
if (!$q->rowCount())
return "empty";
while($r=$q->fetch(PDO::FETCH_OBJ))
{
foreach ($required_fields AS $req)
{
if(!$r->$req) {
while ($r = $q->fetch(PDO::FETCH_OBJ)) {
foreach ($required_fields as $req) {
if (!$r->$req) {
return "incomplete";
}
}
@ -160,34 +149,31 @@ function projectStatus($reg_id="")
}
function mentorStatus($reg_id="")
function mentorStatus($reg_id = "")
{
global $config, $pdo;
$required_fields=array("firstname","lastname","phone","email","organization","description");
$required_fields = array("firstname", "lastname", "phone", "email", "organization", "description");
if($reg_id) $rid=$reg_id;
else $rid=$_SESSION['registration_id'];
if ($reg_id) $rid = $reg_id;
else $rid = $_SESSION['registration_id'];
//first check the registrations table to see if 'nummentors' is set, or if its null
$q=$pdo->prepare("SELECT nummentors FROM registrations WHERE id='$rid' AND year='".$config['FAIRYEAR']."'");
$q = $pdo->prepare("SELECT nummentors FROM registrations WHERE id='$rid' AND year='" . $config['FAIRYEAR'] . "'");
$q->execute();
$r=$q->fetch(PDO::FETCH_OBJ);
if($r->nummentors==null)
$r = $q->fetch(PDO::FETCH_OBJ);
if ($r->nummentors == null)
return "incomplete";
$q=$pdo->prepare("SELECT * FROM mentors WHERE registrations_id='$rid' AND year='".$config['FAIRYEAR']."'");
$q->execute();
$q = $pdo->prepare("SELECT * FROM mentors WHERE registrations_id='$rid' AND year='" . $config['FAIRYEAR'] . "'");
$q->execute();
//if we dont have the minimum, return incomplete
if($q->rowCount()<get_value_from_array($config, 'minmentorserproject'))
if ($q->rowCount() < get_value_from_array($config, 'minmentorserproject'))
return "incomplete";
while($r=$q->fetch(PDO::FETCH_OBJ))
{
foreach ($required_fields AS $req)
{
if(!$r->$req)
{
while ($r = $q->fetch(PDO::FETCH_OBJ)) {
foreach ($required_fields as $req) {
if (!$r->$req) {
return "incomplete";
}
}
@ -195,89 +181,84 @@ $q->execute();
//if it made it through without returning incomplete, then we must be complete
return "complete";
}
function safetyStatus($reg_id="")
function safetyStatus($reg_id = "")
{
global $config, $pdo;
if($reg_id) $rid=$reg_id;
else $rid=$_SESSION['registration_id'];
if ($reg_id) $rid = $reg_id;
else $rid = $_SESSION['registration_id'];
//grab all of their answers
$q=$pdo->prepare("SELECT * FROM safety WHERE registrations_id='$rid'");
$q = $pdo->prepare("SELECT * FROM safety WHERE registrations_id='$rid'");
$q->execute();
while($r=$q->fetch(PDO::FETCH_OBJ))
{
$safetyanswers[$r->safetyquestions_id]=$r->answer;
while ($r = $q->fetch(PDO::FETCH_OBJ)) {
$safetyanswers[$r->safetyquestions_id] = $r->answer;
}
//now grab all the questions
$q=$pdo->prepare("SELECT * FROM safetyquestions WHERE year='".$config['FAIRYEAR']."' ORDER BY ord");
$q = $pdo->prepare("SELECT * FROM safetyquestions WHERE year='" . $config['FAIRYEAR'] . "' ORDER BY ord");
$q->execute();
while($r=$q->fetch(PDO::FETCH_OBJ))
{
if($r->required=="yes" && !$safetyanswers[$r->id])
{
while ($r = $q->fetch(PDO::FETCH_OBJ)) {
if ($r->required == "yes" && !$safetyanswers[$r->id]) {
return "incomplete";
}
}
return "complete";
}
function spawardStatus($reg_id="")
function spawardStatus($reg_id = "")
{
global $config, $pdo;
if($reg_id) $rid=$reg_id;
else $rid=$_SESSION['registration_id'];
if ($reg_id) $rid = $reg_id;
else $rid = $_SESSION['registration_id'];
$q=$pdo->prepare("SELECT * FROM projects WHERE registrations_id='$rid'");
$q = $pdo->prepare("SELECT * FROM projects WHERE registrations_id='$rid'");
$q->execute();
$project=$q->fetch(PDO::FETCH_OBJ);
$project = $q->fetch(PDO::FETCH_OBJ);
/* We want this query to get any awards with a NULL award_awards_id */
$awardsq=$pdo->prepare("SELECT
$awardsq = $pdo->prepare("SELECT
projects.id AS projects_id
FROM
project_specialawards_link,
projects
WHERE
project_specialawards_link.projects_id='".$project->id."'
AND projects.year='".$config['FAIRYEAR']."'
project_specialawards_link.projects_id='" . $project->id . "'
AND projects.year='" . $config['FAIRYEAR'] . "'
");
$awardsq->execute();
if($awardsq->rowCount())
if ($awardsq->rowCount())
return "complete";
else
return "incomplete";
}
function tourStatus($reg_id="")
function tourStatus($reg_id = "")
{
global $config, $pdo;
if($reg_id) $rid=$reg_id;
else $rid=$_SESSION['registration_id'];
if ($reg_id) $rid = $reg_id;
else $rid = $_SESSION['registration_id'];
/* Get the students for this project */
$q=$pdo->prepare("SELECT * FROM students WHERE registrations_id='$rid' AND year='".$config['FAIRYEAR']."'");
$q = $pdo->prepare("SELECT * FROM students WHERE registrations_id='$rid' AND year='" . $config['FAIRYEAR'] . "'");
$q->execute();
$num_found = $q->rowCount();
$ret = "complete";
while($s=$q->fetch(PDO::FETCH_OBJ)) {
while ($s = $q->fetch(PDO::FETCH_OBJ)) {
//grab all of their tour prefs
$sid = $s->id;
$qq=$pdo->prepare("SELECT * FROM tours_choice WHERE students_id='$sid' and year='{$config['FAIRYEAR']}' ORDER BY rank");
$qq = $pdo->prepare("SELECT * FROM tours_choice WHERE students_id='$sid' and year='{$config['FAIRYEAR']}' ORDER BY rank");
$qq->execute();
$n_tours = $qq->rowCount();
if($n_tours > 0) {
if ($n_tours > 0) {
/* See if there's a rank 0 tour (rank 0 == their tour assignment) */
$i = $qq->fetch(PDO::FETCH_OBJ);
if($i->rank == 0) {
if ($i->rank == 0) {
/* Yes, there is, no matter what, this student's tour
* selection is complete. */
continue;
@ -286,7 +267,7 @@ function tourStatus($reg_id="")
/* Else, they haven't been assigned a tour, see if they've made
* the appropraite selection(s) */
if( ($n_tours >= $config['tours_choices_min']) && ($n_tours <= $config['tours_choices_max']) ){
if (($n_tours >= $config['tours_choices_min']) && ($n_tours <= $config['tours_choices_max'])) {
continue;
}
$ret = "incomplete";
@ -294,25 +275,25 @@ function tourStatus($reg_id="")
}
return $ret;
}
function namecheckStatus($reg_id="")
function namecheckStatus($reg_id = "")
{
global $config, $pdo;
if($reg_id) {
$q=$pdo->prepare("SELECT * FROM students WHERE
if ($reg_id) {
$q = $pdo->prepare("SELECT * FROM students WHERE
registrations_id='$reg_id'
AND year='".$config['FAIRYEAR']."'");
$q->execute();
AND year='" . $config['FAIRYEAR'] . "'");
$q->execute();
} else {
$q=$pdo->prepare("SELECT * FROM students WHERE
$q = $pdo->prepare("SELECT * FROM students WHERE
id='{$_SESSION['students_id']}'");
$q->execute();
}
$q->execute();
}
/* Get the students for this project */
while($s=$q->fetch(PDO::FETCH_OBJ)) {
if($s->namecheck_complete == 'no') {
while ($s = $q->fetch(PDO::FETCH_OBJ)) {
if ($s->namecheck_complete == 'no') {
return 'incomplete';
}
}
@ -325,8 +306,8 @@ function generateProjectNumber($registration_id)
global $config, $pdo;
$reg_id = $registration_id;
$q=$pdo->prepare("SELECT projects.projectcategories_id,
$q = $pdo->prepare("SELECT projects.projectcategories_id,
projects.projectdivisions_id,
projectcategories.category_shortform,
projectdivisions.division_shortform
@ -342,30 +323,30 @@ function generateProjectNumber($registration_id)
AND projectdivisions.year='{$config['FAIRYEAR']}'
");
$q->execute();
show_pdo_errors_if_any($pdo);
$r=$q->fetch(PDO::FETCH_OBJ);
show_pdo_errors_if_any($pdo);
$r = $q->fetch(PDO::FETCH_OBJ);
$p=array('number'=>array(), 'sort'=>array() );
$p = array('number' => array(), 'sort' => array());
$p['number']['str'] = $config['project_num_format'];
$p['sort']['str'] = trim($config['project_sort_format']);
if($p['sort']['str'] == '') $p['sort']['str'] = $p['number']['str'];
if ($p['sort']['str'] == '') $p['sort']['str'] = $p['number']['str'];
/* Replace each letter with {letter}, so that we can do additional
* replacements below, without risking subsituting in a letter that may
* get replaced. */
foreach(array('number','sort') as $x) {
$p[$x]['str']=preg_replace('[CcDd]', '{\\0}', $p[$x]['str']);
$p[$x]['str']=preg_replace('(N|X)([0-9])?', '{\\0}', $p[$x]['str']);
foreach (array('number', 'sort') as $x) {
$p[$x]['str'] = preg_replace('[CcDd]', '{\\0}', $p[$x]['str']);
$p[$x]['str'] = preg_replace('(N|X)([0-9])?', '{\\0}', $p[$x]['str']);
}
/* Do some replacements that we don' thave to do anything fancy with,
* and setup some variables for future queries */
foreach(array('number','sort') as $x) {
$p[$x]['str']=str_replace('{D}',$r->projectdivisions_id,$p[$x]['str']);
$p[$x]['str']=str_replace('{C}',$r->projectcategories_id,$p[$x]['str']);
$p[$x]['str']=str_replace('{d}',$r->division_shortform,$p[$x]['str']);
$p[$x]['str']=str_replace('{c}',$r->category_shortform,$p[$x]['str']);
foreach (array('number', 'sort') as $x) {
$p[$x]['str'] = str_replace('{D}', $r->projectdivisions_id, $p[$x]['str']);
$p[$x]['str'] = str_replace('{C}', $r->projectcategories_id, $p[$x]['str']);
$p[$x]['str'] = str_replace('{d}', $r->division_shortform, $p[$x]['str']);
$p[$x]['str'] = str_replace('{c}', $r->category_shortform, $p[$x]['str']);
$p[$x]['n_used'] = array();
$p[$x]['x_used'] = array();
}
@ -381,9 +362,10 @@ function generateProjectNumber($registration_id)
AND projectnumber IS NOT NULL");
$q->execute();
show_pdo_errors_if_any($pdo);
while($i = $q->fetch(PDO::FETCH_OBJ)) {
if( ($r->projectdivisions_id == $i->projectdivisions_id)
&&($r->projectcategories_id == $i->projectcategories_id) ) {
while ($i = $q->fetch(PDO::FETCH_OBJ)) {
if (($r->projectdivisions_id == $i->projectdivisions_id)
&& ($r->projectcategories_id == $i->projectcategories_id)
) {
$p['number']['n_used'][] = $i->projectnumber_seq;
$p['sort']['n_used'][] = $i->projectsort_seq;
}
@ -391,20 +373,20 @@ function generateProjectNumber($registration_id)
$p['number']['x_used'][] = $i->projectnumber_seq;
$p['sort']['x_used'][] = $i->projectsort_seq;
}
/* We only support one N or X to keep things simple, find which
* one we need and how much to pad it */
foreach(array('number','sort') as $x) {
if(preg_match("(N|X)([0-9])?", $p[$x]['str'], $regs)) {
foreach (array('number', 'sort') as $x) {
if (preg_match("(N|X)([0-9])?", $p[$x]['str'], $regs)) {
$p[$x]['seq_type'] = $regs[1];
if($regs[2] != '')
if ($regs[2] != '')
$p[$x]['seq_pad'] = $regs[2];
else
$p[$x]['seq_pad'] = ($regs[1] == 'N') ? 2 : 3;
if($regs[1] == 'N')
if ($regs[1] == 'N')
$p[$x]['used'] = $p[$x]['n_used'];
else
else
$p[$x]['used'] = $p[$x]['x_used'];
} else {
/* FIXME: maybe we should error here? Not having an N
@ -419,12 +401,12 @@ function generateProjectNumber($registration_id)
/* Find the lowest unused number. FIXME: this could be a config
* option, we could search for the lowest unused number (if projects
* get deleted), or we could just go +1 beyond the highest */
foreach(array('number','sort') as $x) {
if($p[$x]['seq_type'] == '') continue;
foreach (array('number', 'sort') as $x) {
if ($p[$x]['seq_type'] == '') continue;
$n = 0;
while(1) {
while (1) {
$n++;
if(in_array($n, $p[$x]['used'])) continue;
if (in_array($n, $p[$x]['used'])) continue;
$r = sprintf("%'0{$p[$x]['seq_pad']}d", $n);
$str = preg_replace("{(N|X)([0-9])?}", $r, $p[$x]['str']);
@ -436,7 +418,7 @@ function generateProjectNumber($registration_id)
/* If we're using the same number type for sorting, then we, in
* theory, know what that number is, so we can go ahead and
* blindly use it */
if($p['number']['seq_type'] == $p['sort']['seq_type']) {
if ($p['number']['seq_type'] == $p['sort']['seq_type']) {
$r = sprintf("%'0{$p['sort']['seq_pad']}d", $n);
$p['sort']['str'] = preg_replace("{(N|X)([0-9])?}", $r, $p['sort']['str']);
$p['sort']['n'] = $n;
@ -444,93 +426,108 @@ function generateProjectNumber($registration_id)
}
}
return array($p['number']['str'], $p['sort']['str'],
$p['number']['n'], $p['sort']['n']);
return array(
$p['number']['str'],
$p['sort']['str'],
$p['number']['n'],
$p['sort']['n']
);
}
function computeRegistrationFee($regid)
{
global $config, $pdo;
global $config, $pdo;
$ret = array();
$regfee_items = array();
$q = $pdo->prepare("SELECT * FROM regfee_items
WHERE year='{$config['FAIRYEAR']}'");
$q->execute();
while($i = $q->fetch(PDO::FETCH_ASSOC)) $regfee_items[] = $i;
while ($i = $q->fetch(PDO::FETCH_ASSOC)) $regfee_items[] = $i;
$q=$pdo->prepare("SELECT * FROM students WHERE registrations_id='$regid' AND year='".$config['FAIRYEAR']."'");
$q = $pdo->prepare("SELECT * FROM students WHERE registrations_id='$regid' AND year='" . $config['FAIRYEAR'] . "'");
$q->execute();
$n_students = $q->rowCount();
$n_tshirts = 0;
$sel = array();
while($s = $q->fetch(PDO::FETCH_OBJ)) {
if($s->tshirt != 'none') $n_tshirts++;
while ($s = $q->fetch(PDO::FETCH_OBJ)) {
if ($s->tshirt != 'none') $n_tshirts++;
/* Check their regfee items too */
if($config['participant_regfee_items_enable'] != 'yes') continue;
if ($config['participant_regfee_items_enable'] != 'yes') continue;
$sel_q = $pdo->prepare("SELECT * FROM regfee_items_link
WHERE students_id={$s->id}");
$sel_q->execute();
while($info_q = $sel_q->fetch(PDO::FETCH_ASSOC)) {
while ($info_q = $sel_q->fetch(PDO::FETCH_ASSOC)) {
$sel[] = $info_q['regfee_items_id'];
}
}
$regfee = $regfee ?? 0;
if($config['regfee_per'] == 'student') {
if ($config['regfee_per'] == 'student') {
if ($config['regfee'] == ''){
$config['regfee'] = 0;
}
$f = $config['regfee'] * $n_students;
$ret[] = array( 'id' => 'regfee',
'text' => "Fair Registration (per student)",
'base' => $config['regfee'],
'num' => $n_students,
'ext' => $f );
$regfee += $f;
$ret[] = array(
'id' => 'regfee',
'text' => "Fair Registration (per student)",
'base' => $config['regfee'],
'num' => $n_students,
'ext' => $f
);
$regfee += $f;
} else {
$ret[] = array( 'id' => 'regfee',
'text' => "Fair Registration (per project)",
'base' => $config['regfee'],
'num' => 1,
'ext' => $config['regfee'] );
$ret[] = array(
'id' => 'regfee',
'text' => "Fair Registration (per project)",
'base' => $config['regfee'],
'num' => 1,
'ext' => $config['regfee']
);
$regfee += $config['regfee'];
}
if($config['participant_student_tshirt'] == 'yes') {
if ($config['participant_student_tshirt'] == 'yes') {
$tsc = floatval($config['participant_student_tshirt_cost']);
if($tsc != 0.0) {
if ($tsc != 0.0) {
$f = $n_tshirts * $tsc;
$regfee += $f;
if($n_tshirts != 0) {
$ret[] = array( 'id' => 'tshirt',
'text' => "T-Shirts",
'base' => $tsc,
'num' => $n_tshirts,
'ext' => $f);
}
if ($n_tshirts != 0) {
$ret[] = array(
'id' => 'tshirt',
'text' => "T-Shirts",
'base' => $tsc,
'num' => $n_tshirts,
'ext' => $f
);
}
}
}
/* $sel will be empty if regfee_items is disabled */
foreach($regfee_items as $rfi) {
foreach ($regfee_items as $rfi) {
$cnt = 0;
foreach($sel as $s) if($rfi['id'] == $s) $cnt++;
foreach ($sel as $s) if ($rfi['id'] == $s) $cnt++;
if($cnt == 0) continue;
if ($cnt == 0) continue;
$tsc = floatval($rfi['cost']);
/* If it's per project, force the count to 1 */
if($rfi['per'] == 'project') {
if ($rfi['per'] == 'project') {
$cnt = 1;
}
$f = $tsc * $cnt;
$ret[] = array( 'id' => "regfee_item_{$rfi['id']}",
'text' => "{$rfi['name']} (per {$rfi['per']})" ,
'base' => $tsc,
'num' => $cnt,
'ext' => $f);
$ret[] = array(
'id' => "regfee_item_{$rfi['id']}",
'text' => "{$rfi['name']} (per {$rfi['per']})",
'base' => $tsc,
'num' => $cnt,
'ext' => $f
);
$regfee += $f;
}
return array($regfee, $ret);

View File

@ -157,7 +157,7 @@ if ($registrations_nummentors == null)
$sel = 'selected="selected"';
else
$sel = '';
echo "<option $sel value=\"\">" . i18n('Choose') . "</option>\n";
echo "<option $sel value=\"-1\">" . i18n('Choose') . "</option>\n";
for ($x = $config['minmentorsperproject']; $x <= $config['maxmentorsperproject']; $x++) {
// dont let them go less than the number we found. to go less, they must delete each record individually
if ($x < $numfound)

View File

@ -128,10 +128,12 @@ if (get_value_from_array($_POST, 'action') == 'save') {
}
// now lets find out their MAX grade, so we can pre-set the Age Category
$q = $pdo->prepare("SELECT MAX(grade) AS maxgrade FROM students WHERE registrations_id='" . $_SESSION['registration_id'] . "'");
$q->execute();
$gradeinfo = $q->fetch(PDO::FETCH_OBJ);
// now lets grab all the age categories, so we can choose one based on the max grade
$q = $pdo->prepare("SELECT * FROM projectcategories WHERE year='" . $config['FAIRYEAR'] . "' ORDER BY id");
$q->execute();
@ -139,17 +141,23 @@ while ($r = $q->fetch(PDO::FETCH_OBJ)) {
// save these in an array, just incase we need them later (FIXME: remove this array if we dont need it)
$agecategories[$r->id]['category'] = $r->category;
$agecategories[$r->id]['mingrade'] = $r->mingrade;
$agecategories[$r->id]['maxgrade'] = $r->maxgrade;
$agecategories[$r->id]['maxgrade'] =$r->maxgrade;
if ($gradeinfo->maxgrade >= $r->mingrade && $gradeinfo->maxgrade <= $r->maxgrade) {
$projectcategories_id = $r->id;
}
}
// now select their project info
$q = $pdo->prepare("SELECT * FROM projects WHERE registrations_id='" . $_SESSION['registration_id'] . "' AND year='" . $config['FAIRYEAR'] . "'");
$q->execute();
if ($projectcategories_id == ''){
echo error(i18n('No project age categories'));
}
// check if it exists, if we didnt find any record, lets insert one
if ($q->rowCount() == 0) {
$stmt = $pdo->prepare("INSERT INTO projects (registrations_id,projectcategories_id,year) VALUES ('" . $_SESSION['registration_id'] . "','$projectcategories_id','" . $config['FAIRYEAR'] . "')");
$stmt->execute();
// now query the one we just inserted