diff --git a/langs/en/labels.json b/langs/en/labels.json index facae01..6a42754 100644 --- a/langs/en/labels.json +++ b/langs/en/labels.json @@ -7,8 +7,12 @@ "Adult": "Adult", "Adults": "Adults", "Youth": "Youth", + "Days": "Days", + "Position": "Position", + "Parent Phone": "Parent Phone", "Total Income": "Total Income", "Card Payments": "Card Payments", + "Camp Coupon/Scout Bucks": "Camp Coupon/Scout Bucks", "First": "First", "Last": "Last", "Last Name": "Last Name", diff --git a/lib/mkmemberdirectory.php b/lib/mkmemberdirectory.php deleted file mode 100644 index 91d3766..0000000 --- a/lib/mkmemberdirectory.php +++ /dev/null @@ -1,224 +0,0 @@ -hasPermission("HACHEPORTAL_VIEW")) { - header("Location: ../app.php?msg=no_permission"); - die(); -} - -use Dompdf\Dompdf; - -// Load all families -$familylist = $database->select("families", "familyid", ["ORDER" => ["familyname"]]); -$families = []; -foreach ($familylist as $f) { - $fam = (new Family())->load($f); - if ($fam->getPrivate()) { - continue; - } - $families[] = $fam; -} - -$format = "html"; -if (!empty($_GET["format"])) { - $format = $_GET["format"]; -} - -$date = date("F j Y"); - -if ($format == "html") { - - $icons = ".grad { - background-image: url(''); - } - .phone { - background-image: url(''); - } - .email { - background-image: url(''); - } - .mapmarker { - background-image: url(''); - } - .nocamera { - background-image: url(''); - }"; - - - $htmltop = << -HACHE Member Directory - -

HACHE Member Directory

-

- Updated: $date -
- Icon key: - : Graduated student | : Photo permission denied -
- You agree to use the information in this directory for homeschool use ONLY. All other purposes, such as soliciting, is strictly prohibited. -

