<? /* * This file is part of the 'Science Fair In A Box' project * SFIAB Website: http://www.sfiab.ca * * Copyright (C) 2009 James Grant <james@lightbox.org> * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public * License as published by the Free Software Foundation, version 2. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; see the file COPYING. If not, write to * the Free Software Foundation, Inc., 59 Temple Place - Suite 330, * Boston, MA 02111-1307, USA. */ ?> <? require ('../common.inc.php'); require_once ('../user.inc.php'); user_auth_required('committee', 'admin'); require ('fundraising_common.inc.php'); switch (get_value_from_array($_GET, 'action')) { case 'campaigninfo_save': save_campaign_info(); exit; break; case 'modify': echo "<div id=\"campaignaccordion\" style=\"width: 780px;\">\n"; $q = $pdo->prepare("SELECT * FROM fundraising_campaigns WHERE fiscalyear=? ORDER BY name"); $q->execute([$config['FISCALYEAR']]); while ($r = $q->fetch(PDO::FETCH_OBJ)) { echo '<h3><a href="#">' . htmlspecialchars($r->name) . "</a></h3>\n"; echo "<div id=\"campaign_{$r->id}\">\n"; echo "<form id=\"campaigninfo_{$r->id}\" method=\"post\" action=\"{$_SERVER['PHP_SELF']}\" onsubmit=\"return campaigninfo_save($r->id)\">\n"; echo "<input type=\"hidden\" name=\"campaign_id\" value=\"{$r->id}\" />\n"; echo "<table>\n"; display_campaign_form($r); ?> <tr><td colspan="6" style="text-align: center;"> <br /> <input type="submit" value="<?= i18n('Save Appeal') ?>"></td> </tr> </table> </form> </div> <? } ?> <h3><a href="#"><?= i18n('Create New Appeal') ?></a></h3> <div id="campaign_new"> <form id="campaigninfo_new" method="post" action="<?= $_SERVER['PHP_SELF'] ?>" onsubmit="return campaigninfo_save(-1)"> <input type="hidden" name="campaign_id" value="-1" /> <table> <? display_campaign_form(); ?> <tr><td colspan="6" style="text-align: center;"> <br /> <input type="submit" value="<?= i18n('Create Appeal') ?>"></td> </tr> </table> </form> </div> </div> <? exit; break; case 'managelist': echo i18n('Select an appeal'); ?> <table class="tableview"> <thead> <tr> <th><?= i18n('Name') ?></th> <th><?= i18n('Type') ?></th> <th><?= i18n('Start Date') ?></th> <th><?= i18n('End Date') ?></th> <th><?= i18n('Target($)') ?></th> <th><?= i18n('Received') ?></th> <th><?= i18n('% to Budget') ?></th> <th><?= i18n('Purpose') ?></th> </tr> </thead> <? $q = $pdo->prepare("SELECT * FROM fundraising_campaigns WHERE fiscalyear=?"); $q->execute([$config['FISCALYEAR']]); while ($r = $q->fetch(PDO::FETCH_OBJ)) { $goalq = $pdo->prepare("SELECT * FROM fundraising_goals WHERE goal=? AND fiscalyear=?"); $goalq->execute([$r->fundraising_goal,$config['FISCALYEAR']]); $goalr = $goalq->fetch(PDO::FETCH_OBJ); $recq = $pdo->prepare("SELECT SUM(value) AS received FROM fundraising_donations WHERE fundraising_campaigns_id=? AND fiscalyear=? AND status='received'"); $recq->execute([$r->id,$config['FISCALYEAR']]); show_pdo_errors_if_any($pdo); $recr = $recq->fetch(PDO::FETCH_OBJ); $received = $recr->received; if ($r->target) $percent = round($received / $r->target * 100, 1); else $percent = 0; $col = colour_to_percent($percent); if (!$goalr) { $goalr = new stdClass(); $goalr->name = ''; } echo "<tr style=\"cursor:pointer;\" onclick=\"return managecampaign($r->id)\">\n"; echo " <td>$r->name</td>\n"; echo " <td>$r->type</td>\n"; echo ' <td>' . format_date($r->startdate) . "</td>\n"; echo ' <td>' . format_date($r->enddate) . '</td>'; echo ' <td style="text-align: right;">' . format_money($r->target, false) . "</td>\n"; echo ' <td style="text-align: right;">' . format_money($received, false) . "</td>\n"; echo " <td style=\"text-align: center; background-color: $col;\">{$percent}%</td>\n"; echo " <td>$goalr->name</td>"; echo "</tr>\n"; } ?> </table> <script type="text/javascript"> $('.tableview').tablesorter();</script> <br /> <? exit; break; case 'manage': if (!$_GET['id']) { error_('Missing campaign to manage'); exit; } $id = intval($_GET['id']); $q = $pdo->prepare("SELECT * FROM fundraising_campaigns WHERE id=?"); $q->execute([$id]); $campaign = $q->fetch(PDO::FETCH_OBJ); echo "<h3>$campaign->name</h3>\n"; ?> <div id="campaign_tabs"> <ul> <li><a href="#campaign_tab_overview"><span><?= i18n('Overview') ?></span></a></li> <li><a href="#campaign_tab_donations"><span><?= i18n('Donations/Sponsorships') ?></span></a></li> <li><a href="#campaign_tab_prospects"><span><?= i18n('Prospects') ?></span></a></li> <li><a href="#campaign_tab_communications"><span><?= i18n('Communications') ?></span></a></li> </ul> <div id="campaign_tab_overview"> overview tab </div> <div id="campaign_tab_donations"> donations tab </div> <div id="campaign_tab_prospects"> prospects tab </div> <div id="campaign_tab_communications"> communications tab </div> </div> <? exit; break; case 'manage_tab_overview': $campaign_id = intval($_GET['id']); $q = $pdo->prepare("SELECT * FROM fundraising_campaigns WHERE id=? AND fiscalyear=?"); $q->execute([$campaign_id,$config['FISCALYEAR']]); if ($r = $q->fetch(PDO::FETCH_OBJ)) { $goalr = getGoal($r->fundraising_goal); $recq = $pdo->prepare("SELECT SUM(value) AS received FROM fundraising_donations WHERE fundraising_campaigns_id=? AND fiscalyear=? AND status='received'"); $recq->execute([$r->id,$config['FISCALYEAR']]); show_pdo_errors_if_any($pdo); $recr = recq->fetch(PDO::FETCH_OBJ); $received = $recr->received; if ($r->target) $percent = round($received / $r->target * 100, 1); else $percent = 0; $col = colour_to_percent($percent); echo '<table cellspacing="3" cellpadding="3">'; echo "<tr>\n"; echo ' <td>' . i18n('Type') . "</td><td>$r->type</td></tr>\n"; echo ' <td>' . i18n('Start Date') . '</td><td>' . format_date($r->startdate) . "</td>\n"; echo "</tr>\n"; echo ' <td>' . i18n('Follow-Up Date') . '</td><td>' . format_date($r->followupdate) . '</td>'; echo "</tr>\n"; echo ' <td>' . i18n('End Date') . '</td><td>' . format_date($r->enddate) . '</td>'; echo "</tr>\n"; echo ' <td>' . i18n('Default Purpose') . "</td><td>$goalr->name</td>"; echo "</tr>\n"; echo ' <td>' . i18n('Target') . '</td><td>' . format_money($r->target, false) . "</td>\n"; echo "</tr>\n"; echo ' <td>' . i18n('Received') . '</td><td>' . format_money($received, false) . "</td>\n"; echo "</tr>\n"; echo ' <td>' . i18n('% to Budget') . "</td><td style=\"color: $col;\">{$percent}%</td>\n"; echo "</tr>\n"; echo "</table>\n"; } exit; break; case 'manage_tab_donations': $campaign_id = intval($_GET['id']); $q = $pdo->prepare("SELECT * FROM fundraising_campaigns WHERE id=? AND fiscalyear=?"); $q->execute([$campaign_id,$config['FISCALYEAR']]); if ($campaign = $q->fetch(PDO::FETCH_OBJ)) { echo '<table class="tableview">'; echo '<thead>'; echo '<tr>'; echo ' <th>' . i18n('Date') . "</th>\n"; echo ' <th>' . i18n('Donor/Sponsor') . "</th>\n"; echo ' <th>' . i18n('Purpose') . "</th>\n"; echo ' <th>' . i18n('Amount') . "</th>\n"; echo ' <th>' . i18n('Type of Support') . "</th>\n"; 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"); while ($r = $q->fetch(PDO::FETCH_OBJ)) { $goal = getGoal($r->fundraising_goal); $sq = $pdo->prepare("SELECT * FROM sponsors WHERE id=?"); $sq->execute([$r->sponsors_id]); $sponsor = $sq->fetch(PDO::FETCH_OBJ); echo '<tr><td>' . format_date($r->datereceived) . "</td>\n"; echo ' <td>' . $sponsor->organization . "</td>\n"; echo ' <td>' . $goal->name . "</td>\n"; echo ' <td>' . format_money($r->value) . "</td>\n"; echo ' <td>' . i18n($r->supporttype) . "</td>\n"; echo "</tr>\n"; } echo "</table>\n"; } exit; break; case 'manage_tab_prospects': $donationhistorylist = array('never' => 'Never donated/sponsored', 'past' => 'Donated/sponsored in the past', 'lastyear' => 'Donated/sponsored last year', 'thisyear' => 'Donated/sponsored this year'); $emailaddresslist = array('available' => 'Available', 'notavaialble' => 'Not Available'); $rolelist = array( 'judge' => 'Judge', 'teacher' => 'Teacher', 'sciencehead' => 'School Science Head', 'principal' => 'School Principal', 'parent' => 'Parent', 'committee' => 'Committee', 'volunteer' => 'Volunteer', 'alumni' => 'Alumni (not implemented)', 'mentor' => 'Mentor (not implemented)', ); $campaign_id = intval($_GET['id']); $q = $pdo->prepare("SELECT * FROM fundraising_campaigns WHERE id=? AND fiscalyear=?"); $q->execute([$campaign_id,$config['FISCALYEAR']]); $campaign = $q->fetch(PDO::FETCH_OBJ); if ($campaign->filterparameters) { echo '<h4>' . i18n('User List') . "</h4>\n"; $params = unserialize($campaign->filterparameters); echo '<table class="tableedit">'; echo '<tr><td>' . i18n('Donor Type') . '</td><td>' . i18n(ucfirst($params['donortype'])) . "</td></tr>\n"; if (is_array($params['donationhistory'])) { echo '<tr><td>' . i18n('Donation History') . '</td><td>'; foreach ($params['donationhistory'] AS $d) { echo i18n($donationhistorylist[$d]) . "<br />\n"; } echo "</td></tr>\n"; } // echo "<tr><td>".i18n("Donation Level")."</td><td>"; // echo "</td></tr>\n"; if (is_array($params['emailaddress'])) { echo '<tr><td>' . i18n('Email Address') . '</td><td>'; foreach ($params['emailaddress'] AS $e) { echo i18n($emailaddresslist[$e]) . "<br />\n"; } echo "</td></tr>\n"; } if ($params['donortype'] == 'individual' && is_array($params['individual_type'])) { echo '<tr><td>' . i18n('Role') . '</td><td>'; foreach ($params['individual_type'] AS $e) { echo i18n($rolelist[$e]) . "<br />\n"; } echo "</td></tr>\n"; } else if (is_array($params['contacttype'])) { echo '<tr><td>' . i18n('Role') . '</td><td>'; foreach ($params['contacttype'] AS $e) { echo i18n(ucfirst($e)) . '<br />'; } echo "</td></tr>\n"; } echo "</table>\n"; // params: individual/org // donation history // donation level // email address // role ind // role org echo '<br />'; echo "<form id=\"prospectremoveform\" onsubmit=\"return removeselectedprospects()\">\n"; echo "<input type=\"hidden\" name=\"fundraising_campaigns_id\" value=\"$campaign_id\" />\n"; $q = $pdo->prepare("SELECT * FROM fundraising_campaigns_users_link WHERE fundraising_campaigns_id=?"); $q->execute([$campaign_id]); while ($r = $q->fetch(PDO::FETCH_OBJ)) { $u = user_load_by_uid($r->users_uid); // hopefully this never returns false, but who knows.. if ($u) { echo '<label>'; echo "<input type=\"checkbox\" name=\"prospectremovefromlist[]\" value=\"{$u['uid']}\" />"; if ($u['sponsor']['donortype'] == 'organization') { echo $u['sponsor']['organization'] . ' - '; } echo $u['firstname'] . ' ' . $u['lastname']; if ($u['email']) echo " <{$u['email']}>"; echo "</label>\n"; echo '<br />'; } } echo '<br />'; echo '<br />'; echo '<table><tr><td>'; echo '<input onclick="return prospect_removeselected()" type="button" value="' . i18n('Remove selected prospects from list') . "\">\n"; echo '</td><td>'; echo '<input onclick="return prospect_removeall()" type="button" value="' . i18n('Remove all prospects from list') . "\">\n"; // echo "</td><td>"; // echo "<input type=\"button\" value=\"".i18n("Finalize prospect list")."\">\n"; echo "</td></tr></table>\n"; } else { ?> <h4><?= i18n('Choose Prospects') ?></h4> <form id="prospectform" onsubmit="return prospect_generatelist()"> <input type="hidden" name="fundraising_campaigns_id" value="<?= $campaign_id ?>" /> <table> <tr><td style="width: 130px;"><?= i18n('Type') ?>:</td><td> <label><input type="radio" name="donortype" value="organization" onchange="donortypechange()" ><?= i18n('Organization') ?></label><br /> <label><input type="radio" name="donortype" value="individual" onchange="donortypechange()" ><?= i18n('Individual') ?></label><br /> </td></tr> </table> <div id="prospect_common" style="display: none;"> <hr /> <table> <tr><td style="width: 130px;"><?= i18n('Donation History') ?>:</td><td> <? foreach ($donationhistorylist AS $k => $v) { echo "<label><input onchange=\"return prospect_search()\" type=\"checkbox\" name=\"donationhistory[]\" value=\"$k\">" . i18n($v) . "</label><br />\n"; } ?> </td></tr> <tr><td><?= i18n('Donation Level') ?>:</td><td> <? $q = $pdo->prepare("SELECT * FROM fundraising_donor_levels WHERE fiscalyear=? ORDER BY min"); $q->execute([$config['FISCALYEAR']]); while ($r = $q->fetch(PDO::FETCH_OBJ)) { echo "<label><input onchange=\"return prospect_search()\" disabled=\"disabled\" type=\"checkbox\" name=\"donationlevel[]\" value=\"$r->level\" >" . i18n($r->level) . ' (' . format_money($r->min, false) . ' - ' . format_money($r->max, false) . ")</label><br />\n"; } echo '(disabled until the logic requirements can be established)'; ?> </td></tr> <tr><td><?= i18n('Email Address') ?>:</td><td> <? foreach ($emailaddresslist AS $k => $v) { echo "<label><input onchange=\"return prospect_search()\" type=\"checkbox\" name=\"emailaddress[]\" value=\"$k\">" . i18n($v) . "</label><br />\n"; } ?> </td></tr> </table> </div> <div id="prospect_individual" style="display: none;"> <table> <tr><td style="width: 130px;"><?= i18n('Role') ?>:</td><td> <? foreach ($rolelist AS $k => $v) { echo "<label><input onchange=\"return prospect_search()\" type=\"checkbox\" name=\"individual_type[]\" value=\"$k\">" . i18n($v) . "</label><br />\n"; } ?> </td></tr></table> </div> <div id="prospect_organization" style="display: none;"> <table> <tr><td style="width: 130px;"><?= i18n('Role') ?>:</td><td> <label><input onchange="return prospect_search()" type="checkbox" name="contacttype[]" value="primary"><?= i18n('Primary contacts') ?></label><br /> <label><input onchange="return prospect_search()" type="checkbox" name="contacttype[]" value="secondary"><?= i18n('Secondary contacts') ?></label><br /> </td></tr></table> </div> <hr /> <div id="prospectsearchresults"></div> </form> <? } exit; break; case 'manage_tab_communications': $campaign_id = intval($_GET['id']); $q = $pdo->prepare("SELECT * FROM fundraising_campaigns WHERE id=? AND fiscalyear=?"); $q->execute([$campaign_id,$config['FISCALYEAR']]); if ($r = $q->fetch(PDO::FETCH_OBJ)) { } $communications = array('initial' => 'Initial Communication', 'followup' => 'Follow-Up Communication'); foreach ($communications as $key => $name) { echo '<h4>' . i18n($name) . "</h4>\n"; // check if they have one in the emails database $q = $pdo->prepare("SELECT * FROM emails WHERE fundraising_campaigns_id=? AND val=?"); $q->execute([$campaign_id,$key]); if ($email = $q->fetch(PDO::FETCH_OBJ)) { echo '<div style="float: right; margin-right: 15px;">'; echo "<a title=\"Edit\" href=\"#\" onclick=\"return opencommunicationeditor(null,$email->id,$campaign_id)\"><img src=\"" . $config['SFIABDIRECTORY'] . '/images/16/edit.' . $config['icon_extension'] . '" border=0></a>'; echo ' '; echo "<a title=\"Remove\" onClick=\"return removecommunication($email->id);\" href=\"\"><img src=\"" . $config['SFIABDIRECTORY'] . '/images/16/button_cancel.' . $config['icon_extension'] . '" border=0></a>'; echo '</div>'; echo '<table cellspacing=0 cellpadding=3 border=1 style="margin-left: 30px; margin-right: 30px; width: 700px;">'; echo '<tr><td>' . i18n('Subject') . '</td><td>' . htmlspecialchars($email->subject) . "</td></tr>\n"; echo '<tr><td>' . i18n('From') . '</td><td>' . htmlspecialchars($email->from) . "</td></tr>\n"; echo '<tr><td colspan="2">' . $email->bodyhtml . "</td></tr>\n"; echo '<tr><td colspan="2">'; echo '<table style="width: 100%;"><tr>'; echo '<td style="text-align: center;">'; // we let them always send it again for now... might change this back later, but i think just notifying them of when it was last sent is enough and keeps teh form more consistent 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); echo i18n('Last Sent'); echo '<br />' . format_date($date); echo '<br />' . format_time($time); } echo "</td>\n"; echo "<td style=\"text-align: center;\"><input type=\"button\" onclick=\"return opensendmaildialog($campaign_id,'$key')\" value=\"" . i18n('Generate PDF for mailing') . "\" /></td>\n"; echo "<td style=\"text-align: center;\"><input type=\"button\" onclick=\"return opensendlabelsdialog(47,$campaign_id)\" value=\"" . i18n('Generate mailing labels') . "\" /></td>\n"; echo "</tr></table>\n"; echo "</td></tr>\n"; echo "</table>\n"; } else { echo "<ul>\n"; echo " <li><a href=\"#\" onclick=\"return opencommunicationchooser('$key');\">" . i18n('Start from an existing communication') . "</a></li>\n"; echo " <li><a href=\"#\" onclick=\"return opencommunicationeditor('$key',null,$campaign_id);\">" . i18n('Create a new communication') . "</a></li>\n"; echo "</ul>\n"; } echo '<br />'; } exit; break; case 'prospect_removeselected': $campaignid = intval($_POST['fundraising_campaigns_id']); print_r($_POST); if (is_array($_POST['prospectremovefromlist'])) { $uidlist = implode(',', $_POST['prospectremovefromlist']); $query = "DELETE FROM fundraising_campaigns_users_link WHERE fundraising_campaigns_id=? AND users_uid IN ($uidlist)"; $stmt = $pdo->prepare($query); $stmt->execute([$campaignid]); show_pdo_errors_if_any($pdo); } // if theres nobody left in the list we need to reset the filter params as well $q = $pdo->prepare("SELECT COUNT(*) AS num FROM fundraising_campaigns_users_link WHERE fundraising_campaigns_id=?"); $q->execute([$campaignid]); $r = $q->fetch(PDO::FETCH_OBJ); if ($r->num == 0) { $stmt = $pdo->prepare("UPDATE fundraising_campaigns SET filterparameters=NULL WHERE id=?"); $stmt->execute([$campaignid]); } happy_('Selected users removed from list'); exit; break; case 'prospect_removeall': $campaignid = intval($_POST['fundraising_campaigns_id']); $stmt = $pdo->prepare("DELETE FROM fundraising_campaigns_users_link WHERE fundraising_campaigns_id=?"); $stmt->execute([$campaignid]); $stmt = $pdo->prepare("UPDATE fundraising_campaigns SET filterparameters=NULL WHERE id=?"); $stmt->execute([$campaignid]); happy_('All users removed from list'); exit; break; case 'communication_remove': $emails_id = $_POST['id']; // check if its been sent, if so, it cannot be deleted, sorry! $q = $pdo->prepare("SELECT * FROM emails WHERE id=?"); $q->execute([$emails_id]); $e = $q->fetch(PDO::FETCH_OBJ); if ($e->lastsent) { error_('Cannot remove an email that has already been sent'); } else { $stmt = $pdo->prepare("DELETE FROM emails WHERE id=?"); $stmt->execute([$emails_id]); happy_('Communicaton removed'); } break; } function save_campaign_info() { global $config, $pdo; if (!$_POST['name']) { error_('Appeal Name is required'); return; } if (!$_POST['startdate']) $startdate = date('Y-m-d'); else $startdate = $_POST['startdate']; if (!$_GET['id']) { $query = "INSERT INTO fundraising_campaigns (name, fiscalyear) VALUES (?,?)"; echo $query; $stmt = $pdo->prepare($query); $stmt->execute([stripslashes($_POST['name']),$config['FISCALYEAR']]); $id = $pdo->lastInsertId(); happy_('Appeal Created'); } else { $id = $_GET['id']; happy_('Appeal Saved'); } $stmt = $pdo->prepare("UPDATE fundraising_campaigns SET name=?, `type`=?, startdate=?, followupdate=?, enddate=?, target=?, fundraising_goal=? WHERE id=?"); $stmt->execute([stripslashes($_POST['name']),$_POST['type'],$startdate,$_POST['followupdate'],$_POST['enddate'],$_POST['target'],$_POST['fundraising_goal'],$id]); } send_header('Appeal Management', array('Committee Main' => 'committee_main.php', 'Administration' => 'admin/index.php', 'Fundraising' => 'admin/fundraising.php'), 'fundraising'); ?> <script type="text/javascript"> $(document).ready(function() { <? if (get_value_from_array($_GET, 'manage_campaign')) { echo 'managecampaign(' . intval(get_value_from_array($_GET, 'manage_campaign')) . ");\n"; } else { echo "managecampaigns();\n"; } ?> }); function modifycampaigns() { $("#campaigndiv").show(); $("#campaigndiv").load("<? $_SERVER['PHP_SELF'] ?>?action=modify", null, function() {modifycampaignsfinish();}); } function managecampaigns() { $("#campaigndiv").show(); $("#campaigndiv").load("<? $_SERVER['PHP_SELF'] ?>?action=managelist", null, function() {managecampaignsfinish();}); } var currentcampaignid; function managecampaign(id) { $("#campaigndiv").show(); $("#campaigndiv").load("<? $_SERVER['PHP_SELF'] ?>?action=manage&id="+id, null, function() {managecampaignfinish();}); currentcampaignid=id; } function modifycampaignsfinish(){ $("#campaignaccordion").accordion(); // create the date pickers for our form $(".date").datepicker({ dateFormat: 'yy-mm-dd' }); } function managecampaignsfinish() { } function managecampaignfinish() { $("#editor_tabs").tabs({ create: function( event, ui ) { update_tab_overview(); update_tab_donations(); update_tab_prospects(); update_tab_communications(); }, selected: 0 });} // function managecampaignfinish() { // $("#campaign_tabs").tabs({ // show: function(event, ui) { // switch(ui.panel.id) { // case 'campaign_tab_overview': // update_tab_overview(); // break; // case 'campaign_tab_donations': // update_tab_donations(); // break; // case 'campaign_tab_prospects': // update_tab_prospects(); // break; // case 'campaign_tab_communications': // update_tab_communications(); // break; // } // }, // selected: 0 // });} function campaigninfo_save(id) { //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(id==-1) { $("#debug").load("<? $_SERVER['PHP_SELF'] ?>?action=campaigninfo_save", $("#campaigninfo_new").serializeArray(), function() { modifycampaigns(); }); } else { $("#debug").load("<? $_SERVER['PHP_SELF'] ?>?action=campaigninfo_save&id="+id, $("#campaigninfo_"+id).serializeArray(), function() { modifycampaigns(); }); } return false; } function update_tab_overview() { $("#campaign_tab_overview").load("<? $_SERVER['PHP_SELF'] ?>?action=manage_tab_overview&id="+currentcampaignid); } function update_tab_donations() { $("#campaign_tab_donations").load( "<? $_SERVER['PHP_SELF'] ?>?action=manage_tab_donations&id="+currentcampaignid, null, function(){$('.tableview').tablesorter();} ); } function update_tab_prospects() { $("#campaign_tab_prospects").load("<? $_SERVER['PHP_SELF'] ?>?action=manage_tab_prospects&id="+currentcampaignid); } function update_tab_communications() { $("#campaign_tab_communications").load("<? $_SERVER['PHP_SELF'] ?>?action=manage_tab_communications&id="+currentcampaignid); } function donortypechange() { if($("input[@name='donortype']:checked").val()=="organization") { $("#prospect_common").show('slow'); $("#prospect_organization").show('slow'); $("#prospect_individual").hide('slow'); } else if($("input[@name='donortype']:checked").val()=="individual") { $("#prospect_common").show('slow'); $("#prospect_organization").hide('slow'); $("#prospect_individual").show('slow'); } else { $("#prospect_common").hide('slow'); } prospect_search(); } function prospect_search() { $("#prospectsearchresults").load("fundraising_campaigns_prospecting.php",$("#prospectform").serializeArray()); return false; } function prospect_generatelist() { $("#prospectsearchresults").load("fundraising_campaigns_prospecting.php?generatelist=true",$("#prospectform").serializeArray(), function() { update_tab_prospects(); }); return false; } function prospect_removeselected() { $("#debug").load("fundraising_campaigns.php?action=prospect_removeselected",$("#prospectremoveform").serializeArray(),function() { update_tab_prospects(); }); return false; } function prospect_removeall() { $("#debug").load("fundraising_campaigns.php?action=prospect_removeall",$("#prospectremoveform").serializeArray(),function() { update_tab_prospects(); }); return false; } var comm_chooser_key = null; function opencommunicationchooser(key) { comm_chooser_key = key; $("#dialog").empty(); $("#dialog").load("communication.php?action=dialog_choose&type=fundraising",null,function() { }); } function removecommunication(id) { $("#debug").load("fundraising_campaigns.php?action=communication_remove",{id:id},function() { update_tab_communications(); }); return false; } function comm_dialog_choose_select(id) { // alert('im back with email id: '+id); //get rid of hte html var key = comm_chooser_key; $("#dialog").empty(); $("#dialog").load("communication.php?action=dialog_edit&cloneid="+id+"&key="+key+"&fundraising_campaigns_id="+currentcampaignid,null,function() { }); } function comm_dialog_choose_cancel() { // alert('im cancelled'); } function comm_dialog_edit_save(id) { // alert("saved!"); update_tab_communications(); } function comm_dialog_edit_cancel() { // alert("cancelled!"); } function opensendlabelsdialog(reports_id,fcid) { $("#dialog").empty(); var args = "action=dialog_gen&sid="+reports_id+"&filter[0][field]=fundraising_campaigns_id&filter[0][x]=0&filter[0][value]="+fcid; $("#dialog").load("reports_gen.php?"+args,null,function() { }); } function opensendmaildialog(fcid,key) { var dlargs = "fundraising_campaigns_id="+fcid+"&key="+key; var dlurl = "<?= $config['SFIABDIRECTORY'] ?>/admin/reports_appeal_letters.php?"+dlargs; window.location.href = dlurl; // $('#content').attr('src',dlurl); return false; } function opensendemaildialog(fcid,emails_id) { $("#dialog").empty(); $("#dialog").load("communication.php?action=dialog_send&type=fundraising&fundraising_campaigns_id="+fcid+"&emails_id="+emails_id,null,function() { }); } </script> <? function display_campaign_form($r = null) { global $config; global $campaign_types; global $pdo; ?> <tr> <td><?= i18n('Name') ?></td> <td colspan="3"><input size="40" type="text" name="name" value="<?= get_value_property_or_default($r, 'name') ?>"></td> <td><?= i18n('Type') ?></td><td> <select name="type"> <option value=""><?= i18n('Choose') ?></option> <? foreach ($campaign_types AS $ct) { if ($r->type == $ct) $sel = 'selected="selected"'; else $sel = ''; echo "<option $sel value=\"$ct\">" . i18n($ct) . "</option>\n"; } ?> </select> </td> </tr> <? if (get_value_property_or_default($r, 'startdate')) $sd = $r->startdate; else $sd = date('Y-m-d'); ?> <tr> <td><?= i18n('Start Date') ?></td><td><input type="text" name="startdate" class="date" value="<?= $sd ?>" /></td> <td><?= i18n('Follow-Up Date') ?></td><td><input type="text" name="followupdate" class="date" value="<?= get_value_property_or_default($r, 'followupdate') ?>" /></td> <td><?= i18n('End Date') ?></td><td><input type="text" name="enddate" class="date" value="<?= get_value_property_or_default($r, 'enddate') ?>" /></td> </tr> <tr> <td><?= i18n('Target') ?></td><td>$<input type="text" id="target" name="target" size="10" value="<?= get_value_property_or_default($r, 'target') ?>" /></td> <td><?= i18n('Default Purpose') ?></td><td colspan="3"> <? $fgq = $pdo->prepare("SELECT * FROM fundraising_goals WHERE fiscalyear=? ORDER BY name"); $fgq->execute([$config['FISCALYEAR']]); echo '<select name="fundraising_goal">'; echo '<option value="">' . i18n('Choose Default Purpose') . "</option>\n"; while ($fgr = $fgq->fetch(PDO::FETCH_OBJ)) { if ($r->fundraising_goal == $fgr->goal) $sel = 'selected="selected"'; else $sel = ''; echo "<option $sel value=\"$fgr->goal\">" . i18n($fgr->name) . "</option>\n"; } echo "</select>\n"; ?> </td> </tr> <? } ?> <table cellspacing=2 width=740 border=0> <tr><td> <a href="#" onclick="modifycampaigns()">Create/Modify Appeals</a> </td><td> <a href="#" onclick="managecampaigns()">Appeal Management</a> </td></tr></table> <hr /> <div id="campaigndiv" style="width: 780px; display: none;"></div> <div id="dialog" style="width: 780px; display: none;"></div> <? send_footer(); ?>