forked from science-ation/science-ation
Fix participant registration and fundraising
This commit is contained in:
parent
e77fc688f0
commit
b6494034ad
@ -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
@ -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 */
|
||||
|
465
admin/donors.php
465
admin/donors.php
@ -23,12 +23,13 @@
|
||||
*/
|
||||
?>
|
||||
<?
|
||||
require ('../common.inc.php');
|
||||
require_once ('../user.inc.php');
|
||||
require('../common.inc.php');
|
||||
require_once('../user.inc.php');
|
||||
user_auth_required('committee', 'admin');
|
||||
require_once ('fundraising_common.inc.php');
|
||||
require_once('fundraising_common.inc.php');
|
||||
|
||||
global $pdo;
|
||||
|
||||
switch (get_value_from_array($_GET, 'action')) {
|
||||
case 'organizationinfo_load':
|
||||
$id = intval($_GET['id']);
|
||||
@ -41,6 +42,8 @@ switch (get_value_from_array($_GET, 'action')) {
|
||||
|
||||
case 'organizationinfo_save':
|
||||
$id = intval($_POST['sponsor_id']);
|
||||
|
||||
|
||||
if ($id == -1) {
|
||||
echo "INSERT INTO sponsors (year) VALUES ('" . $config['FAIRYEAR'] . "')";
|
||||
$q = $pdo->prepare("INSERT INTO sponsors (year) VALUES ('" . $config['FAIRYEAR'] . "')");
|
||||
@ -51,8 +54,20 @@ switch (get_value_from_array($_GET, 'action')) {
|
||||
$createnew = true;
|
||||
} else
|
||||
$createnew = false;
|
||||
|
||||
if ($id) {
|
||||
|
||||
if ($_POST['fundingselectiondate'] == '') {
|
||||
$_POST['fundingselectiondate'] = '0000-00-00';
|
||||
}
|
||||
|
||||
if ($_POST['proposalsubmissiondate'] == '') {
|
||||
$_POST['proposalsubmissiondate'] = '0000-00-00';
|
||||
}
|
||||
|
||||
if (!$_POST['waiveraccepted']) {
|
||||
$_POST['waiveraccepted'] = 'no';
|
||||
}
|
||||
|
||||
$exec = 'UPDATE sponsors SET '
|
||||
. "donortype='" . stripslashes($_POST['donortype']) . "', "
|
||||
. "organization='" . stripslashes($_POST['organization']) . "', "
|
||||
@ -302,7 +317,7 @@ switch (get_value_from_array($_GET, 'action')) {
|
||||
$supporttypes[] = 'Sponsorship';
|
||||
echo "<select name=\"supporttype\">\n";
|
||||
echo "<option value=\"\">Choose type of support</option>\n";
|
||||
foreach ($supporttypes AS $st) {
|
||||
foreach ($supporttypes as $st) {
|
||||
echo "<option value=\"$st\">" . i18n($st) . "</option>\n";
|
||||
}
|
||||
echo "</select>\n";
|
||||
@ -364,24 +379,25 @@ switch (get_value_from_array($_GET, 'action')) {
|
||||
break;
|
||||
|
||||
case 'newcontactsearch':
|
||||
if ($_POST['email'])
|
||||
if ($_POST['email']) {
|
||||
$q = $pdo->prepare("SELECT *,MAX(year) FROM users WHERE email='" . trim($_POST['email']) . "' GROUP BY uid HAVING deleted='no'");
|
||||
$q->execute();
|
||||
}
|
||||
if ($r = $q->fetch(PDO::FETCH_OBJ)) {
|
||||
echo i18n('There is an exact email address match for %1', array($_POST['email']));
|
||||
echo '<ul>';
|
||||
echo "<li><a href=\"#\" onclick=\"useexistingcontact($r->uid)\">$r->firstname $r->lastname $r->email $r->phonehome</a></li>\n";
|
||||
echo '</ul>';
|
||||
|
||||
?>
|
||||
?>
|
||||
<script type="text/javascript">
|
||||
$("#contactnewsave").attr("disabled","disabled");
|
||||
$("#contactnewsave").attr("disabled", "disabled");
|
||||
</script>
|
||||
<?
|
||||
} else {
|
||||
?>
|
||||
<script type="text/javascript">
|
||||
$("#contactnewsave").attr("disabled","");
|
||||
$("#contactnewsave").attr("disabled", "");
|
||||
</script>
|
||||
<?
|
||||
|
||||
@ -463,10 +479,14 @@ switch (get_value_from_array($_GET, 'action')) {
|
||||
break;
|
||||
}
|
||||
|
||||
send_header('Donor/Sponsor Management',
|
||||
array('Committee Main' => 'committee_main.php',
|
||||
send_header(
|
||||
'Donor/Sponsor Management',
|
||||
array(
|
||||
'Committee Main' => 'committee_main.php',
|
||||
'Administration' => 'admin/index.php',
|
||||
'Fundraising' => 'admin/fundraising.php'));
|
||||
'Fundraising' => 'admin/fundraising.php'
|
||||
)
|
||||
);
|
||||
|
||||
// delete the contact who has been submitted in _POST
|
||||
function delete_contact()
|
||||
@ -709,7 +729,7 @@ function draw_contact_form($sponsor_id, $contact = null)
|
||||
<select name="salutation">
|
||||
<option value=""><?= i18n('Choose') ?></option>
|
||||
<?
|
||||
foreach ($salutations AS $salutation) {
|
||||
foreach ($salutations as $salutation) {
|
||||
if ($contact['salutation'] == $salutation)
|
||||
$sel = 'selected="selected"';
|
||||
else
|
||||
@ -727,38 +747,51 @@ function draw_contact_form($sponsor_id, $contact = null)
|
||||
$d = '';
|
||||
?>
|
||||
|
||||
<td><input type="text" name="position" <?= $d ?> value = "<?= htmlspecialchars($contact['position']) ?>"></td>
|
||||
<td><input type="text" name="position" <?= $d ?> value="<?= htmlspecialchars($contact['position']) ?>"></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td><?= i18n('First Name'); ?></td>
|
||||
<td><input <?= $newcontactsearch ?> type="text" name="firstname" value = "<?= htmlspecialchars($contact['firstname']) ?>"></td>
|
||||
<td><input <?= $newcontactsearch ?> type="text" name="firstname" value="<?= htmlspecialchars($contact['firstname']) ?>"></td>
|
||||
<td><?= i18n('Last Name'); ?></td>
|
||||
<td><input <?= $newcontactsearch ?> type="text" name="lastname" value = "<?= htmlspecialchars($contact['lastname']) ?>"></td>
|
||||
<td><input <?= $newcontactsearch ?> type="text" name="lastname" value="<?= htmlspecialchars($contact['lastname']) ?>"></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td><?= i18n('Email'); ?></td>
|
||||
<td colspan="3"><input <?= $newcontactsearch ?> type="text" name="email" size="60" value = "<?= htmlspecialchars($contact['email']) ?>"></td>
|
||||
<td colspan="3"><input <?= $newcontactsearch ?> type="text" name="email" size="60" value="<?= htmlspecialchars($contact['email']) ?>"></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td><?= i18n('Phone (Work)'); ?></td>
|
||||
<td><input type="text" name="phonework" value = "<?= htmlspecialchars($contact['phonework']) ?>"></td>
|
||||
<td><input type="text" name="phonework" value="<?= htmlspecialchars($contact['phonework']) ?>"></td>
|
||||
<td><?= i18n('Phone (Cell)'); ?></td>
|
||||
<td><input type="text" name="phonecell" value = "<?= htmlspecialchars($contact['phonecell']) ?>"></td>
|
||||
<td><input type="text" name="phonecell" value="<?= htmlspecialchars($contact['phonecell']) ?>"></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td><?= i18n('Phone (Home)'); ?></td>
|
||||
<td><input type="text" name="phonehome" value = "<?= htmlspecialchars($contact['phonehome']) ?>"></td>
|
||||
<td><input type="text" name="phonehome" value="<?= htmlspecialchars($contact['phonehome']) ?>"></td>
|
||||
<td><?= i18n('Fax'); ?></td>
|
||||
<td><input type="text" name="fax" value = "<?= htmlspecialchars($contact['fax']) ?>"></td>
|
||||
<td><input type="text" name="fax" value="<?= htmlspecialchars($contact['fax']) ?>"></td>
|
||||
</tr>
|
||||
|
||||
<tr><td><?= i18n('Address 1') ?></td><td colspan="3"><input type="text" name="address" size="60" maxlength="64" value="<?= htmlspecialchars($contact['address']) ?>" /></td></tr>
|
||||
<tr><td><?= i18n('Address 2') ?></td><td colspan="3"><input type="text" name="address2" size="60" maxlength="64" value="<?= htmlspecialchars($contact['address2']) ?>" /></td></tr>
|
||||
<tr><td><?= i18n('City') ?></td><td><input id="city" type="text" name="city" size="16" maxlength="32" value="<?= htmlspecialchars($contact['city']) ?>" /></td>
|
||||
<td><?= i18n($config['provincestate']) ?></td><td>
|
||||
<tr>
|
||||
<td><?= i18n('Address 1') ?></td>
|
||||
<td colspan="3"><input type="text" name="address" size="60" maxlength="64" value="<?= htmlspecialchars($contact['address']) ?>" /></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td><?= i18n('Address 2') ?></td>
|
||||
<td colspan="3"><input type="text" name="address2" size="60" maxlength="64" value="<?= htmlspecialchars($contact['address2']) ?>" /></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td><?= i18n('City') ?></td>
|
||||
<td><input id="city" type="text" name="city" size="16" maxlength="32" value="<?= htmlspecialchars($contact['city']) ?>" /></td>
|
||||
<td><?= i18n($config['provincestate']) ?></td>
|
||||
<td>
|
||||
<? emit_province_selector('province_code', $contact['province']); ?>
|
||||
</td></tr>
|
||||
<tr><td><?= i18n($config['postalzip']) ?></td><td colspan="3"><input type="text" name="postalcode" size="8" maxlength="7" value="<?= htmlspecialchars($contact['postalcode']) ?>" /></td></tr>
|
||||
</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td><?= i18n($config['postalzip']) ?></td>
|
||||
<td colspan="3"><input type="text" name="postalcode" size="8" maxlength="7" value="<?= htmlspecialchars($contact['postalcode']) ?>" /></td>
|
||||
</tr>
|
||||
|
||||
|
||||
<tr>
|
||||
@ -771,7 +804,7 @@ function draw_contact_form($sponsor_id, $contact = null)
|
||||
<label><?= i18n('Yes') ?><input type="radio" name="primary" value="yes" <? if ($contact['primary'] == 'yes') echo 'checked="checked"'; ?></label>
|
||||
<label><?= i18n('No') ?><input type="radio" name="primary" value="no" <? if ($contact['primary'] != 'yes') echo 'checked="checked"'; ?>></label>
|
||||
</td>
|
||||
<?php
|
||||
<?php
|
||||
echo "<td align=\"center\"><input $newcontactsave type=\"submit\" value=\"" . i18n('Save') . '" onClick="return contactsinfo_save(\'' . $id . '\')" /></td>';
|
||||
echo '<td>';
|
||||
if ($id != 'new')
|
||||
@ -780,7 +813,7 @@ function draw_contact_form($sponsor_id, $contact = null)
|
||||
?>
|
||||
</tr>
|
||||
</table>
|
||||
</form>
|
||||
</form>
|
||||
<?php
|
||||
}
|
||||
|
||||
@ -789,7 +822,7 @@ function draw_activityinfo_form()
|
||||
global $config, $pdo;
|
||||
$sponsorid = $_GET['id'];
|
||||
// we'll start by drawing the table header
|
||||
?>
|
||||
?>
|
||||
<form id="activityinfo">
|
||||
<table class="tableview" style="width:99%">
|
||||
<thead>
|
||||
@ -801,21 +834,21 @@ function draw_activityinfo_form()
|
||||
<th><?= i18n('Notes') ?></th>
|
||||
</tr>
|
||||
<tr>
|
||||
<td align="center" ><input type="submit" value="<?= i18n('Add Log') ?>" onClick="return activityinfo_save()" /></td>
|
||||
<td align="center"><input type="submit" value="<?= i18n('Add Log') ?>" onClick="return activityinfo_save()" /></td>
|
||||
<td align="center"><?= $_SESSION['name'] ?></td>
|
||||
<td align="center">
|
||||
<?php
|
||||
<?php
|
||||
echo '<select name="type">';
|
||||
echo '<option value="">' . i18n('Choose Type') . "</option>\n";
|
||||
$logtypes = array('Appeal', 'Phone Call', 'Email', 'Personal Visit', 'Other');
|
||||
foreach ($logtypes AS $lt) {
|
||||
foreach ($logtypes as $lt) {
|
||||
echo "<option value=\"$lt\">" . i18n($lt) . "</option>\n";
|
||||
}
|
||||
echo "</select>\n";
|
||||
?>
|
||||
</td>
|
||||
<td align="center">
|
||||
<?php
|
||||
<?php
|
||||
$q = $pdo->prepare("SELECT * FROM fundraising_campaigns WHERE fiscalyear='{$config['FISCALYEAR']}' ORDER BY name");
|
||||
$q->execute();
|
||||
echo '<select name="fundraising_campaigns_id">';
|
||||
@ -826,19 +859,19 @@ function draw_activityinfo_form()
|
||||
echo "</select>\n";
|
||||
?>
|
||||
</td>
|
||||
<td><input type="text" name="comment" style="width: 99%;"/></td>
|
||||
<td><input type="text" name="comment" style="width: 99%;" /></td>
|
||||
</tr>
|
||||
</thead>
|
||||
<tbody>
|
||||
|
||||
|
||||
<?php
|
||||
<?php
|
||||
$query = "SELECT CONCAT_WS(' ', users.firstname, users.lastname) AS name, fdl.dt, fdl.log, fdl.type,
|
||||
fundraising_campaigns.name AS campaignname
|
||||
\t FROM fundraising_donor_logs AS fdl
|
||||
\t LEFT JOIN users ON fdl.users_id=users.id
|
||||
\t LEFT JOIN fundraising_campaigns ON fdl.fundraising_campaigns_id=fundraising_campaigns.id
|
||||
\t WHERE sponsors_id=" . $sponsorid . ' ORDER BY dt DESC';
|
||||
FROM fundraising_donor_logs AS fdl
|
||||
LEFT JOIN users ON fdl.users_id=users.id
|
||||
LEFT JOIN fundraising_campaigns ON fdl.fundraising_campaigns_id=fundraising_campaigns.id
|
||||
WHERE sponsors_id=" . $sponsorid . ' ORDER BY dt DESC';
|
||||
// echo "<tr><td colspan=\"3\">" . $query . "</td></tr>";
|
||||
$q = $pdo->prepare($query);
|
||||
$q->execute();
|
||||
@ -857,7 +890,8 @@ function draw_activityinfo_form()
|
||||
}
|
||||
?>
|
||||
|
||||
</tbody></table>
|
||||
</tbody>
|
||||
</table>
|
||||
</form>
|
||||
<?php
|
||||
}
|
||||
@ -920,18 +954,18 @@ function getDonationString($id)
|
||||
|
||||
?>
|
||||
<script type="text/javascript">
|
||||
/* Setup the popup window */
|
||||
$(document).ready(function() {
|
||||
/*`
|
||||
/* Setup the popup window */
|
||||
$(document).ready(function() {
|
||||
/*`
|
||||
$("#open_editor").dialog({
|
||||
bgiframe: true, autoOpen: false,
|
||||
modal: true, resizable: false,
|
||||
draggable: false
|
||||
});
|
||||
*/
|
||||
*/
|
||||
|
||||
$("#editor_tabs").tabs({
|
||||
create: function( event, ui ) {
|
||||
create: function(event, ui) {
|
||||
update_organizationinfo();
|
||||
update_sponsorshipinfo();
|
||||
update_contactsinfo();
|
||||
@ -940,23 +974,28 @@ $(document).ready(function() {
|
||||
selected: 0
|
||||
});
|
||||
|
||||
$("#organizationinfo_fundingselectiondate").datepicker({ dateFormat: 'yy-mm-dd'});
|
||||
$("#organizationinfo_proposalsubmissiondate").datepicker({ dateFormat: 'yy-mm-dd'});
|
||||
$("#organizationinfo_fundingselectiondate").datepicker({
|
||||
dateFormat: 'yy-mm-dd'
|
||||
});
|
||||
$("#organizationinfo_proposalsubmissiondate").datepicker({
|
||||
dateFormat: 'yy-mm-dd'
|
||||
});
|
||||
//, showOn: 'button', buttonText: "<?= i18n('calendar') ?>" });
|
||||
open_search();
|
||||
});
|
||||
});
|
||||
|
||||
|
||||
var sponsor_id=0;
|
||||
function open_editor(id) {
|
||||
sponsor_id=id;
|
||||
var sponsor_id = 0;
|
||||
|
||||
function open_editor(id) {
|
||||
sponsor_id = id;
|
||||
$("#donor_editor").show();
|
||||
$("#searchbrowse").hide();
|
||||
$("#searchresults").hide();
|
||||
|
||||
if(id==-1) {
|
||||
if (id == -1) {
|
||||
$('#editor_tabs').tabs('option', 'selected', 0);
|
||||
$('#editor_tabs').tabs('option', 'disabled', [1,2,3]);
|
||||
$('#editor_tabs').tabs('option', 'disabled', [1, 2, 3]);
|
||||
|
||||
$("#organizationinfo_organization").val("");
|
||||
$("#organizationinfo_address").val("");
|
||||
@ -974,37 +1013,36 @@ function open_editor(id) {
|
||||
$("#organizationinfo_proposalsubmissiondate").val("");
|
||||
$("#organizationinfo_notes").val("");
|
||||
|
||||
$("#update_contactsinfoorganizationinfo_save_button").attr('disabled','disabled');
|
||||
$("[name=donortype]").attr('checked','');
|
||||
$("#update_contactsinfoorganizationinfo_save_button").attr('disabled', 'disabled');
|
||||
$("[name=donortype]").attr('checked', '');
|
||||
|
||||
}
|
||||
else {
|
||||
} else {
|
||||
$('#editor_tabs').tabs('option', 'selected', 0);
|
||||
$('#editor_tabs').tabs('option', 'disabled', []);
|
||||
}
|
||||
|
||||
update_organizationinfo();
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
function open_search() {
|
||||
function open_search() {
|
||||
$("#donor_editor").hide();
|
||||
$("#searchbrowse").show();
|
||||
donorsearch(false);
|
||||
}
|
||||
function update_organizationinfo()
|
||||
{
|
||||
var id=sponsor_id;
|
||||
if(!sponsor_id)
|
||||
}
|
||||
|
||||
function update_organizationinfo() {
|
||||
var id = sponsor_id;
|
||||
if (!sponsor_id)
|
||||
return false;
|
||||
if(sponsor_id==-1) {
|
||||
if (sponsor_id == -1) {
|
||||
$("#sponsor_id").val(-1);
|
||||
return false;
|
||||
}
|
||||
|
||||
$.getJSON("<?= $_SERVER['PHP_SELF'] ?>?action=organizationinfo_load&id="+id,
|
||||
function(json){
|
||||
$("#donor_name").html("<h3>"+json.organization+"</h3>");
|
||||
$.getJSON("<?= $_SERVER['PHP_SELF'] ?>?action=organizationinfo_load&id=" + id,
|
||||
function(json) {
|
||||
$("#donor_name").html("<h3>" + json.organization + "</h3>");
|
||||
$("#sponsor_id").val(json.id);
|
||||
$("#organizationinfo_organization").val(json.organization);
|
||||
$("#organizationinfo_address").val(json.address);
|
||||
@ -1027,54 +1065,53 @@ function update_organizationinfo()
|
||||
|
||||
donortypechange();
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
function organizationinfo_save() {
|
||||
function organizationinfo_save() {
|
||||
|
||||
//if we're creating we need to do the post, and get the id it returns, so we can re-open the popup window with that id
|
||||
if($("#sponsor_id").val()==-1) {
|
||||
if ($("#sponsor_id").val() == -1) {
|
||||
$.post("<? $_SERVER['PHP_SELF'] ?>?action=organizationinfo_save", $("#organizationinfo").serializeArray(),
|
||||
function(json) {
|
||||
open_editor(json.id);
|
||||
},
|
||||
"json");
|
||||
}
|
||||
else
|
||||
} else
|
||||
$("#debug").load("<? $_SERVER['PHP_SELF'] ?>?action=organizationinfo_save", $("#organizationinfo").serializeArray());
|
||||
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
function update_sponsorshipinfo()
|
||||
{
|
||||
var id=sponsor_id;
|
||||
$("#editor_tab_sponsorship").load("<?= $_SERVER['PHP_SELF'] ?>?action=sponsorshipinfo_load&id="+id, null,function() {
|
||||
$(".date").datepicker({ dateFormat: 'yy-mm-dd' });
|
||||
function update_sponsorshipinfo() {
|
||||
var id = sponsor_id;
|
||||
$("#editor_tab_sponsorship").load("<?= $_SERVER['PHP_SELF'] ?>?action=sponsorshipinfo_load&id=" + id, null, function() {
|
||||
$(".date").datepicker({
|
||||
dateFormat: 'yy-mm-dd'
|
||||
});
|
||||
$('.tableview').tablesorter();
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
function sponsorshipinfo_save() {
|
||||
function sponsorshipinfo_save() {
|
||||
$("#debug").load("<? $_SERVER['PHP_SELF'] ?>?action=sponsorshipinfo_save", $("#sponsorshipinfo").serializeArray());
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
function update_contactsinfo()
|
||||
{
|
||||
var id=sponsor_id;
|
||||
$("#editor_tab_contacts").load("<?= $_SERVER['PHP_SELF'] ?>?action=contactsinfo_load&id="+id, null,
|
||||
function update_contactsinfo() {
|
||||
var id = sponsor_id;
|
||||
$("#editor_tab_contacts").load("<?= $_SERVER['PHP_SELF'] ?>?action=contactsinfo_load&id=" + id, null,
|
||||
function() {
|
||||
$("#contactaccordion").accordion({
|
||||
heightStyle: "content"
|
||||
});
|
||||
}
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
function contactsinfo_save(uid) {
|
||||
var id=sponsor_id;
|
||||
function contactsinfo_save(uid) {
|
||||
var id = sponsor_id;
|
||||
print(id);
|
||||
$("#debug").load("<? $_SERVER['PHP_SELF'] ?>?action=contactsinfo_save&id="+id, $("#contact_" + uid).serializeArray(),
|
||||
$("#debug").load("<? $_SERVER['PHP_SELF'] ?>?action=contactsinfo_save&id=" + id, $("#contact_" + uid).serializeArray(),
|
||||
function() {
|
||||
$("#contactaccordion").accordion({
|
||||
heightStyle: "content"
|
||||
@ -1082,11 +1119,11 @@ function contactsinfo_save(uid) {
|
||||
update_contactsinfo();
|
||||
});
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
function contactsinfo_delete(uid) {
|
||||
var id=sponsor_id;
|
||||
$("#debug").load("<? $_SERVER['PHP_SELF'] ?>?action=contactsinfo_delete&id="+id, $("#contact_" + uid).serializeArray(),
|
||||
function contactsinfo_delete(uid) {
|
||||
var id = sponsor_id;
|
||||
$("#debug").load("<? $_SERVER['PHP_SELF'] ?>?action=contactsinfo_delete&id=" + id, $("#contact_" + uid).serializeArray(),
|
||||
function() {
|
||||
$("#contactaccordion").accordion({
|
||||
heightStyle: "content"
|
||||
@ -1094,97 +1131,111 @@ function contactsinfo_delete(uid) {
|
||||
update_contactsinfo();
|
||||
});
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
function update_activityinfo()
|
||||
{
|
||||
var id=sponsor_id;
|
||||
function update_activityinfo() {
|
||||
var id = sponsor_id;
|
||||
$("#editor_tab_activity").load(
|
||||
"<?= $_SERVER['PHP_SELF'] ?>?action=activityinfo_load&id="+id,
|
||||
"<?= $_SERVER['PHP_SELF'] ?>?action=activityinfo_load&id=" + id,
|
||||
null,
|
||||
function(){$('.tableview').tablesorter(); }
|
||||
function() {
|
||||
$('.tableview').tablesorter();
|
||||
}
|
||||
);
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
function activityinfo_save() {
|
||||
var id=sponsor_id;
|
||||
$("#debug").load("<? $_SERVER['PHP_SELF'] ?>?action=activityinfo_save&id="+id, $("#activityinfo").serializeArray(),
|
||||
function(){
|
||||
function activityinfo_save() {
|
||||
var id = sponsor_id;
|
||||
$("#debug").load("<? $_SERVER['PHP_SELF'] ?>?action=activityinfo_save&id=" + id, $("#activityinfo").serializeArray(),
|
||||
function() {
|
||||
update_activityinfo();
|
||||
});
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
function donorsearch(realsearch) {
|
||||
function donorsearch(realsearch) {
|
||||
$("#searchresults").show();
|
||||
if(realsearch)
|
||||
$("#searchresults").load("donors_search.php", $("#searchform").serializeArray(), function(){$('.tableview').tablesorter(); });
|
||||
if (realsearch)
|
||||
$("#searchresults").load("donors_search.php", $("#searchform").serializeArray(), function() {
|
||||
$('.tableview').tablesorter();
|
||||
});
|
||||
else
|
||||
$("#searchresults").load("donors_search.php", null, function(){$('.tableview').tablesorter(); }); //, $("#searchform").serializeArray());
|
||||
$("#searchresults").load("donors_search.php", null, function() {
|
||||
$('.tableview').tablesorter();
|
||||
}); //, $("#searchform").serializeArray());
|
||||
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
var searchtimer;
|
||||
var searchtimer;
|
||||
|
||||
function newcontactsearch() {
|
||||
function newcontactsearch() {
|
||||
clearTimeout(searchtimer);
|
||||
searchtimer=setTimeout('donewcontactsearch()',300);
|
||||
searchtimer = setTimeout('donewcontactsearch()', 300);
|
||||
return true;
|
||||
}
|
||||
function donewcontactsearch() {
|
||||
$("#newcontactsearch").load("<?= $_SERVER['PHP_SELF'] ?>?action=newcontactsearch",$("#contact_new").serializeArray());
|
||||
}
|
||||
}
|
||||
|
||||
function useexistingcontact(uid) {
|
||||
var id=sponsor_id;
|
||||
$("#debug").load("<? $_SERVER['PHP_SELF'] ?>?action=contactsinfo_addexisting",{id: id, uid: uid} ,function() { update_contactsinfo(); });
|
||||
}
|
||||
function donewcontactsearch() {
|
||||
$("#newcontactsearch").load("<?= $_SERVER['PHP_SELF'] ?>?action=newcontactsearch", $("#contact_new").serializeArray());
|
||||
}
|
||||
|
||||
function togglefulldonationhistory() {
|
||||
function useexistingcontact(uid) {
|
||||
var id = sponsor_id;
|
||||
$("#debug").load("<? $_SERVER['PHP_SELF'] ?>?action=contactsinfo_addexisting", {
|
||||
id: id,
|
||||
uid: uid
|
||||
}, function() {
|
||||
update_contactsinfo();
|
||||
});
|
||||
}
|
||||
|
||||
function togglefulldonationhistory() {
|
||||
$("#fulldonationhistory").toggle('slow');
|
||||
$("#thisyeardonationhistory").toggle('slow');
|
||||
}
|
||||
}
|
||||
|
||||
function campaignchange() {
|
||||
var campaignid=$("#fundraising_campaign_id").val();
|
||||
var goal=defaultgoals[campaignid];
|
||||
function campaignchange() {
|
||||
var campaignid = $("#fundraising_campaign_id").val();
|
||||
var goal = defaultgoals[campaignid];
|
||||
$("#fundraising_goal").val(goal);
|
||||
}
|
||||
}
|
||||
|
||||
function donortypechange() {
|
||||
if($("input[name='donortype']:checked").val()=="organization") {
|
||||
$("#organizationinfo_logo").attr("disabled","");
|
||||
$("#organizationinfo_donationpolicyurl").attr("disabled","");
|
||||
$("#organizationinfo_fundingselectiondate").attr("disabled","");
|
||||
$("#organizationinfo_proposalsubmissiondate").attr("disabled","");
|
||||
function donortypechange() {
|
||||
if ($("input[name='donortype']:checked").val() == "organization") {
|
||||
$("#organizationinfo_logo").removeAttr("disabled", "");
|
||||
$("#organizationinfo_donationpolicyurl").removeAttr("disabled", "");
|
||||
$("#organizationinfo_fundingselectiondate").removeAttr("disabled", "");
|
||||
$("#organizationinfo_proposalsubmissiondate").removeAttr("disabled", "");
|
||||
} else if ($("input[name='donortype']:checked").val() == "individual") {
|
||||
$("#organizationinfo_logo").attr("disabled", "disabled");
|
||||
$("#organizationinfo_donationpolicyurl").attr("disabled", "disabled");
|
||||
$("#organizationinfo_fundingselectiondate").attr("disabled", "disabled");
|
||||
$("#organizationinfo_proposalsubmissiondate").attr("disabled", "disabled");
|
||||
} else {}
|
||||
$("#organizationinfo_save_button").removeAttr('disabled', '');
|
||||
}
|
||||
else if($("input[name='donortype']:checked").val()=="individual") {
|
||||
$("#organizationinfo_logo").attr("disabled","disabled");
|
||||
$("#organizationinfo_donationpolicyurl").attr("disabled","disabled");
|
||||
$("#organizationinfo_fundingselectiondate").attr("disabled","disabled");
|
||||
$("#organizationinfo_proposalsubmissiondate").attr("disabled","disabled");
|
||||
}
|
||||
else {
|
||||
}
|
||||
$("#organizationinfo_save_button").attr('disabled','');
|
||||
}
|
||||
|
||||
function adddonation() {
|
||||
var id=sponsor_id;
|
||||
$("#debug").load("<? $_SERVER['PHP_SELF'] ?>?action=donation_add", $("#addnewdonationform").serializeArray(),function() { update_sponsorshipinfo(); });
|
||||
function adddonation() {
|
||||
var id = sponsor_id;
|
||||
$("#debug").load("<? $_SERVER['PHP_SELF'] ?>?action=donation_add", $("#addnewdonationform").serializeArray(), function() {
|
||||
update_sponsorshipinfo();
|
||||
});
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
function removedonation(donationid,sponsorid) {
|
||||
if(confirmClick('Are you sure you want to remove this donation/sponsorship?')) {
|
||||
$("#debug").load("<? $_SERVER['PHP_SELF'] ?>?action=donation_remove", {id: donationid, sponsors_id: sponsorid},function() { update_sponsorshipinfo(); });
|
||||
function removedonation(donationid, sponsorid) {
|
||||
if (confirmClick('Are you sure you want to remove this donation/sponsorship?')) {
|
||||
$("#debug").load("<? $_SERVER['PHP_SELF'] ?>?action=donation_remove", {
|
||||
id: donationid,
|
||||
sponsors_id: sponsorid
|
||||
}, function() {
|
||||
update_sponsorshipinfo();
|
||||
});
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
}
|
||||
</script>
|
||||
<?
|
||||
|
||||
@ -1206,7 +1257,7 @@ echo '</tr></table>';
|
||||
echo '<hr />';
|
||||
?>
|
||||
<div id="donor_editor" title="Donor/Sponsor Editor" style="display: none; width: 770px;">
|
||||
<div id="donor_name"></div>
|
||||
<div id="donor_name"></div>
|
||||
<div id="editor_tabs">
|
||||
<ul>
|
||||
<li><a href="#editor_tab_organization"><span><?= i18n('Donor/Sponsor Details') ?></span></a></li>
|
||||
@ -1219,33 +1270,68 @@ echo '<hr />';
|
||||
<form enctype="multipart/form-data" id="organizationinfo">
|
||||
<input type="hidden" name="sponsor_id" id="sponsor_id" value="0">
|
||||
<table class="tableedit" border=0>
|
||||
<tr><td><?= i18n('Donor Type') ?></td><td colspan="5">
|
||||
<tr>
|
||||
<td><?= i18n('Donor Type') ?></td>
|
||||
<td colspan="5">
|
||||
<input id="donortype_individual" type="radio" name="donortype" value="individual" onchange="return donortypechange()" /><label for="donortype_individual"><?= i18n('Individual') ?></label>
|
||||
<input id="donortype_organization" type="radio" name="donortype" value="organization" onchange="return donortypechange()" /><label for="donortype_organization"><?= i18n('Organization') ?></label>
|
||||
</td></tr>
|
||||
<tr><td><?= i18n('Name') ?></td><td colspan="5"><input class="translatable" type="text" id="organizationinfo_organization" name="organization" size="60" maxlength="128" /></td></tr>
|
||||
<tr><td><?= i18n('Address 1') ?></td><td colspan="5"><input id="organizationinfo_address" type="text" name="address" size="60" maxlength="64" /></td></tr>
|
||||
<tr><td><?= i18n('Address 2') ?></td><td colspan="5"><input id="organizationinfo_address2" type="text" name="address2" size="60" maxlength="64" /></td></tr>
|
||||
<tr><td><?= i18n('City') ?></td><td><input id="organizationinfo_city" type="text" name="city" size="16" maxlength="32" /></td>
|
||||
<td><?= i18n($config['provincestate']) ?></td><td>
|
||||
</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td><?= i18n('Name') ?></td>
|
||||
<td colspan="5"><input class="translatable" type="text" id="organizationinfo_organization" name="organization" size="60" maxlength="128" /></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td><?= i18n('Address 1') ?></td>
|
||||
<td colspan="5"><input id="organizationinfo_address" type="text" name="address" size="60" maxlength="64" /></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td><?= i18n('Address 2') ?></td>
|
||||
<td colspan="5"><input id="organizationinfo_address2" type="text" name="address2" size="60" maxlength="64" /></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td><?= i18n('City') ?></td>
|
||||
<td><input id="organizationinfo_city" type="text" name="city" size="16" maxlength="32" /></td>
|
||||
<td><?= i18n($config['provincestate']) ?></td>
|
||||
<td>
|
||||
<? emit_province_selector('province_code', '', 'id="organizationinfo_province_code"'); ?>
|
||||
</td>
|
||||
<td><?= i18n($config['postalzip']) ?></td><td><input id="organizationinfo_postalcode" type="text" name="postalcode" size="8" maxlength="7" /></td></tr>
|
||||
<tr><td><?= i18n('Phone') ?></td><td><input type="text" id="organizationinfo_phone" name="phone" size="16" maxlength="32" /></td>
|
||||
<td><?= i18n('Toll Free') ?></td><td><input type="text" id="organizationinfo_tollfree" name="tollfree" size="16" maxlength="32" /></td>
|
||||
<td><?= i18n('Fax') ?></td><td><input type="text" id="organizationinfo_fax" name="fax" size="16" maxlength="32" /></td></tr>
|
||||
<tr><td><?= i18n('Email') ?></td><td colspan="5"><input type="text" id="organizationinfo_email" name="email" size="60" maxlength="128" /></td>
|
||||
<td><?= i18n($config['postalzip']) ?></td>
|
||||
<td><input id="organizationinfo_postalcode" type="text" name="postalcode" size="8" maxlength="7" /></td>
|
||||
</tr>
|
||||
<tr><td><?= i18n('Website') ?></td><td colspan="5"><input type="text" id="organizationinfo_website" name="website" size="60" maxlength="128" /></td>
|
||||
<tr>
|
||||
<td><?= i18n('Phone') ?></td>
|
||||
<td><input type="text" id="organizationinfo_phone" name="phone" size="16" maxlength="32" /></td>
|
||||
<td><?= i18n('Toll Free') ?></td>
|
||||
<td><input type="text" id="organizationinfo_tollfree" name="tollfree" size="16" maxlength="32" /></td>
|
||||
<td><?= i18n('Fax') ?></td>
|
||||
<td><input type="text" id="organizationinfo_fax" name="fax" size="16" maxlength="32" /></td>
|
||||
</tr>
|
||||
<tr><td><?= i18n('Donation Policy') ?></td><td colspan="5"><input id="organizationinfo_donationpolicyurl" type="file" name="donationpolicyurl" size="30" maxlength="128" /></td></tr>
|
||||
<tr><td><?= i18n('Logo') ?></td><td colspan="5"><input type="file" id="organizationinfo_logo" name="logo" size="30" /></td></tr>
|
||||
<tr><td><?= i18n('Funding Selection Date') ?></td><td><input id="organizationinfo_fundingselectiondate" type="text" name="fundingselectiondate" class="date" size="12" maxlength="12" /></td>
|
||||
<td><?= i18n('Proposal Submission Date') ?></td><td colspan="3"><input id="organizationinfo_proposalsubmissiondate" type="text" name="proposalsubmissiondate" class="date" size="12" maxlength="12" /></td>
|
||||
<tr>
|
||||
<td><?= i18n('Email') ?></td>
|
||||
<td colspan="5"><input type="text" id="organizationinfo_email" name="email" size="60" maxlength="128" /></td>
|
||||
</tr>
|
||||
<?
|
||||
<tr>
|
||||
<td><?= i18n('Website') ?></td>
|
||||
<td colspan="5"><input type="text" id="organizationinfo_website" name="website" size="60" maxlength="128" /></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td><?= i18n('Donation Policy') ?></td>
|
||||
<td colspan="5"><input id="organizationinfo_donationpolicyurl" type="file" name="donationpolicyurl" size="30" maxlength="128" /></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td><?= i18n('Logo') ?></td>
|
||||
<td colspan="5"><input type="file" id="organizationinfo_logo" name="logo" size="30" /></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td><?= i18n('Funding Selection Date') ?></td>
|
||||
<td><input id="organizationinfo_fundingselectiondate" type="text" name="fundingselectiondate" class="date" size="12" maxlength="12" /></td>
|
||||
<td><?= i18n('Proposal Submission Date') ?></td>
|
||||
<td colspan="3"><input id="organizationinfo_proposalsubmissiondate" type="text" name="proposalsubmissiondate" class="date" size="12" maxlength="12" /></td>
|
||||
</tr>
|
||||
<?
|
||||
|
||||
/*
|
||||
/*
|
||||
* <tr><td><?=i18n("Waiver Accepted")?></td><td>
|
||||
* <input type="radio" id="organizationinfo_waiveraccepted_no" name="waiveraccepted" value="no"><label for="organizationinfo_waiveraccepted_no"><?=i18n("No")?></label>
|
||||
* <input type="radio" id="organizationinfo_waiveraccepted_yes" name="waiveraccepted" value="yes"><label for="organizationinfo_waiveraccepted_yes"><?=i18n("Yes")?></label>
|
||||
@ -1261,8 +1347,11 @@ echo '<hr />';
|
||||
* <input type="radio" id="organizationinfo_marketingreceiptrequired_yes" name="marketingreceiptrequired" value="yes"><label for="organizationinfo_marketingreceiptrequired_yes"><?=i18n("Yes")?></label>
|
||||
* </td></tr>
|
||||
*/
|
||||
?>
|
||||
<tr><td><?= i18n('Notes') ?></td><td colspan="5"><textarea id="organizationinfo_notes" name="notes" rows="4" cols="60"></textarea></td></tr>
|
||||
?>
|
||||
<tr>
|
||||
<td><?= i18n('Notes') ?></td>
|
||||
<td colspan="5"><textarea id="organizationinfo_notes" name="notes" rows="4" cols="60"></textarea></td>
|
||||
</tr>
|
||||
</table>
|
||||
<input id="organizationinfo_save_button" type="submit" value="<?= i18n('Save') ?>" onClick="return organizationinfo_save()" />
|
||||
</form>
|
||||
@ -1280,25 +1369,25 @@ echo '<hr />';
|
||||
|
||||
|
||||
<div id="searchbrowse" style="display: none;">
|
||||
<form id="searchform" method="post" action="donors.php" onsubmit="return donorsearch(true)">
|
||||
<input type="hidden" name="limit" value="-1" />
|
||||
<?= i18n('Search') ?>: <input type="text" name="search" />
|
||||
<input id="search_donortype_individual" type="checkbox" name="donortype[]" value="individual" checked="checked" /><label for="search_donortype_individual"><?= i18n('Individual') ?></label>
|
||||
<input id="search_donortype_organization" type="checkbox" name="donortype[]" value="organization" checked="checked"/><label for="search_donortype_organization"><?= i18n('Organization') ?></label>
|
||||
<input type="submit" value="<?= i18n('Browse') ?>" />
|
||||
</form>
|
||||
<form id="searchform" method="post" action="donors.php" onsubmit="return donorsearch(true)">
|
||||
<input type="hidden" name="limit" value="-1" />
|
||||
<?= i18n('Search') ?>: <input type="text" name="search" />
|
||||
<input id="search_donortype_individual" type="checkbox" name="donortype[]" value="individual" checked="checked" /><label for="search_donortype_individual"><?= i18n('Individual') ?></label>
|
||||
<input id="search_donortype_organization" type="checkbox" name="donortype[]" value="organization" checked="checked" /><label for="search_donortype_organization"><?= i18n('Organization') ?></label>
|
||||
<input type="submit" value="<?= i18n('Browse') ?>" />
|
||||
</form>
|
||||
</div>
|
||||
<div id="searchresults">
|
||||
</div>
|
||||
<?
|
||||
|
||||
if (get_value_from_array($_GET, 'action') == 'add') {
|
||||
?>
|
||||
<script type="text/javascript">
|
||||
$(document).ready(function() {
|
||||
?>
|
||||
<script type="text/javascript">
|
||||
$(document).ready(function() {
|
||||
open_editor(-1);
|
||||
});
|
||||
</script>
|
||||
});
|
||||
</script>
|
||||
<?
|
||||
}
|
||||
|
||||
|
@ -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();
|
||||
|
@ -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();
|
||||
|
@ -86,6 +86,7 @@ switch ($action) {
|
||||
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'));
|
||||
}
|
||||
|
||||
@ -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();
|
||||
}
|
||||
|
||||
echo '<select name="projectdivisions_id">';
|
||||
echo '<option value="">' . i18n('Select a division') . "</option>\n";
|
||||
|
@ -313,7 +313,7 @@ $(document).ready(function() {
|
||||
|
||||
|
||||
$("#editor_tabs").tabs({
|
||||
create: function( event, ui ) {
|
||||
activate: function( event, ui ) {
|
||||
update_students();
|
||||
update_project();
|
||||
update_reg();
|
||||
|
@ -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') {
|
||||
|
@ -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']}'");
|
||||
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']}'");
|
||||
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']}'");
|
||||
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 {
|
||||
|
378
common.inc.php
378
common.inc.php
@ -26,12 +26,12 @@
|
||||
|
||||
// ////echo phpinfo();
|
||||
header('Content-Type: text/html; charset=utf8');
|
||||
include_once('helper.inc.php');
|
||||
include_once ('helper.inc.php');
|
||||
// set error reporting to not show notices, for some reason some people's installation dont set this by default
|
||||
// so we will set it in the code instead just to make sure
|
||||
error_reporting(E_ALL);
|
||||
// error_reporting(E_ALL);
|
||||
// error_reporting( E_ALL ^ E_WARNING );
|
||||
// error_reporting( E_ALL ^ E_WARNING ^ E_NOTICE ^ E_DEPRECATED );
|
||||
error_reporting(E_ALL ^ E_WARNING ^ E_NOTICE ^ E_DEPRECATED);
|
||||
|
||||
define('REQUIREDFIELD', '<span class="requiredfield">*</span>');
|
||||
|
||||
@ -70,7 +70,7 @@ if (!is_writable($prependdir . 'data')) {
|
||||
}
|
||||
|
||||
if (file_exists($prependdir . 'data/config.inc.php')) {
|
||||
require_once($prependdir . 'data/config.inc.php');
|
||||
require_once ($prependdir . 'data/config.inc.php');
|
||||
} else {
|
||||
echo '<html><head><title>SFIAB</title></head><body>';
|
||||
echo '<h1>Science Fair In A Box - Installation</h1>';
|
||||
@ -138,7 +138,7 @@ if (!$dbdbversion) {
|
||||
exit;
|
||||
}
|
||||
|
||||
if (!$_SERVER['REQUEST_URI'] == "db_update.php" && ($dbcodeversion != $dbdbversion)) {
|
||||
if (!$_SERVER['REQUEST_URI'] == 'db_update.php' && ($dbcodeversion != $dbdbversion)) {
|
||||
echo '<html><head><title>SFIAB ERROR</title></head><body>';
|
||||
echo '<h1>Science Fair In A Box - ERROR</h1>';
|
||||
echo 'SFIAB database and code are mismatched';
|
||||
@ -173,10 +173,10 @@ while ($r = $q->fetch()) {
|
||||
}
|
||||
|
||||
// and now pull the theme
|
||||
require_once("theme/{$config['theme']}/theme.php");
|
||||
require_once("theme/{$config['theme_icons']}/icons.php");
|
||||
require_once ("theme/{$config['theme']}/theme.php");
|
||||
require_once ("theme/{$config['theme_icons']}/icons.php");
|
||||
|
||||
require_once('committee.inc.php');
|
||||
require_once ('committee.inc.php');
|
||||
|
||||
if ($config['SFIABDIRECTORY'] == '') {
|
||||
session_name('SFIABSESSID');
|
||||
@ -350,16 +350,19 @@ function send_header($title = '', $nav = null, $icon = null, $titletranslated =
|
||||
return;
|
||||
else
|
||||
$HEADER_SENT = true;
|
||||
?>
|
||||
?>
|
||||
<!DOCTYPE html>
|
||||
<html>
|
||||
|
||||
<head>
|
||||
<meta charset="utf-8" />
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1" />
|
||||
<title><? if ($title && !$titletranslated) echo i18n($title);
|
||||
else if ($title) echo $title;
|
||||
else echo i18n($config['fairname']); ?></title>
|
||||
<title><? if ($title && !$titletranslated)
|
||||
echo i18n($title);
|
||||
else if ($title)
|
||||
echo $title;
|
||||
else
|
||||
echo i18n($config['fairname']); ?></title>
|
||||
|
||||
<link rel="stylesheet" href="https://code.jquery.com/ui/1.14.1/themes/base/jquery-ui.css">
|
||||
<link rel="stylesheet" href="<?= $config['SFIABDIRECTORY'] ?>/theme/<?= $config['theme'] ?>/sfiab.css" type="text/css" media="all" />
|
||||
@ -369,15 +372,17 @@ function send_header($title = '', $nav = null, $icon = null, $titletranslated =
|
||||
</head>
|
||||
|
||||
<body>
|
||||
<!-- <? if ($title && !$titletranslated) echo i18n($title);
|
||||
else if ($title) echo $title;
|
||||
else echo i18n($config['fairname']); ?> -->
|
||||
<!-- <? if ($title && !$titletranslated)
|
||||
echo i18n($title);
|
||||
else if ($title)
|
||||
echo $title;
|
||||
else
|
||||
echo i18n($config['fairname']); ?> -->
|
||||
<script src="https://code.jquery.com/jquery-3.7.1.js"></script>
|
||||
<script src="https://code.jquery.com/jquery-migrate-3.5.2.js"></script>
|
||||
|
||||
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery.tablesorter/2.32.0/js/jquery.tablesorter.min.js" integrity="sha512-O/JP2r8BG27p5NOtVhwqsSokAwEP5RwYgvEzU9G6AfNjLYqyt2QT8jqU1XrXCiezS50Qp1i3ZtCQWkHZIRulGA==" crossorigin="anonymous" referrerpolicy="no-referrer"></script>
|
||||
|
||||
<!-- <script type="text/javascript" src="<?= $config['SFIABDIRECTORY'] ?>/js/jqueryui/1.7.2/jquery-ui.min.js"></script> -->
|
||||
<script src="https://code.jquery.com/ui/1.14.1/jquery-ui.min.js"></script>
|
||||
<script type="text/javascript" src="<?= $config['SFIABDIRECTORY'] ?>/js/sfiab.js"></script>
|
||||
<script type="text/javascript" src="<?= $config['SFIABDIRECTORY'] ?>/theme/<?= $config['theme'] ?>/theme-script.js"></script>
|
||||
@ -389,7 +394,7 @@ function send_header($title = '', $nav = null, $icon = null, $titletranslated =
|
||||
<?
|
||||
// if we're under /admin or /config we also want the translation editor
|
||||
if (substr(getcwd(), -6) == '/admin' || substr(getcwd(), -7) == '/config' || substr(getcwd(), -6) == '\admin' || substr(getcwd(), -7) == '\config')
|
||||
require_once('../translationseditor.inc.php');
|
||||
require_once ('../translationseditor.inc.php');
|
||||
?>
|
||||
|
||||
<div id="notice_area" class="notice_area"></div>
|
||||
@ -400,11 +405,10 @@ function send_header($title = '', $nav = null, $icon = null, $titletranslated =
|
||||
|
||||
echo '<h1>' . i18n($config['fairname']) . '</h1>';
|
||||
|
||||
|
||||
if ($config['theme'] == 'science_ation')
|
||||
echo "<span id='menu-toggle-button' onClick='toggle_sidebar()' class='material-symbols-outlined'>
|
||||
menu
|
||||
</span>"
|
||||
\t menu
|
||||
\t </span>"
|
||||
?>
|
||||
|
||||
</div>
|
||||
@ -611,12 +615,12 @@ function send_header($title = '', $nav = null, $icon = null, $titletranslated =
|
||||
echo '</table>';
|
||||
|
||||
display_messages();
|
||||
}
|
||||
}
|
||||
|
||||
/* END OF send_header */
|
||||
/* END OF send_header */
|
||||
|
||||
function send_footer()
|
||||
{
|
||||
function send_footer()
|
||||
{
|
||||
global $config;
|
||||
?>
|
||||
</td>
|
||||
@ -652,10 +656,10 @@ function send_header($title = '', $nav = null, $icon = null, $titletranslated =
|
||||
</html>
|
||||
|
||||
<?
|
||||
}
|
||||
}
|
||||
|
||||
function send_popup_header($title = '')
|
||||
{
|
||||
function send_popup_header($title = '')
|
||||
{
|
||||
global $HEADER_SENT;
|
||||
global $config;
|
||||
|
||||
@ -666,7 +670,7 @@ function send_header($title = '', $nav = null, $icon = null, $titletranslated =
|
||||
$HEADER_SENT = true;
|
||||
|
||||
echo "<?xml version=\"1.0\" encoding=\"iso-8859-1\" ?>\n";
|
||||
?>
|
||||
?>
|
||||
<!DOCTYPE html>
|
||||
<html>
|
||||
|
||||
@ -694,10 +698,10 @@ function send_header($title = '', $nav = null, $icon = null, $titletranslated =
|
||||
<?
|
||||
if ($title)
|
||||
echo '<h2>' . i18n($title) . '</h2>';
|
||||
}
|
||||
}
|
||||
|
||||
function send_popup_footer()
|
||||
{
|
||||
function send_popup_footer()
|
||||
{
|
||||
?>
|
||||
<br />
|
||||
<br />
|
||||
@ -719,10 +723,10 @@ function send_header($title = '', $nav = null, $icon = null, $titletranslated =
|
||||
|
||||
</html>
|
||||
<?
|
||||
}
|
||||
}
|
||||
|
||||
function emit_month_selector($name, $selected = '')
|
||||
{
|
||||
function emit_month_selector($name, $selected = '')
|
||||
{
|
||||
echo "<select name=\"$name\">\n";
|
||||
$months = array('', 'Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec');
|
||||
echo '<option value="">' . i18n('Month') . "</option>\n";
|
||||
@ -735,10 +739,10 @@ function send_header($title = '', $nav = null, $icon = null, $titletranslated =
|
||||
}
|
||||
|
||||
echo "</select>\n";
|
||||
}
|
||||
}
|
||||
|
||||
function emit_day_selector($name, $selected = '')
|
||||
{
|
||||
function emit_day_selector($name, $selected = '')
|
||||
{
|
||||
echo "<select name=\"$name\">\n";
|
||||
echo '<option value="">' . i18n('Day') . "</option>\n";
|
||||
|
||||
@ -746,10 +750,10 @@ function send_header($title = '', $nav = null, $icon = null, $titletranslated =
|
||||
echo '<option value="' . ($x < 10 ? '0' : '') . "$x\" " . ($selected == $x ? 'selected="selected"' : '') . ">$x</option>\n";
|
||||
|
||||
echo "</select>\n";
|
||||
}
|
||||
}
|
||||
|
||||
function emit_year_selector($name, $selected = '', $min = 0, $max = 0)
|
||||
{
|
||||
function emit_year_selector($name, $selected = '', $min = 0, $max = 0)
|
||||
{
|
||||
$curyear = date('Y');
|
||||
echo "<select name=\"$name\">\n";
|
||||
echo '<option value="">' . i18n('Year') . "</option>\n";
|
||||
@ -763,10 +767,10 @@ function send_header($title = '', $nav = null, $icon = null, $titletranslated =
|
||||
echo "<option value=\"$x\" " . ($selected == $x ? 'selected="selected"' : '') . ">$x</option>\n";
|
||||
}
|
||||
echo "</select>\n";
|
||||
}
|
||||
}
|
||||
|
||||
function emit_date_selector($name, $selected = '')
|
||||
{
|
||||
function emit_date_selector($name, $selected = '')
|
||||
{
|
||||
if ($selected) {
|
||||
list($year, $month, $day) = explode('-', $selected);
|
||||
}
|
||||
@ -779,10 +783,10 @@ function send_header($title = '', $nav = null, $icon = null, $titletranslated =
|
||||
emit_day_selector($name . '_day', $day);
|
||||
echo '</td></tr>';
|
||||
echo '</table>';
|
||||
}
|
||||
}
|
||||
|
||||
function emit_hour_selector($name, $selected = '')
|
||||
{
|
||||
function emit_hour_selector($name, $selected = '')
|
||||
{
|
||||
if ($selected != '')
|
||||
$selected = (int) $selected;
|
||||
echo "<select name=\"$name\">\n";
|
||||
@ -797,10 +801,10 @@ function send_header($title = '', $nav = null, $icon = null, $titletranslated =
|
||||
}
|
||||
|
||||
echo "</select>\n";
|
||||
}
|
||||
}
|
||||
|
||||
function emit_minute_selector($name, $selected = '')
|
||||
{
|
||||
function emit_minute_selector($name, $selected = '')
|
||||
{
|
||||
$mins = array('00', '05', '10', '15', '20', '25', '30', '35', '40', '45', '50', '55');
|
||||
echo "<select name=\"$name\">\n";
|
||||
echo "<option value=\"\">MM</option>\n";
|
||||
@ -809,10 +813,10 @@ function send_header($title = '', $nav = null, $icon = null, $titletranslated =
|
||||
echo '<option value="' . $mins[$x] . '" ' . ($selected == $mins[$x] ? 'selected' : '') . ">$mins[$x]</option>\n";
|
||||
|
||||
echo "</select>\n";
|
||||
}
|
||||
}
|
||||
|
||||
function emit_time_selector($name, $selected = '')
|
||||
{
|
||||
function emit_time_selector($name, $selected = '')
|
||||
{
|
||||
global $hour;
|
||||
global $minute;
|
||||
if ($selected) {
|
||||
@ -825,10 +829,10 @@ function send_header($title = '', $nav = null, $icon = null, $titletranslated =
|
||||
emit_minute_selector($name . '_minute', $minute);
|
||||
echo '</td></tr>';
|
||||
echo '</table>';
|
||||
}
|
||||
}
|
||||
|
||||
function emit_province_selector($name, $selected = '', $extra = '')
|
||||
{
|
||||
function emit_province_selector($name, $selected = '', $extra = '')
|
||||
{
|
||||
global $config;
|
||||
|
||||
global $pdo;
|
||||
@ -856,10 +860,10 @@ function send_header($title = '', $nav = null, $icon = null, $titletranslated =
|
||||
|
||||
echo "</select>\n";
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
function outputStatus($status)
|
||||
{
|
||||
function outputStatus($status)
|
||||
{
|
||||
$ret = '';
|
||||
switch ($status) {
|
||||
case 'incomplete':
|
||||
@ -883,19 +887,19 @@ function send_header($title = '', $nav = null, $icon = null, $titletranslated =
|
||||
break;
|
||||
}
|
||||
return $ret;
|
||||
}
|
||||
}
|
||||
|
||||
// returns true if its a valid email address, false if its not
|
||||
function isEmailAddress($str)
|
||||
{
|
||||
// returns true if its a valid email address, false if its not
|
||||
function isEmailAddress($str)
|
||||
{
|
||||
if (preg_match('/^[+a-zA-Z0-9._-]+@[a-zA-Z0-9._-]+\.([a-zA-Z]{2,4})$/i', $str))
|
||||
return true;
|
||||
else
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
function communication_get_user_replacements(&$u)
|
||||
{
|
||||
function communication_get_user_replacements(&$u)
|
||||
{
|
||||
global $config;
|
||||
$rep = array(
|
||||
'FAIRNAME' => $config['fairname'],
|
||||
@ -908,10 +912,10 @@ function send_header($title = '', $nav = null, $icon = null, $titletranslated =
|
||||
'ORGANIZATION' => $u['sponsor']['organization'],
|
||||
);
|
||||
return $rep;
|
||||
}
|
||||
}
|
||||
|
||||
function communication_replace_vars($text, &$u, $otherrep = array())
|
||||
{
|
||||
function communication_replace_vars($text, &$u, $otherrep = array())
|
||||
{
|
||||
global $config;
|
||||
if ($u) {
|
||||
$userrep = communication_get_user_replacements($u);
|
||||
@ -924,10 +928,10 @@ function send_header($title = '', $nav = null, $icon = null, $titletranslated =
|
||||
$text = preg_replace("\[$k\]", $v, $text);
|
||||
}
|
||||
return $text;
|
||||
}
|
||||
}
|
||||
|
||||
function email_send($val, $to, $sub_subject = array(), $sub_body = array())
|
||||
{
|
||||
function email_send($val, $to, $sub_subject = array(), $sub_body = array())
|
||||
{
|
||||
global $config, $pdo;
|
||||
|
||||
/*
|
||||
@ -987,54 +991,54 @@ function send_header($title = '', $nav = null, $icon = null, $titletranslated =
|
||||
if ($fr) {
|
||||
// send using RMail
|
||||
// FIXME EMAIL
|
||||
////email_send_new($to, $fr, $subject, $body, $bodyhtml);
|
||||
// //email_send_new($to, $fr, $subject, $body, $bodyhtml);
|
||||
} else
|
||||
echo error(i18n("CRITICAL ERROR: email '%1' does not have a 'From' and the Fair Manager Email is not configured", array($val), array('email key name')));
|
||||
} else {
|
||||
echo error(i18n("CRITICAL ERROR: email '%1' not found", array($val), array('email key name')));
|
||||
}
|
||||
}
|
||||
|
||||
/*require_once("Rmail/Rmail.php");
|
||||
require_once("Rmail/RFC822.php");
|
||||
|
||||
// this sends out an all-ready-to-go email, it does no substitution or changes or database lookups or anything
|
||||
function email_send_new($to, $from, $subject, $body, $bodyhtml = '')
|
||||
{
|
||||
$mail = new RMail();
|
||||
$mail->setFrom($from);
|
||||
$mail->setSubject($subject);
|
||||
$mail->setText($body);
|
||||
|
||||
$r = new Mail_RFC822($from);
|
||||
$structure = $r->parseAddressList($from);
|
||||
$s = $structure[0];
|
||||
$ret = sprintf('%s@%s', $s->mailbox, $s->host);
|
||||
$mail->setReturnPath($ret);
|
||||
$mail->setHeader('Bounce-To', $ret);
|
||||
|
||||
// only add the html if we have it
|
||||
if ($bodyhtml) {
|
||||
$mail->setHTML($bodyhtml);
|
||||
}
|
||||
|
||||
if (is_array($to)) {
|
||||
return $mail->send($to);
|
||||
} else {
|
||||
return $mail->send(array($to));
|
||||
}
|
||||
}
|
||||
*/
|
||||
|
||||
/*
|
||||
* require_once("Rmail/Rmail.php");
|
||||
* require_once("Rmail/RFC822.php");
|
||||
*
|
||||
* // this sends out an all-ready-to-go email, it does no substitution or changes or database lookups or anything
|
||||
* function email_send_new($to, $from, $subject, $body, $bodyhtml = '')
|
||||
* {
|
||||
* $mail = new RMail();
|
||||
* $mail->setFrom($from);
|
||||
* $mail->setSubject($subject);
|
||||
* $mail->setText($body);
|
||||
*
|
||||
* $r = new Mail_RFC822($from);
|
||||
* $structure = $r->parseAddressList($from);
|
||||
* $s = $structure[0];
|
||||
* $ret = sprintf('%s@%s', $s->mailbox, $s->host);
|
||||
* $mail->setReturnPath($ret);
|
||||
* $mail->setHeader('Bounce-To', $ret);
|
||||
*
|
||||
* // only add the html if we have it
|
||||
* if ($bodyhtml) {
|
||||
* $mail->setHTML($bodyhtml);
|
||||
* }
|
||||
*
|
||||
* if (is_array($to)) {
|
||||
* return $mail->send($to);
|
||||
* } else {
|
||||
* return $mail->send(array($to));
|
||||
* }
|
||||
* }
|
||||
*/
|
||||
|
||||
/*
|
||||
/*
|
||||
* returns an array of arrays
|
||||
* [ 0 ] = array ( to, firstname, lastname, email )
|
||||
* [ 1 ] = array ( to, firstname, lastname, email )
|
||||
* ...etc
|
||||
*/
|
||||
function getEmailRecipientsForRegistration($reg_id)
|
||||
{
|
||||
function getEmailRecipientsForRegistration($reg_id)
|
||||
{
|
||||
global $config, $pdo;
|
||||
// okay first grab the registration record, to see if we should email the kids, the teacher, and/or the parents
|
||||
$q = $pdo->prepare("SELECT * FROM registrations WHERE id='$reg_id' AND year='{$config['FAIRYEAR']}'");
|
||||
@ -1066,10 +1070,10 @@ function email_send_new($to, $from, $subject, $body, $bodyhtml = '')
|
||||
}
|
||||
}
|
||||
return $ret;
|
||||
}
|
||||
}
|
||||
|
||||
function output_page_text($textname)
|
||||
{
|
||||
function output_page_text($textname)
|
||||
{
|
||||
global $config;
|
||||
global $pdo;
|
||||
|
||||
@ -1089,10 +1093,10 @@ function email_send_new($to, $from, $subject, $body, $bodyhtml = '')
|
||||
echo nl2br($r->text);
|
||||
else
|
||||
echo get_value_property_or_default($r, 'text');
|
||||
}
|
||||
}
|
||||
|
||||
function output_page_cms($filename)
|
||||
{
|
||||
function output_page_cms($filename)
|
||||
{
|
||||
global $config;
|
||||
global $pdo;
|
||||
|
||||
@ -1118,17 +1122,17 @@ function email_send_new($to, $from, $subject, $body, $bodyhtml = '')
|
||||
}
|
||||
|
||||
send_footer();
|
||||
}
|
||||
}
|
||||
|
||||
// config specific warning
|
||||
function config_warnings() {}
|
||||
|
||||
// admin specific warnings
|
||||
function admin_warnings() {}
|
||||
// admin specific warnings
|
||||
function admin_warnings() {}
|
||||
|
||||
// warnings to show to both config and/or admin people
|
||||
function committee_warnings()
|
||||
{
|
||||
// warnings to show to both config and/or admin people
|
||||
function committee_warnings()
|
||||
{
|
||||
global $config, $pdo;
|
||||
// it is vital that each year the system be rolled over before we start it again
|
||||
// we should do this, say, 4 months after the FAIRDATE, so its soon enough that they should see
|
||||
@ -1165,7 +1169,7 @@ function config_warnings() {}
|
||||
}
|
||||
}
|
||||
|
||||
$CWSFDivisions = array(
|
||||
$CWSFDivisions = array(
|
||||
1 => 'Discovery',
|
||||
2 => 'Energy',
|
||||
3 => 'Environment',
|
||||
@ -1173,10 +1177,10 @@ function config_warnings() {}
|
||||
5 => 'Information',
|
||||
6 => 'Innovation',
|
||||
7 => 'Resources'
|
||||
);
|
||||
);
|
||||
|
||||
function theme_icon($icon, $width = 0)
|
||||
{
|
||||
function theme_icon($icon, $width = 0)
|
||||
{
|
||||
global $theme_icons, $config;
|
||||
|
||||
$w = ($width == 0) ? '' : "width=\"$width\"";
|
||||
@ -1184,41 +1188,47 @@ function config_warnings() {}
|
||||
return "<img src=\"{$config['SFIABDIRECTORY']}/theme/{$config['theme_icons']}/{$theme_icons['icons'][$icon]}\" border=\"0\" $w alt=\"" . htmlspecialchars($icon) . '">';
|
||||
|
||||
return '';
|
||||
}
|
||||
}
|
||||
|
||||
// $d can be a unix timestamp integer, OR a text string, eg 2008-01-22
|
||||
function format_date($d)
|
||||
{
|
||||
// $d can be a unix timestamp integer, OR a text string, eg 2008-01-22
|
||||
function format_date($d)
|
||||
{
|
||||
global $config;
|
||||
if (is_numeric($d))
|
||||
return date($config['dateformat'], $d);
|
||||
else
|
||||
else {
|
||||
if ($d != '0000-00-00')
|
||||
return date($config['dateformat'], strtotime($d));
|
||||
else {
|
||||
return i18n('Not set.');
|
||||
// return '0000-00-00';
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// $t can be a unix timestamp integer, or a text string, eg 10:23:48
|
||||
function format_time($t)
|
||||
{
|
||||
// $t can be a unix timestamp integer, or a text string, eg 10:23:48
|
||||
function format_time($t)
|
||||
{
|
||||
global $config;
|
||||
if (is_numeric($t))
|
||||
return date($config['timeformat'], $t);
|
||||
else
|
||||
return date($config['timeformat'], strtotime($t));
|
||||
}
|
||||
}
|
||||
|
||||
// $dt can be a unix timestamp integer, or a text string, eg 2008-01-22 10:23:48
|
||||
function format_datetime($dt)
|
||||
{
|
||||
// $dt can be a unix timestamp integer, or a text string, eg 2008-01-22 10:23:48
|
||||
function format_datetime($dt)
|
||||
{
|
||||
if (is_numeric($dt)) {
|
||||
return format_date($dt) . ' ' . i18n('at') . ' ' . format_time($dt);
|
||||
} else {
|
||||
list($d, $t) = explode(' ', $dt);
|
||||
return format_date($d) . ' ' . i18n('at') . ' ' . format_time($t);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
function format_money($n, $decimals = true)
|
||||
{
|
||||
function format_money($n, $decimals = true)
|
||||
{
|
||||
global $neg;
|
||||
if ($n < 0) {
|
||||
$neg = true;
|
||||
@ -1258,36 +1268,36 @@ function config_warnings() {}
|
||||
else
|
||||
return sprintf('%s$%s', $negdisp, $out);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
function message_push($m)
|
||||
{
|
||||
function message_push($m)
|
||||
{
|
||||
if (!is_array($_SESSION['messages']))
|
||||
$_SESSION['messages'] = array();
|
||||
$_SESSION['messages'][] = $m;
|
||||
}
|
||||
}
|
||||
|
||||
function notice_($str, $i18n_array = array(), $timeout = -1, $type = 'notice')
|
||||
{
|
||||
function notice_($str, $i18n_array = array(), $timeout = -1, $type = 'notice')
|
||||
{
|
||||
if ($timeout == -1)
|
||||
$timeout = 5000;
|
||||
echo "<script type=\"text/javascript\">
|
||||
notice_create('$type',\"" . i18n($str, $i18n_array) . "\",$timeout);
|
||||
</script>";
|
||||
}
|
||||
}
|
||||
|
||||
function happy_($str, $i18n_array = array(), $timeout = -1)
|
||||
{
|
||||
function happy_($str, $i18n_array = array(), $timeout = -1)
|
||||
{
|
||||
notice_($str, $i18n_array, $timeout, 'happy');
|
||||
}
|
||||
}
|
||||
|
||||
function error_($str, $i18n_array = array(), $timeout = -1)
|
||||
{
|
||||
function error_($str, $i18n_array = array(), $timeout = -1)
|
||||
{
|
||||
notice_($str, $i18n_array, $timeout, 'error');
|
||||
}
|
||||
}
|
||||
|
||||
function debug_($str)
|
||||
{
|
||||
function debug_($str)
|
||||
{
|
||||
if (get_value_from_array($_SESSION, 'debug') != true)
|
||||
return;
|
||||
$s = str_replace("\n", '', nl2br(htmlspecialchars($str))) . '<br />';
|
||||
@ -1296,11 +1306,11 @@ function config_warnings() {}
|
||||
\$(\"#debug\").append(\"$s\");
|
||||
});
|
||||
</script>";
|
||||
}
|
||||
}
|
||||
|
||||
// this function returns a HTML colour code ranging between red and green, with yellow in the middle based on the percent passed into it
|
||||
function colour_to_percent($percent)
|
||||
{
|
||||
// this function returns a HTML colour code ranging between red and green, with yellow in the middle based on the percent passed into it
|
||||
function colour_to_percent($percent)
|
||||
{
|
||||
// 0 is red
|
||||
// 50 is yellow
|
||||
// 100 is green
|
||||
@ -1308,21 +1318,23 @@ function config_warnings() {}
|
||||
if ($percent <= 50)
|
||||
$red = 255;
|
||||
else
|
||||
$red = (100 - $percent) * 2 / 100 * 255;;
|
||||
$red = (100 - $percent) * 2 / 100 * 255;
|
||||
;
|
||||
|
||||
if ($percent > 50)
|
||||
$green = 255;
|
||||
else
|
||||
$green = ($percent) * 2 / 100 * 255;;
|
||||
$green = ($percent) * 2 / 100 * 255;
|
||||
;
|
||||
|
||||
// echo "red=$red";
|
||||
// echo "green=$green";
|
||||
$str = '#' . sprintf('%02s', dechex($red)) . sprintf('%02s', dechex($green)) . '00';
|
||||
return $str;
|
||||
}
|
||||
}
|
||||
|
||||
function format_duration($seconds, $granularity = 2)
|
||||
{
|
||||
function format_duration($seconds, $granularity = 2)
|
||||
{
|
||||
$units = array(
|
||||
'1 year|:count years' => 31536000,
|
||||
'1 week|:count weeks' => 604800,
|
||||
@ -1347,10 +1359,10 @@ function config_warnings() {}
|
||||
}
|
||||
}
|
||||
return $output ? $output : '0 sec';
|
||||
}
|
||||
}
|
||||
|
||||
function getTextFromHtml($html)
|
||||
{
|
||||
function getTextFromHtml($html)
|
||||
{
|
||||
// first, replace an </p> with </p><br />
|
||||
$text = str_replace('</p>', '</p><br />', $html);
|
||||
// next, replace a </div> with </div><br />
|
||||
@ -1373,10 +1385,10 @@ function config_warnings() {}
|
||||
$text = wordwrap($text, 75, "\n", true);
|
||||
|
||||
return $text;
|
||||
}
|
||||
}
|
||||
|
||||
function getUserForSponsor($sponsor_id)
|
||||
{
|
||||
function getUserForSponsor($sponsor_id)
|
||||
{
|
||||
global $pdo;
|
||||
// loop through each contact and draw a form with their data in it.
|
||||
$q = $pdo->prepare("SELECT *,MAX(year) FROM users LEFT JOIN users_sponsor ON users_sponsor.users_id=users.id
|
||||
@ -1391,10 +1403,10 @@ function config_warnings() {}
|
||||
$q->execute();
|
||||
$r = $q->fetch();
|
||||
return user_load_by_uid($r->uid);
|
||||
}
|
||||
}
|
||||
|
||||
function projectdivisions_load($year = false)
|
||||
{
|
||||
function projectdivisions_load($year = false)
|
||||
{
|
||||
global $config, $pdo;
|
||||
if ($year == false)
|
||||
$year = $config['FAIRYEAR'];
|
||||
@ -1404,10 +1416,10 @@ function config_warnings() {}
|
||||
while ($d = $q->fetch(PDO::FETCH_ASSOC))
|
||||
$divs[$d['id']] = $d;
|
||||
return $divs;
|
||||
}
|
||||
}
|
||||
|
||||
function projectcategories_load($year = false)
|
||||
{
|
||||
function projectcategories_load($year = false)
|
||||
{
|
||||
global $config, $pdo;
|
||||
if ($year == false)
|
||||
$year = $config['FAIRYEAR'];
|
||||
@ -1417,12 +1429,12 @@ function config_warnings() {}
|
||||
while ($c = $q->fetch(PDO::FETCH_ASSOC))
|
||||
$cats[$c['id']] = $c;
|
||||
return $cats;
|
||||
}
|
||||
}
|
||||
|
||||
// Converts the numeric value "$val" to an English text representation of it (e.g. "two thousand four").
|
||||
// If the "$monetize" flag is set to true, then it's formatted to be useable on printed cheques (e.g. "***** Two Thousand Four 00/100 *****".
|
||||
function wordify($val, $monetize = false)
|
||||
{
|
||||
// Converts the numeric value "$val" to an English text representation of it (e.g. "two thousand four").
|
||||
// If the "$monetize" flag is set to true, then it's formatted to be useable on printed cheques (e.g. "***** Two Thousand Four 00/100 *****".
|
||||
function wordify($val, $monetize = false)
|
||||
{
|
||||
$digits = array('zero', 'one', 'two', 'three', 'four', 'five', 'six', 'seven', 'eight', 'nine');
|
||||
if ($monetize) {
|
||||
$pennies = intval(($val - intval($val)) * 100);
|
||||
@ -1466,11 +1478,11 @@ function config_warnings() {}
|
||||
if ($monetize)
|
||||
$returnval = '***' . $returnval;
|
||||
return $returnval;
|
||||
}
|
||||
}
|
||||
|
||||
// Converts a number between zero and one thousand to Canadian English text
|
||||
function smallIntToText($number)
|
||||
{
|
||||
// Converts a number between zero and one thousand to Canadian English text
|
||||
function smallIntToText($number)
|
||||
{
|
||||
$number %= 1000;
|
||||
$rvals = array(
|
||||
0 => 'Zero',
|
||||
@ -1526,6 +1538,6 @@ function config_warnings() {}
|
||||
$returnval .= ' ' . $rvals[$number];
|
||||
}
|
||||
return $returnval;
|
||||
}
|
||||
}
|
||||
|
||||
?>
|
@ -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,
|
||||
|
@ -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']."'");
|
||||
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();
|
||||
}
|
||||
}
|
||||
|
||||
/* 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';
|
||||
}
|
||||
}
|
||||
@ -326,7 +307,7 @@ function generateProjectNumber($registration_id)
|
||||
|
||||
$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
|
||||
@ -343,29 +324,29 @@ function generateProjectNumber($registration_id)
|
||||
");
|
||||
$q->execute();
|
||||
show_pdo_errors_if_any($pdo);
|
||||
$r=$q->fetch(PDO::FETCH_OBJ);
|
||||
$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;
|
||||
}
|
||||
@ -394,15 +376,15 @@ function generateProjectNumber($registration_id)
|
||||
|
||||
/* 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
|
||||
$p[$x]['used'] = $p[$x]['x_used'];
|
||||
@ -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,8 +426,12 @@ 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)
|
||||
@ -457,80 +443,91 @@ function computeRegistrationFee($regid)
|
||||
$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',
|
||||
$ret[] = array(
|
||||
'id' => 'regfee',
|
||||
'text' => "Fair Registration (per student)",
|
||||
'base' => $config['regfee'],
|
||||
'num' => $n_students,
|
||||
'ext' => $f );
|
||||
'ext' => $f
|
||||
);
|
||||
$regfee += $f;
|
||||
} else {
|
||||
$ret[] = array( 'id' => 'regfee',
|
||||
$ret[] = array(
|
||||
'id' => 'regfee',
|
||||
'text' => "Fair Registration (per project)",
|
||||
'base' => $config['regfee'],
|
||||
'num' => 1,
|
||||
'ext' => $config['regfee'] );
|
||||
'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',
|
||||
if ($n_tshirts != 0) {
|
||||
$ret[] = array(
|
||||
'id' => 'tshirt',
|
||||
'text' => "T-Shirts",
|
||||
'base' => $tsc,
|
||||
'num' => $n_tshirts,
|
||||
'ext' => $f);
|
||||
'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']})" ,
|
||||
$ret[] = array(
|
||||
'id' => "regfee_item_{$rfi['id']}",
|
||||
'text' => "{$rfi['name']} (per {$rfi['per']})",
|
||||
'base' => $tsc,
|
||||
'num' => $cnt,
|
||||
'ext' => $f);
|
||||
'ext' => $f
|
||||
);
|
||||
$regfee += $f;
|
||||
}
|
||||
return array($regfee, $ret);
|
||||
|
@ -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)
|
||||
|
@ -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
|
||||
|
Loading…
x
Reference in New Issue
Block a user