xref: /webtrees/app/Module/InteractiveTreeModule.php (revision 15d603e7c7c15d20f055d3d9c38d6b133453c5be)
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() {
60*15d603e7SGreg 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	 *
764eb71cfaSGreg Roach	 * @return Menu|null
77168ff6f3Sric2016	 */
78168ff6f3Sric2016	public function getChartMenu(Individual $individual) {
79168ff6f3Sric2016		return new Menu(
80168ff6f3Sric2016			$this->getTitle(),
814eb71cfaSGreg Roach			'module.php?mod=tree&amp;mod_action=treeview&amp;rootid=' . $individual->getXref() . '&amp;ged=' . $individual->getTree()->getNameUrl(),
82168ff6f3Sric2016			'menu-chart-tree',
8313abd6f3SGreg Roach			['rel' => 'nofollow']
84168ff6f3Sric2016		);
85168ff6f3Sric2016	}
86168ff6f3Sric2016
874eb71cfaSGreg Roach	/**
884eb71cfaSGreg Roach	 * Return a menu item for this chart - for use in individual boxes.
894eb71cfaSGreg Roach	 *
904eb71cfaSGreg Roach	 * @return Menu|null
914eb71cfaSGreg Roach	 */
92168ff6f3Sric2016	public function getBoxChartMenu(Individual $individual) {
93168ff6f3Sric2016		return $this->getChartMenu($individual);
94168ff6f3Sric2016	}
95168ff6f3Sric2016
968c2e8227SGreg Roach	/** {@inheritdoc} */
978c2e8227SGreg Roach	public function getPreLoadContent() {
98*15d603e7SGreg Roach		// We cannot use $("head").append(<link rel="stylesheet" ...as jQuery is not loaded at this time
998c2e8227SGreg Roach		return
1008c2e8227SGreg Roach			'<script>
1018c2e8227SGreg Roach			if (document.createStyleSheet) {
1028c2e8227SGreg Roach				document.createStyleSheet("' . $this->css() . '"); // For Internet Explorer
1038c2e8227SGreg Roach			} else {
1048c2e8227SGreg Roach				var newSheet=document.createElement("link");
1058c2e8227SGreg Roach				newSheet.setAttribute("rel","stylesheet");
1068c2e8227SGreg Roach				newSheet.setAttribute("type","text/css");
1078c2e8227SGreg Roach				newSheet.setAttribute("href","' . $this->css() . '");
1088c2e8227SGreg Roach				document.getElementsByTagName("head")[0].appendChild(newSheet);
1098c2e8227SGreg Roach			}
1108c2e8227SGreg Roach			</script>';
1118c2e8227SGreg Roach	}
1128c2e8227SGreg Roach
11376692c8bSGreg Roach	/**
11476692c8bSGreg Roach	 * This is a general purpose hook, allowing modules to respond to routes
11576692c8bSGreg Roach	 * of the form module.php?mod=FOO&mod_action=BAR
11676692c8bSGreg Roach	 *
11776692c8bSGreg Roach	 * @param string $mod_action
11876692c8bSGreg Roach	 */
1198c2e8227SGreg Roach	public function modAction($mod_action) {
12024ec66ceSGreg Roach		global $controller, $WT_TREE;
12124ec66ceSGreg Roach
1228c2e8227SGreg Roach		switch ($mod_action) {
1238c2e8227SGreg Roach		case 'treeview':
1248c2e8227SGreg Roach			$controller = new ChartController;
1258c2e8227SGreg Roach			$tv         = new TreeView('tv');
1268c2e8227SGreg Roach			ob_start();
1278c2e8227SGreg Roach
1288c2e8227SGreg Roach			$person = $controller->getSignificantIndividual();
1298c2e8227SGreg Roach
1308c2e8227SGreg Roach			list($html, $js) = $tv->drawViewport($person, 4);
1318c2e8227SGreg Roach
1328c2e8227SGreg Roach			$controller
1338c2e8227SGreg Roach				->setPageTitle(I18N::translate('Interactive tree of %s', $person->getFullName()))
1348c2e8227SGreg Roach				->pageHeader()
1358c2e8227SGreg Roach				->addExternalJavascript($this->js())
1368c2e8227SGreg Roach				->addInlineJavascript($js)
1378c2e8227SGreg Roach				->addInlineJavascript('
1388c2e8227SGreg Roach					if (document.createStyleSheet) {
1398c2e8227SGreg Roach						document.createStyleSheet("' . $this->css() . '"); // For Internet Explorer
1408c2e8227SGreg Roach					} else {
141*15d603e7SGreg Roach						$("head").append(\'<link rel="stylesheet" type="text/css" href="' . $this->css() . '">\');
1428c2e8227SGreg Roach					}
1438c2e8227SGreg Roach				');
1448c2e8227SGreg Roach			echo $html;
1458c2e8227SGreg Roach			break;
1468c2e8227SGreg Roach
1478c2e8227SGreg Roach		case 'getDetails':
1488c2e8227SGreg Roach			header('Content-Type: text/html; charset=UTF-8');
1498c2e8227SGreg Roach			$pid        = Filter::get('pid', WT_REGEX_XREF);
1508c2e8227SGreg Roach			$i          = Filter::get('instance');
1518c2e8227SGreg Roach			$tv         = new TreeView($i);
15224ec66ceSGreg Roach			$individual = Individual::getInstance($pid, $WT_TREE);
1538c2e8227SGreg Roach			if ($individual) {
1548c2e8227SGreg Roach				echo $tv->getDetails($individual);
1558c2e8227SGreg Roach			}
1568c2e8227SGreg Roach			break;
1578c2e8227SGreg Roach
1588c2e8227SGreg Roach		case 'getPersons':
1598c2e8227SGreg Roach			header('Content-Type: text/html; charset=UTF-8');
1608c2e8227SGreg Roach			$q  = Filter::get('q');
1618c2e8227SGreg Roach			$i  = Filter::get('instance');
1628c2e8227SGreg Roach			$tv = new TreeView($i);
1638c2e8227SGreg Roach			echo $tv->getPersons($q);
1648c2e8227SGreg Roach			break;
1658c2e8227SGreg Roach
1668c2e8227SGreg Roach		default:
1678c2e8227SGreg Roach			http_response_code(404);
1688c2e8227SGreg Roach			break;
1698c2e8227SGreg Roach		}
1708c2e8227SGreg Roach	}
1718c2e8227SGreg Roach
1728c2e8227SGreg Roach	/**
17376692c8bSGreg Roach	 * URL for our style sheet.
1743cf92ae2SGreg Roach	 *
1758c2e8227SGreg Roach	 * @return string
1768c2e8227SGreg Roach	 */
1778c2e8227SGreg Roach	public function css() {
1788c2e8227SGreg Roach		return WT_STATIC_URL . WT_MODULES_DIR . $this->getName() . '/css/treeview.css';
1798c2e8227SGreg Roach	}
1808c2e8227SGreg Roach
1818c2e8227SGreg Roach	/**
18276692c8bSGreg Roach	 * URL for our JavaScript.
18376692c8bSGreg Roach	 *
1848c2e8227SGreg Roach	 * @return string
1858c2e8227SGreg Roach	 */
1868c2e8227SGreg Roach	public function js() {
1878c2e8227SGreg Roach		return WT_STATIC_URL . WT_MODULES_DIR . $this->getName() . '/js/treeview.js';
1888c2e8227SGreg Roach	}
1898c2e8227SGreg Roach}
190