- -
-END; - - $htmlmiddle = ""; - - $currentletter = " "; - - foreach ($families as $f) { - // Add headings for letters - if (strtoupper($f->getName()[0]) > $currentletter) { - $currentletter = strtoupper($f->getName()[0]); - $htmlmiddle .= "\n

$currentletter

\n"; - } - $famhtml = "\n
\n" - . "\t" . $f->getName() . ", " . $f->getFather() . " and " . $f->getMother() . "\n"; - if (!$f->getPhotoPermission()) { - $famhtml .= "\t\n"; - } - $famhtml .= "\t
" . $f->getAddress() . ", " . $f->getCity() . ", " . $f->getState() . " " . $f->getZip() . "\n" - . "\t
getPhone() . "\">" . $f->getPhone() . "    getEmail() . "\">" . $f->getEmail() . "\n"; - foreach ($f->getChildren() as $child) { - $famhtml .= "\t
\n"; - if ($child->isGraduated()) { - $famhtml .= "\t\t\n"; - } else { - $famhtml .= "\t\t\n"; - } - $famhtml .= "\t\t" . $child->getName() . ", " . date("M y", $child->getBirthday()) . "\n"; - $famhtml .= "\t
\n"; - } - $famhtml .= "
\n"; - $htmlmiddle .= $famhtml; - } - - $htmlbottom = << -END; - - $html = $htmltop . $htmlmiddle . $htmlbottom; - - header("Content-Type: text/html; charset=UTF-8"); - echo $html; -} else { - \PhpOffice\PhpWord\Settings::setOutputEscapingEnabled(true); - $phpWord = new \PhpOffice\PhpWord\PhpWord(); - - $properties = $phpWord->getDocInfo(); - $properties->setCreator('HACHE Membership Portal'); - $properties->setCompany('HACHE'); - $properties->setTitle('HACHE Member Directory'); - - $phpWord->addTitleStyle(1, ['bold' => true, 'size' => 24, 'alignment' => \PhpOffice\PhpWord\SimpleType\Jc::CENTER]); - $phpWord->addTitleStyle(2, ['bold' => true, 'size' => 16]); - - $header = $phpWord->addSection(["paperSize" => "Letter", 'marginLeft' => 600, 'marginRight' => 600, 'marginTop' => 600, 'marginBottom' => 600]); - $header->addTitle("HACHE Member Directory\n", 1); - $updated = $header->addTextRun(); - $updated->addText("Updated: ", ['bold' => true]); - $updated->addText("$date"); - $iconkey = $header->addTextRun(); - $iconkey->addText("Icon key: ", ['bold' => true]); - $iconkey->addText("●: Graduated student | ►: Photo permission denied"); - $header->addText($Strings->get("You agree to use the information in this directory for homeschool use ONLY. All other purposes, such as soliciting, is strictly prohibited.", false)); - - $header->addTextBreak(2); - - $body = $phpWord->addSection(['breakType' => 'continuous', 'colsNum' => 2, "paperSize" => "Letter", 'marginLeft' => 600, 'marginRight' => 600, 'marginTop' => 600, 'marginBottom' => 600]); - - $currentletter = " "; - - foreach ($families as $f) { - // Add headings for letters - if (strtoupper($f->getName()[0]) > $currentletter) { - $currentletter = strtoupper($f->getName()[0]); - $body->addTitle("$currentletter", 2); - } - $famtext = $body->addTextRun(); - if (!$f->getPhotoPermission()) { - $famtext->addText("►"); - } - $famtext->addText($f->getName(), ['bold' => true]); - $famtext->addText(", " . $f->getFather() . " and " . $f->getMother()); - $body->addText($f->getAddress() . ", " . $f->getCity() . ", " . $f->getState() . " " . $f->getZip()); - $links = $body->addTextRun(); - $links->addLink("tel:" . $f->getPhone(), $f->getPhone()); - $links->addText(" "); - $links->addLink("mailto:" . $f->getEmail(), $f->getEmail()); - - foreach ($f->getChildren() as $child) { - $chtext = $body->addTextRun(["indent" => 1440]); - if ($child->isGraduated()) { - $chtext->addText(" ● "); - } else { - $chtext->addText(" "); - } - $chtext->addText($child->getName() . ", " . date("M y", $child->getBirthday())); - } - $body->addTextBreak(1); - } - - header("Content-Description: File Transfer"); - header('Content-Transfer-Encoding: binary'); - header('Cache-Control: must-revalidate, post-check=0, pre-check=0'); - header('Expires: 0'); - - switch ($format) { - case "docx": - $phpWord->getCompatibility()->setOoxmlVersion(15); - $objWriter = \PhpOffice\PhpWord\IOFactory::createWriter($phpWord, 'Word2007'); - header("Content-Type: application/vnd.openxmlformats-officedocument.wordprocessingml.document"); - header("Content-disposition: attachment; filename=\"HACHE_Directory_" . date("Y-m-d") . ".docx\""); - break; - case "odt": - default: - // Paper size is stuck at A4 and margins don't work. - // See https://github.com/PHPOffice/PHPWord/issues/1531 - // Hopefully they'll get this fixed. - $objWriter = \PhpOffice\PhpWord\IOFactory::createWriter($phpWord, 'ODText'); - header("Content-Type: application/vnd.oasis.opendocument.text"); - header("Content-disposition: attachment; filename=\"HACHE_Directory_" . date("Y-m-d") . ".odt\""); - break; - } - $objWriter->save('php://output'); -} -?> \ No newline at end of file diff --git a/lib/reports.php b/lib/reports.php index 69a5604..c77d126 100644 --- a/lib/reports.php +++ b/lib/reports.php @@ -32,85 +32,183 @@ if (LOADED) { * @param array $filter Medoo WHERE clause. * @return string */ -function getMemberReport($filter = []): Report { +function getPeopleReport($filter = ""): Report { global $database, $Strings; if (empty($filter)) { - $report = new Report($Strings->get("Families", false)); + $report = new Report($Strings->get("People", false)); $filter = ["ORDER" => ["familyname" => "ASC"]]; } else { - $report = new Report($Strings->get("Expiring Memberships", false)); + $report = new Report($Strings->get("$filter", false)); } - $familyids = $database->select( - "families", "familyid", $filter - ); - - $report->setHeader([ - $Strings->get("Name", false), - $Strings->get("Father", false), - $Strings->get("Mother", false), - $Strings->get("Phone", false), - $Strings->get("Email", false), - $Strings->get("Address", false), - $Strings->get("City", false), - $Strings->get("State", false), - $Strings->get("ZIP", false), - $Strings->get("Photo Permission", false), - $Strings->get("Newsletter", false), - $Strings->get("Expires", false), - $Strings->get("Private", false), - $Strings->get("Children", false), - ]); - $families = []; - foreach ($familyids as $id) { - $f = (new Family())->load($id); - $families[] = $f; + $join = []; + $where = []; + $header = []; + switch ($filter) { + case "Campers": + $join = ["[>]campers" => ["camperid" => "camperid"]]; + $where = ["people.camperid[!]" => null]; + $header = [ + $Strings->get("First", false), + $Strings->get("Last", false), + $Strings->get("Parent", false), + $Strings->get("Unit", false), + $Strings->get("Rank", false), + $Strings->get("Phone", false), + $Strings->get("Email", false), + $Strings->get("Address", false), + $Strings->get("ZIP", false), + $Strings->get("Shirt", false), + $Strings->get("Sex", false) + ]; + break; + case "Adults": + $join = ["[>]adults" => ["adultid" => "adultid"]]; + $where = ["people.adultid[!]" => null]; + $header = [ + $Strings->get("First", false), + $Strings->get("Last", false), + $Strings->get("Phone", false), + $Strings->get("Email", false), + $Strings->get("Address", false), + $Strings->get("ZIP", false), + $Strings->get("Days", false), + $Strings->get("Position", false), + $Strings->get("Shirt", false), + $Strings->get("Sex", false) + ]; + break; + case "Youth": + $join = ["[>]youth" => ["youthid" => "youthid"]]; + $where = ["people.youthid[!]" => null]; + $header = [ + $Strings->get("First", false), + $Strings->get("Last", false), + $Strings->get("Parent", false), + $Strings->get("Phone", false), + $Strings->get("Parent Phone", false), + $Strings->get("Email", false), + $Strings->get("Address", false), + $Strings->get("ZIP", false), + $Strings->get("Days", false), + $Strings->get("Position", false), + $Strings->get("Shirt", false), + $Strings->get("Sex", false) + ]; + break; + default: + $header = [ + $Strings->get("First", false), + $Strings->get("Last", false), + $Strings->get("Type", false), + $Strings->get("Phone", false), + $Strings->get("Email", false), + $Strings->get("Address", false), + $Strings->get("ZIP", false), + $Strings->get("Shirt", false), + $Strings->get("Sex", false) + ]; } - foreach ($families as $f) { - $newsletter = ""; - switch ($f->getNewsletter()) { - case 1: - $newsletter = $Strings->get("Email", false); + + if (empty($join)) { + $people = $database->select("people", '*', $where); + } else { + $people = $database->select("people", $join, '*', $where); + } + + $report->setHeader($header); + + foreach ($people as $p) { + $row = []; + + $type = "Unknown"; + if (!empty($p['camperid'])) { + $type = $Strings->get("Camper", false); + } else if (!empty($p['adultid'])) { + $type = $Strings->get("Adult", false); + } else if (!empty($p['youthid'])) { + $type = $Strings->get("Youth", false); + } + + switch ($filter) { + case "Campers": + $row = [ + $p['firstname'], + $p['lastname'], + $p['parentname'], + $p['unit'], + $p['rank'], + $p['phone1'], + $p['email'], + $p['address'], + $p['zip'], + $p['shirt'], + $p['sex'] + ]; break; - case 2: - $newsletter = $Strings->get("Print", false); + case "Adults": + $row = [ + $p['firstname'], + $p['lastname'], + $p['phone1'], + $p['email'], + $p['address'], + $p['zip'], + $p['days'], + $p['position'], + $p['shirt'], + $p['sex'] + ]; break; - case 3: - $newsletter = $Strings->get("Email+Print", false); + case "Youth": + $row = [ + $p['firstname'], + $p['lastname'], + $p['parentname'], + $p['phone1'], + $p['phone2'], + $p['email'], + $p['address'], + $p['zip'], + $p['days'], + $p['position'], + $p['shirt'], + $p['sex'] + ]; break; + default: + $row = [ + $p['firstname'], + $p['lastname'], + $type, + $p['phone1'] . (empty($p['phone2']) ? "" : " " . $p['phone2']), + $p['email'], + $p['address'], + $p['zip'], + $p['shirt'], + $p['sex'] + ]; } - $children = []; - foreach ($f->getChildren() as $c) { - $children[] = $c->getName() . " (" . date("n/d", $c->getBirthday()) . ")"; - } - $report->addDataRow([ - $f->getName(), - $f->getFather(), - $f->getMother(), - $f->getPhone() . "", - $f->getEmail(), - $f->getAddress(), - $f->getCity(), - $f->getState(), - $f->getZip() . "", - $f->getPhotoPermission() ? $Strings->get("Yes", false) : $Strings->get("No", false), - $newsletter, - date("Y-m-d", $f->getExpires()), - $f->getPrivate() ? $Strings->get("Yes", false) : $Strings->get("No", false), - implode(", ", $children) - ]); + + $report->addDataRow($row); } return $report; } function getReport($type): Report { switch ($type) { - case "members": - return getMemberReport(); + case "campers": + return getPeopleReport("Campers"); + break; + case "adults": + return getPeopleReport("Adults"); + break; + case "youth": + return getPeopleReport("Youth"); break; - case "expiring": - return getMemberReport(["expires[<]" => date("Y-m-d", strtotime("+1 month")), "ORDER" => ["expires" => "ASC"]]); + case "people": + return getPeopleReport(""); break; default: return new Report("error", ["ERROR"], ["Invalid report type."]); diff --git a/pages/reports.php b/pages/reports.php index 4858530..cef04d4 100644 --- a/pages/reports.php +++ b/pages/reports.php @@ -20,47 +20,58 @@ if (!$user->hasPermission("HACHEPORTAL_VIEW")) {
-
-

get("Member Directory"); ?>

-

get("A formatted and up-to-date HACHE member directory."); ?>

- - get("Office (ODT)"); ?> + + + -
-

get("Family List"); ?>

-

get("All the data from the member directory in a spreadsheet."); ?>

- + -
-

get("Expiring Memberships"); ?>

-

get("All members expired or expiring within a month."); ?>

- +