<?

/*
 * 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 " &lt;{$u['email']}&gt;";
                    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 '&nbsp;&nbsp;';
                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();
?>