xref: /webtrees/app/Module/InteractiveTreeModule.php (revision 05168efae8a3622edfdeaa2beb26320ee49abacd)
18c2e8227SGreg Roach<?php
28c2e8227SGreg Roach/**
38c2e8227SGreg Roach * webtrees: online genealogy
46bdf7674SGreg Roach * Copyright (C) 2017 webtrees development team
58c2e8227SGreg Roach * This program is free software: you can redistribute it and/or modify
68c2e8227SGreg Roach * it under the terms of the GNU General Public License as published by
78c2e8227SGreg Roach * the Free Software Foundation, either version 3 of the License, or
88c2e8227SGreg Roach * (at your option) any later version.
98c2e8227SGreg Roach * This program is distributed in the hope that it will be useful,
108c2e8227SGreg Roach * but WITHOUT ANY WARRANTY; without even the implied warranty of
118c2e8227SGreg Roach * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
128c2e8227SGreg Roach * GNU General Public License for more details.
138c2e8227SGreg Roach * You should have received a copy of the GNU General Public License
148c2e8227SGreg Roach * along with this program. If not, see <http://www.gnu.org/licenses/>.
158c2e8227SGreg Roach */
1676692c8bSGreg Roachnamespace Fisharebest\Webtrees\Module;
1776692c8bSGreg Roach
180e62c4b8SGreg Roachuse Fisharebest\Webtrees\Controller\ChartController;
190e62c4b8SGreg Roachuse Fisharebest\Webtrees\Filter;
200e62c4b8SGreg Roachuse Fisharebest\Webtrees\I18N;
210e62c4b8SGreg Roachuse Fisharebest\Webtrees\Individual;
22168ff6f3Sric2016use Fisharebest\Webtrees\Menu;
23e46b0479SScrutinizer Auto-Fixeruse Fisharebest\Webtrees\Module\InteractiveTree\TreeView;
248c2e8227SGreg Roach
258c2e8227SGreg Roach/**
268c2e8227SGreg Roach * Class InteractiveTreeModule
278c2e8227SGreg Roach * Tip : you could change the number of generations loaded before ajax calls both in individual page and in treeview page to optimize speed and server load
288c2e8227SGreg Roach */
29168ff6f3Sric2016class InteractiveTreeModule extends AbstractModule implements ModuleTabInterface, ModuleChartInterface {
308c2e8227SGreg Roach	/** {@inheritdoc} */
318c2e8227SGreg Roach	public function getTitle() {
328c2e8227SGreg Roach		return /* I18N: Name of a module */ I18N::translate('Interactive tree');
338c2e8227SGreg Roach	}
348c2e8227SGreg Roach
358c2e8227SGreg Roach	/** {@inheritdoc} */
368c2e8227SGreg Roach	public function getDescription() {
378c2e8227SGreg Roach		return /* I18N: Description of the “Interactive tree” module */ I18N::translate('An interactive tree, showing all the ancestors and descendants of an individual.');
388c2e8227SGreg Roach	}
398c2e8227SGreg Roach
408c2e8227SGreg Roach	/** {@inheritdoc} */
418c2e8227SGreg Roach	public function defaultTabOrder() {
428c2e8227SGreg Roach		return 68;
438c2e8227SGreg Roach	}
448c2e8227SGreg Roach
458c2e8227SGreg Roach	/** {@inheritdoc} */
468c2e8227SGreg Roach	public function getTabContent() {
478c2e8227SGreg Roach		global $controller;
488c2e8227SGreg Roach
498c2e8227SGreg Roach		$tv              = new TreeView('tvTab');
508c2e8227SGreg Roach		list($html, $js) = $tv->drawViewport($controller->record, 3);
51cbc1590aSGreg Roach
528c2e8227SGreg Roach		return
538c2e8227SGreg Roach			'<script src="' . $this->js() . '"></script>' .
548c2e8227SGreg Roach			'<script>' . $js . '</script>' .
558c2e8227SGreg Roach			$html;
568c2e8227SGreg Roach	}
578c2e8227SGreg Roach
588c2e8227SGreg Roach	/** {@inheritdoc} */
598c2e8227SGreg Roach	public function hasTabContent() {
6015d603e7SGreg Roach		return true;
618c2e8227SGreg Roach	}
628c2e8227SGreg Roach
638c2e8227SGreg Roach	/** {@inheritdoc} */
648c2e8227SGreg Roach	public function isGrayedOut() {
658c2e8227SGreg Roach		return false;
668c2e8227SGreg Roach	}
678c2e8227SGreg Roach
688c2e8227SGreg Roach	/** {@inheritdoc} */
698c2e8227SGreg Roach	public function canLoadAjax() {
708c2e8227SGreg Roach		return true;
718c2e8227SGreg Roach	}
728c2e8227SGreg Roach
73168ff6f3Sric2016	/**
74168ff6f3Sric2016	 * Return a menu item for this chart.
75168ff6f3Sric2016	 *
7660bc3e3fSGreg Roach	 * @param Individual $individual
7760bc3e3fSGreg Roach	 *
784eb71cfaSGreg Roach	 * @return Menu|null
79168ff6f3Sric2016	 */
80168ff6f3Sric2016	public function getChartMenu(Individual $individual) {
81168ff6f3Sric2016		return new Menu(
82168ff6f3Sric2016			$this->getTitle(),
834eb71cfaSGreg Roach			'module.php?mod=tree&amp;mod_action=treeview&amp;rootid=' . $individual->getXref() . '&amp;ged=' . $individual->getTree()->getNameUrl(),
84168ff6f3Sric2016			'menu-chart-tree',
8513abd6f3SGreg Roach			['rel' => 'nofollow']
86168ff6f3Sric2016		);
87168ff6f3Sric2016	}
88168ff6f3Sric2016
894eb71cfaSGreg Roach	/**
904eb71cfaSGreg Roach	 * Return a menu item for this chart - for use in individual boxes.
914eb71cfaSGreg Roach	 *
9260bc3e3fSGreg Roach	 * @param Individual $individual
9360bc3e3fSGreg Roach	 *
944eb71cfaSGreg Roach	 * @return Menu|null
954eb71cfaSGreg Roach	 */
96168ff6f3Sric2016	public function getBoxChartMenu(Individual $individual) {
97168ff6f3Sric2016		return $this->getChartMenu($individual);
98168ff6f3Sric2016	}
99168ff6f3Sric2016
1008c2e8227SGreg Roach	/** {@inheritdoc} */
1018c2e8227SGreg Roach	public function getPreLoadContent() {
10215d603e7SGreg Roach		// We cannot use $("head").append(<link rel="stylesheet" ...as jQuery is not loaded at this time
1038c2e8227SGreg Roach		return
1048c2e8227SGreg Roach			'<script>
1058c2e8227SGreg Roach			if (document.createStyleSheet) {
1068c2e8227SGreg Roach				document.createStyleSheet("' . $this->css() . '"); // For Internet Explorer
1078c2e8227SGreg Roach			} else {
1088c2e8227SGreg Roach				var newSheet=document.createElement("link");
1098c2e8227SGreg Roach				newSheet.setAttribute("rel","stylesheet");
1108c2e8227SGreg Roach				newSheet.setAttribute("type","text/css");
1118c2e8227SGreg Roach				newSheet.setAttribute("href","' . $this->css() . '");
1128c2e8227SGreg Roach				document.getElementsByTagName("head")[0].appendChild(newSheet);
1138c2e8227SGreg Roach			}
1148c2e8227SGreg Roach			</script>';
1158c2e8227SGreg Roach	}
1168c2e8227SGreg Roach
11776692c8bSGreg Roach	/**
11876692c8bSGreg Roach	 * This is a general purpose hook, allowing modules to respond to routes
11976692c8bSGreg Roach	 * of the form module.php?mod=FOO&mod_action=BAR
12076692c8bSGreg Roach	 *
12176692c8bSGreg Roach	 * @param string $mod_action
12276692c8bSGreg Roach	 */
1238c2e8227SGreg Roach	public function modAction($mod_action) {
12424ec66ceSGreg Roach		global $controller, $WT_TREE;
12524ec66ceSGreg Roach
1268c2e8227SGreg Roach		switch ($mod_action) {
1278c2e8227SGreg Roach		case 'treeview':
1288c2e8227SGreg Roach			$controller = new ChartController;
1298c2e8227SGreg Roach			$tv         = new TreeView('tv');
1308c2e8227SGreg Roach			ob_start();
1318c2e8227SGreg Roach
1328c2e8227SGreg Roach			$person = $controller->getSignificantIndividual();
1338c2e8227SGreg Roach
1348c2e8227SGreg Roach			list($html, $js) = $tv->drawViewport($person, 4);
1358c2e8227SGreg Roach
1368c2e8227SGreg Roach			$controller
1378c2e8227SGreg Roach				->setPageTitle(I18N::translate('Interactive tree of %s', $person->getFullName()))
1388c2e8227SGreg Roach				->pageHeader()
1398c2e8227SGreg Roach				->addExternalJavascript($this->js())
1408c2e8227SGreg Roach				->addInlineJavascript($js)
1418c2e8227SGreg Roach				->addInlineJavascript('
1428c2e8227SGreg Roach					if (document.createStyleSheet) {
1438c2e8227SGreg Roach						document.createStyleSheet("' . $this->css() . '"); // For Internet Explorer
1448c2e8227SGreg Roach					} else {
14515d603e7SGreg Roach						$("head").append(\'<link rel="stylesheet" type="text/css" href="' . $this->css() . '">\');
1468c2e8227SGreg Roach					}
1478c2e8227SGreg Roach				');
1488c2e8227SGreg Roach			echo $html;
1498c2e8227SGreg Roach			break;
1508c2e8227SGreg Roach
1518c2e8227SGreg Roach		case 'getDetails':
1528c2e8227SGreg Roach			header('Content-Type: text/html; charset=UTF-8');
1538c2e8227SGreg Roach			$pid        = Filter::get('pid', WT_REGEX_XREF);
1548c2e8227SGreg Roach			$i          = Filter::get('instance');
1558c2e8227SGreg Roach			$tv         = new TreeView($i);
15624ec66ceSGreg Roach			$individual = Individual::getInstance($pid, $WT_TREE);
1578c2e8227SGreg Roach			if ($individual) {
1588c2e8227SGreg Roach				echo $tv->getDetails($individual);
1598c2e8227SGreg Roach			}
1608c2e8227SGreg Roach			break;
1618c2e8227SGreg Roach
1628c2e8227SGreg Roach		case 'getPersons':
1638c2e8227SGreg Roach			header('Content-Type: text/html; charset=UTF-8');
1648c2e8227SGreg Roach			$q  = Filter::get('q');
1658c2e8227SGreg Roach			$i  = Filter::get('instance');
1668c2e8227SGreg Roach			$tv = new TreeView($i);
1678c2e8227SGreg Roach			echo $tv->getPersons($q);
1688c2e8227SGreg Roach			break;
1698c2e8227SGreg Roach
1708c2e8227SGreg Roach		default:
1718c2e8227SGreg Roach			http_response_code(404);
1728c2e8227SGreg Roach			break;
1738c2e8227SGreg Roach		}
1748c2e8227SGreg Roach	}
1758c2e8227SGreg Roach
1768c2e8227SGreg Roach	/**
17776692c8bSGreg Roach	 * URL for our style sheet.
1783cf92ae2SGreg Roach	 *
1798c2e8227SGreg Roach	 * @return string
1808c2e8227SGreg Roach	 */
1818c2e8227SGreg Roach	public function css() {
182*05168efaSGreg Roach		return WT_MODULES_DIR . $this->getName() . '/css/treeview.css';
1838c2e8227SGreg Roach	}
1848c2e8227SGreg Roach
1858c2e8227SGreg Roach	/**
18676692c8bSGreg Roach	 * URL for our JavaScript.
18776692c8bSGreg Roach	 *
1888c2e8227SGreg Roach	 * @return string
1898c2e8227SGreg Roach	 */
1908c2e8227SGreg Roach	public function js() {
191*05168efaSGreg Roach		return WT_MODULES_DIR . $this->getName() . '/js/treeview.js';
1928c2e8227SGreg Roach	}
1938c2e8227SGreg Roach}
194