1dd6b2bfcSGreg Roach<?php 21b860509SRico Sonntagdeclare(strict_types=1); 31b860509SRico Sonntag 41b860509SRico Sonntaguse Fisharebest\Webtrees\Auth; 5*5373aac2SGreg Roachuse Fisharebest\Webtrees\Carbon; 61b860509SRico Sonntaguse Fisharebest\Webtrees\Date; 71b860509SRico Sonntaguse Fisharebest\Webtrees\GedcomTag; 81b860509SRico Sonntaguse Fisharebest\Webtrees\I18N; 987cca37cSGreg Roachuse Fisharebest\Webtrees\Module\ModuleChartInterface; 101b860509SRico Sonntaguse Fisharebest\Webtrees\Module\ModuleInterface; 111b860509SRico Sonntaguse Fisharebest\Webtrees\Module\RelationshipsChartModule; 121b860509SRico Sonntaguse Fisharebest\Webtrees\Services\ModuleService; 131b860509SRico Sonntaguse Fisharebest\Webtrees\View; 141b860509SRico Sonntaguse Ramsey\Uuid\Uuid; 151b860509SRico Sonntag 16dd6b2bfcSGreg Roach// lists requires a unique ID in case there are multiple lists per page 17dd6b2bfcSGreg Roach$table_id = 'table-indi-' . Uuid::uuid4()->toString(); 18dd6b2bfcSGreg Roach 19*5373aac2SGreg Roach$hundred_years_ago = Carbon::now()->subYears(100)->julianDay(); 201b860509SRico Sonntag 21dd6b2bfcSGreg Roach$unique_indis = []; // Don't double-count indis with multiple names. 2284b37362SGreg Roach 23b2a8cedfSGreg Roach$today_jd = unixtojd(); 24b2a8cedfSGreg Roach$show_estimated_dates = (bool) $tree->getPreference('SHOW_EST_LIST_DATES'); 25b2a8cedfSGreg Roach 261b860509SRico Sonntag$module = app(ModuleService::class) 2787cca37cSGreg Roach ->findByComponent(ModuleChartInterface::class, $tree, Auth::user()) 280b5fd0a6SGreg Roach ->first(static function (ModuleInterface $module) { 2990d97cc8SGreg Roach return $module instanceof RelationshipsChartModule; 3090d97cc8SGreg Roach }); 31dd6b2bfcSGreg Roach?> 32dd6b2bfcSGreg Roach 33dd6b2bfcSGreg Roach<?php View::push('javascript') ?> 34dd6b2bfcSGreg Roach<script> 351b860509SRico Sonntag 36dd6b2bfcSGreg Roach$("#<?= e($table_id) ?>").dataTable({ 37dd6b2bfcSGreg Roach dom: '<"H"<"filtersH_<?= e($table_id) ?>">T<"dt-clear">pf<"dt-clear">irl>t<"F"pl<"dt-clear"><"filtersF_<?= e($table_id) ?>">>', 38dd6b2bfcSGreg Roach autoWidth: false, 39dd6b2bfcSGreg Roach processing: true, 40dd6b2bfcSGreg Roach retrieve: true, 41dd6b2bfcSGreg Roach columns: [ 42dd6b2bfcSGreg Roach /* Given names */ { type: "text" }, 43dd6b2bfcSGreg Roach /* Surnames */ { type: "text" }, 44dd6b2bfcSGreg Roach /* SOSA numnber */ { type: "num", visible: <?= json_encode($sosa) ?> }, 45dd6b2bfcSGreg Roach /* Birth date */ { type: "num" }, 46dd6b2bfcSGreg Roach /* Anniversary */ { type: "num" }, 47dd6b2bfcSGreg Roach /* Birthplace */ { type: "text" }, 48dd6b2bfcSGreg Roach /* Children */ { type: "num" }, 49dd6b2bfcSGreg Roach /* Deate date */ { type: "num" }, 50dd6b2bfcSGreg Roach /* Anniversary */ { type: "num" }, 51dd6b2bfcSGreg Roach /* Age */ { type: "num" }, 52dd6b2bfcSGreg Roach /* Death place */ { type: "text" }, 53dd6b2bfcSGreg Roach /* Last change */ { visible: <?= json_encode($tree->getPreference('SHOW_LAST_CHANGE')) ?> }, 54dd6b2bfcSGreg Roach /* Filter sex */ { sortable: false }, 55dd6b2bfcSGreg Roach /* Filter birth */ { sortable: false }, 56dd6b2bfcSGreg Roach /* Filter death */ { sortable: false }, 57dd6b2bfcSGreg Roach /* Filter tree */ { sortable: false } 58dd6b2bfcSGreg Roach ], 59b2c011d7SGreg Roach sorting: <?= json_encode($sosa ? [[4, 'asc']] : [[1, 'asc']]) ?> 60dd6b2bfcSGreg Roach}); 61dd6b2bfcSGreg Roach 62dd6b2bfcSGreg Roach$("#<?= e($table_id) ?>") 63dd6b2bfcSGreg Roach /* Hide/show parents */ 64dd6b2bfcSGreg Roach .on("click", ".btn-toggle-parents", function() { 65dd6b2bfcSGreg Roach $(this).toggleClass("ui-state-active"); 66dd6b2bfcSGreg Roach $(".parents", $(this).closest("table").DataTable().rows().nodes()).slideToggle(); 67dd6b2bfcSGreg Roach }) 68dd6b2bfcSGreg Roach /* Hide/show statistics */ 69dd6b2bfcSGreg Roach .on("click", ".btn-toggle-statistics", function() { 70dd6b2bfcSGreg Roach $(this).toggleClass("ui-state-active"); 711b860509SRico Sonntag $("#individual-charts-<?= e($table_id) ?>").slideToggle({ 721b860509SRico Sonntag complete: function () { 731b860509SRico Sonntag // Trigger resize to redraw the chart 741b860509SRico Sonntag $('div[id^="google-chart-"]').resize(); 751b860509SRico Sonntag } 761b860509SRico Sonntag }); 77dd6b2bfcSGreg Roach }) 78dd6b2bfcSGreg Roach /* Filter buttons in table header */ 79dd6b2bfcSGreg Roach .on("click", "button[data-filter-column]", function() { 80dd6b2bfcSGreg Roach var btn = $(this); 81dd6b2bfcSGreg Roach // De-activate the other buttons in this button group 82dd6b2bfcSGreg Roach btn.siblings().removeClass("active"); 83dd6b2bfcSGreg Roach // Apply (or clear) this filter 84dd6b2bfcSGreg Roach var col = $("#<?= e($table_id) ?>").DataTable().column(btn.data("filter-column")); 85dd6b2bfcSGreg Roach if (btn.hasClass("active")) { 86dd6b2bfcSGreg Roach col.search("").draw(); 87dd6b2bfcSGreg Roach } else { 88dd6b2bfcSGreg Roach col.search(btn.data("filter-value")).draw(); 89dd6b2bfcSGreg Roach } 90dd6b2bfcSGreg Roach }); 911b860509SRico Sonntag 92dd6b2bfcSGreg Roach</script> 93dd6b2bfcSGreg Roach<?php View::endpush() ?> 94dd6b2bfcSGreg Roach 95dd6b2bfcSGreg Roach<?php 96dd6b2bfcSGreg Roach$max_age = (int) $tree->getPreference('MAX_ALIVE_AGE'); 97dd6b2bfcSGreg Roach 98dd6b2bfcSGreg Roach// Inititialise chart data 99dd6b2bfcSGreg Roach$deat_by_age = []; 100dd6b2bfcSGreg Roachfor ($age = 0; $age <= $max_age; $age++) { 1011b860509SRico Sonntag $deat_by_age[$age]['M'] = 0; 1021b860509SRico Sonntag $deat_by_age[$age]['F'] = 0; 1031b860509SRico Sonntag $deat_by_age[$age]['U'] = 0; 104dd6b2bfcSGreg Roach} 105dd6b2bfcSGreg Roach$birt_by_decade = []; 106dd6b2bfcSGreg Roach$deat_by_decade = []; 1071b860509SRico Sonntagfor ($year = 1400; $year < 2050; $year += 10) { 1081b860509SRico Sonntag $birt_by_decade[$year]['M'] = 0; 1091b860509SRico Sonntag $birt_by_decade[$year]['F'] = 0; 1101b860509SRico Sonntag $birt_by_decade[$year]['U'] = 0; 1111b860509SRico Sonntag $deat_by_decade[$year]['M'] = 0; 1121b860509SRico Sonntag $deat_by_decade[$year]['F'] = 0; 1131b860509SRico Sonntag $deat_by_decade[$year]['U'] = 0; 114dd6b2bfcSGreg Roach} 1151b860509SRico Sonntag 1161b860509SRico Sonntag$birthData = [ 1171b860509SRico Sonntag [ 1181b860509SRico Sonntag [ 1191b860509SRico Sonntag 'label' => I18N::translate('Century'), 1201b860509SRico Sonntag 'type' => 'date', 1211b860509SRico Sonntag ], [ 1221b860509SRico Sonntag 'label' => I18N::translate('Males'), 1231b860509SRico Sonntag 'type' => 'number', 1241b860509SRico Sonntag ], [ 1251b860509SRico Sonntag 'label' => I18N::translate('Females'), 1261b860509SRico Sonntag 'type' => 'number', 1271b860509SRico Sonntag ], 1281b860509SRico Sonntag ] 1291b860509SRico Sonntag]; 1301b860509SRico Sonntag 1311b860509SRico Sonntag$deathData = [ 1321b860509SRico Sonntag [ 1331b860509SRico Sonntag [ 1341b860509SRico Sonntag 'label' => I18N::translate('Century'), 1351b860509SRico Sonntag 'type' => 'date', 1361b860509SRico Sonntag ], [ 1371b860509SRico Sonntag 'label' => I18N::translate('Males'), 1381b860509SRico Sonntag 'type' => 'number', 1391b860509SRico Sonntag ], [ 1401b860509SRico Sonntag 'label' => I18N::translate('Females'), 1411b860509SRico Sonntag 'type' => 'number', 1421b860509SRico Sonntag ], 1431b860509SRico Sonntag ] 1441b860509SRico Sonntag]; 1451b860509SRico Sonntag 1461b860509SRico Sonntag$deathAgeData = [ 1471b860509SRico Sonntag [ 1481b860509SRico Sonntag I18N::translate('Age'), 1491b860509SRico Sonntag I18N::translate('Males'), 1501b860509SRico Sonntag I18N::translate('Females'), 1511b860509SRico Sonntag I18N::translate('Average age'), 1521b860509SRico Sonntag ] 1531b860509SRico Sonntag]; 1541b860509SRico Sonntag 155dd6b2bfcSGreg Roach?> 156dd6b2bfcSGreg Roach 157dd6b2bfcSGreg Roach<div class="indi-list"> 1585529b85eSGreg Roach <table id="<?= e($table_id) ?>" class="table-bordered" 159b6c326d8SGreg Roach <?= view('lists/datatables-attributes') ?> 160b6c326d8SGreg Roach > 161dd6b2bfcSGreg Roach <thead> 162dd6b2bfcSGreg Roach <tr> 163dd6b2bfcSGreg Roach <th colspan="16"> 164dd6b2bfcSGreg Roach <div class="btn-toolbar d-flex justify-content-between mb-2" role="toolbar"> 165dd6b2bfcSGreg Roach <div class="btn-group" data-toggle="buttons"> 166dd6b2bfcSGreg Roach <button 167dd6b2bfcSGreg Roach class="btn btn-secondary" 168dd6b2bfcSGreg Roach data-filter-column="12" 169dd6b2bfcSGreg Roach data-filter-value="M" 170dd6b2bfcSGreg Roach title="<?= I18N::translate('Show only males.') ?>" 171dd6b2bfcSGreg Roach > 172032918ffSGreg Roach <?= view('icons/sex-M') ?> 173dd6b2bfcSGreg Roach </button> 174dd6b2bfcSGreg Roach <button 175dd6b2bfcSGreg Roach class="btn btn-secondary" 176dd6b2bfcSGreg Roach data-filter-column="12" 177dd6b2bfcSGreg Roach data-filter-value="F" 178dd6b2bfcSGreg Roach title="<?= I18N::translate('Show only females.') ?>" 179dd6b2bfcSGreg Roach > 180032918ffSGreg Roach <?= view('icons/sex-F') ?> 181dd6b2bfcSGreg Roach </button> 182dd6b2bfcSGreg Roach <button 183dd6b2bfcSGreg Roach class="btn btn-secondary" 184dd6b2bfcSGreg Roach data-filter-column="12" 185dd6b2bfcSGreg Roach data-filter-value="U" 186dd6b2bfcSGreg Roach title="<?= I18N::translate('Show only individuals for whom the gender is not known.') ?>" 187dd6b2bfcSGreg Roach > 188032918ffSGreg Roach <?= view('icons/sex-U') ?> 189dd6b2bfcSGreg Roach </button> 190dd6b2bfcSGreg Roach </div> 191dd6b2bfcSGreg Roach <div class="btn-group" data-toggle="buttons"> 192dd6b2bfcSGreg Roach <button 193dd6b2bfcSGreg Roach class="btn btn-secondary" 194dd6b2bfcSGreg Roach data-filter-column="14" 195dd6b2bfcSGreg Roach data-filter-value="N" 196dd6b2bfcSGreg Roach title="<?= I18N::translate('Show individuals who are alive or couples where both partners are alive.') ?>" 197dd6b2bfcSGreg Roach > 198dd6b2bfcSGreg Roach <?= I18N::translate('Alive') ?> 199dd6b2bfcSGreg Roach </button> 200dd6b2bfcSGreg Roach <button 201dd6b2bfcSGreg Roach class="btn btn-secondary" 202dd6b2bfcSGreg Roach data-filter-column="14" 203dd6b2bfcSGreg Roach data-filter-value="Y" 204dd6b2bfcSGreg Roach title="<?= I18N::translate('Show individuals who are dead or couples where both partners are dead.') ?>" 205dd6b2bfcSGreg Roach > 206dd6b2bfcSGreg Roach <?= I18N::translate('Dead') ?> 207dd6b2bfcSGreg Roach </button> 208dd6b2bfcSGreg Roach <button 209dd6b2bfcSGreg Roach class="btn btn-secondary" 210dd6b2bfcSGreg Roach data-filter-column="14" 211dd6b2bfcSGreg Roach data-filter-value="YES" 212dd6b2bfcSGreg Roach title="<?= I18N::translate('Show individuals who died more than 100 years ago.') ?>" 213dd6b2bfcSGreg Roach > 214dd6b2bfcSGreg Roach <?= I18N::translate('Death') ?>>100 215dd6b2bfcSGreg Roach </button> 216dd6b2bfcSGreg Roach <button 217dd6b2bfcSGreg Roach class="btn btn-secondary" 218dd6b2bfcSGreg Roach data-filter-column="14" 219dd6b2bfcSGreg Roach data-filter-value="Y100" 220dd6b2bfcSGreg Roach title="<?= I18N::translate('Show individuals who died within the last 100 years.') ?>" 221dd6b2bfcSGreg Roach > 222392561bbSGreg Roach <?= I18N::translate('Death') ?><=100 223dd6b2bfcSGreg Roach </button> 224dd6b2bfcSGreg Roach </div> 225dd6b2bfcSGreg Roach <div class="btn-group" data-toggle="buttons"> 226dd6b2bfcSGreg Roach <button 227dd6b2bfcSGreg Roach class="btn btn-secondary" 228dd6b2bfcSGreg Roach data-filter-column="13" 229dd6b2bfcSGreg Roach data-filter-value="YES" 230dd6b2bfcSGreg Roach title="<?= I18N::translate('Show individuals born more than 100 years ago.') ?>" 231dd6b2bfcSGreg Roach > 232dd6b2bfcSGreg Roach <?= I18N::translate('Birth') ?>>100 233dd6b2bfcSGreg Roach </button> 234dd6b2bfcSGreg Roach <button 235dd6b2bfcSGreg Roach class="btn btn-secondary" 236dd6b2bfcSGreg Roach data-filter-column="13" 237dd6b2bfcSGreg Roach data-filter-value="Y100" 238dd6b2bfcSGreg Roach title="<?= I18N::translate('Show individuals born within the last 100 years.') ?>" 239dd6b2bfcSGreg Roach > 240dd6b2bfcSGreg Roach <?= I18N::translate('Birth') ?><=100 241dd6b2bfcSGreg Roach </button> 242dd6b2bfcSGreg Roach </div> 243dd6b2bfcSGreg Roach <div class="btn-group" data-toggle="buttons"> 244dd6b2bfcSGreg Roach <button 245dd6b2bfcSGreg Roach class="btn btn-secondary" 246dd6b2bfcSGreg Roach data-filter-column="15" 247dd6b2bfcSGreg Roach data-filter-value="R" 248dd6b2bfcSGreg Roach title="<?= I18N::translate('Show “roots” couples or individuals. These individuals may also be called “patriarchs”. They are individuals who have no parents recorded in the database.') ?>" 249dd6b2bfcSGreg Roach > 250dd6b2bfcSGreg Roach <?= I18N::translate('Roots') ?> 251dd6b2bfcSGreg Roach </button> 252dd6b2bfcSGreg Roach <button 253dd6b2bfcSGreg Roach class="btn btn-secondary" 254dd6b2bfcSGreg Roach data-filter-column="15" 255dd6b2bfcSGreg Roach data-filter-value="L" 256dd6b2bfcSGreg Roach title="<?= I18N::translate('Show “leaves” couples or individuals. These are individuals who are alive but have no children recorded in the database.') ?>" 257dd6b2bfcSGreg Roach > 258dd6b2bfcSGreg Roach <?= I18N::translate('Leaves') ?> 259dd6b2bfcSGreg Roach </button> 260dd6b2bfcSGreg Roach </div> 261dd6b2bfcSGreg Roach </div> 262dd6b2bfcSGreg Roach </th> 263dd6b2bfcSGreg Roach </tr> 264dd6b2bfcSGreg Roach <tr> 265dd6b2bfcSGreg Roach <th><?= I18N::translate('Given names') ?></th> 266dd6b2bfcSGreg Roach <th><?= I18N::translate('Surname') ?></th> 267dd6b2bfcSGreg Roach <th><?= /* I18N: Abbreviation for “Sosa-Stradonitz number”. This is an individual’s surname, so may need transliterating into non-latin alphabets. */ 268dd6b2bfcSGreg Roach I18N::translate('Sosa') ?></th> 269dd6b2bfcSGreg Roach <th><?= I18N::translate('Birth') ?></th> 270dd6b2bfcSGreg Roach <th> 271e39fd5c6SGreg Roach <span title="<?= I18N::translate('Anniversary') ?>"> 272e39fd5c6SGreg Roach <?= view('icons/anniversary') ?> 273e39fd5c6SGreg Roach </span> 274dd6b2bfcSGreg Roach </th> 275dd6b2bfcSGreg Roach <th><?= I18N::translate('Place') ?></th> 276dd6b2bfcSGreg Roach <th> 277dd6b2bfcSGreg Roach <i class="icon-children" title="<?= I18N::translate('Children') ?>"></i> 278dd6b2bfcSGreg Roach </th> 279dd6b2bfcSGreg Roach <th><?= I18N::translate('Death') ?></th> 280dd6b2bfcSGreg Roach <th> 281e39fd5c6SGreg Roach <span title="<?= I18N::translate('Anniversary') ?>"> 282e39fd5c6SGreg Roach <?= view('icons/anniversary') ?> 283e39fd5c6SGreg Roach </span> 284dd6b2bfcSGreg Roach </th> 285dd6b2bfcSGreg Roach <th><?= I18N::translate('Age') ?></th> 286dd6b2bfcSGreg Roach <th><?= I18N::translate('Place') ?></th> 287dd6b2bfcSGreg Roach <th><?= I18N::translate('Last change') ?></th> 288dd6b2bfcSGreg Roach <th hidden></th> 289dd6b2bfcSGreg Roach <th hidden></th> 290dd6b2bfcSGreg Roach <th hidden></th> 291dd6b2bfcSGreg Roach <th hidden></th> 292dd6b2bfcSGreg Roach </tr> 293dd6b2bfcSGreg Roach </thead> 294dd6b2bfcSGreg Roach <tfoot> 295dd6b2bfcSGreg Roach <tr> 296dd6b2bfcSGreg Roach <th colspan="16"> 297dd6b2bfcSGreg Roach <div class="btn-toolbar"> 298dd6b2bfcSGreg Roach <div class="btn-group"> 299dd6b2bfcSGreg Roach <button class="ui-state-default btn-toggle-parents"> 300dd6b2bfcSGreg Roach <?= I18N::translate('Show parents') ?> 301dd6b2bfcSGreg Roach </button> 302dd6b2bfcSGreg Roach <button class="ui-state-default btn-toggle-statistics"> 303dd6b2bfcSGreg Roach <?= I18N::translate('Show statistics charts') ?> 304dd6b2bfcSGreg Roach </button> 305dd6b2bfcSGreg Roach </div> 306dd6b2bfcSGreg Roach </div> 307dd6b2bfcSGreg Roach </th> 308dd6b2bfcSGreg Roach </tr> 309dd6b2bfcSGreg Roach </tfoot> 310dd6b2bfcSGreg Roach 311dd6b2bfcSGreg Roach <tbody> 312dd6b2bfcSGreg Roach <?php foreach ($individuals as $key => $individual) : ?> 31317dd427eSGreg Roach <tr class="<?= $individual->isPendingDeletion() ? 'wt-old' : ($individual->isPendingAddition() ? 'wt-new' : '') ?>"> 31439ca88baSGreg Roach <td colspan="2" data-sort="<?= e(str_replace([',', '@P.N.', '@N.N.'], 'AAAA', implode(',', array_reverse(explode(',', $individual->sortName()))))) ?>"> 315dd6b2bfcSGreg Roach <?php foreach ($individual->getAllNames() as $num => $name) : ?> 316dd6b2bfcSGreg Roach <a title="<?= $name['type'] === 'NAME' ? '' : GedcomTag::getLabel($name['type'], $individual) ?>" href="<?= e($individual->url()) ?>" class="<?= $num === $individual->getPrimaryName() ? 'name2' : '' ?>"> 317dd6b2bfcSGreg Roach <?= $name['full'] ?> 318dd6b2bfcSGreg Roach </a> 319dd6b2bfcSGreg Roach <?php if ($num === $individual->getPrimaryName()) : ?> 320032918ffSGreg Roach <small><?= view('icons/sex-' . $individual->sex()) ?></small> 321dd6b2bfcSGreg Roach <?php endif ?> 322dd6b2bfcSGreg Roach <br> 323dd6b2bfcSGreg Roach <?php endforeach ?> 324dd6b2bfcSGreg Roach <?= $individual->getPrimaryParentsNames('parents details1', 'none') ?> 325dd6b2bfcSGreg Roach </td> 326dd6b2bfcSGreg Roach 32739ca88baSGreg Roach <td hidden data-sort="<?= e(str_replace([',', '@P.N.', '@N.N.'], 'AAAA', $individual->sortName())) ?>"></td> 328dd6b2bfcSGreg Roach 329242a7862SGreg Roach <td class="text-center" data-sort="<?= $key ?>"> 330dd6b2bfcSGreg Roach <?php if ($sosa) : ?> 33184b37362SGreg Roach <?php if ($module instanceof RelationshipsChartModule) : ?> 33284b37362SGreg Roach <a href="<?= e($module->chartUrl($individuals[1], ['xref2' => $individual->xref()])) ?>" rel="nofollow" title="<?= I18N::translate('Relationships') ?>" rel="nofollow"> 333dd6b2bfcSGreg Roach <?= I18N::number($key) ?> 334dd6b2bfcSGreg Roach </a> 33584b37362SGreg Roach <?php else : ?> 33684b37362SGreg Roach <?= I18N::number($key) ?> 33784b37362SGreg Roach <?php endif ?> 338dd6b2bfcSGreg Roach <?php endif ?> 339dd6b2bfcSGreg Roach </td> 340dd6b2bfcSGreg Roach 341dd6b2bfcSGreg Roach <!-- Birth date --> 342dd6b2bfcSGreg Roach <td data-sort="<?= $individual->getEstimatedBirthDate()->julianDay() ?>"> 343dd6b2bfcSGreg Roach <?php $birth_dates = $individual->getAllBirthDates(); ?> 344dd6b2bfcSGreg Roach 345dd6b2bfcSGreg Roach <?php foreach ($birth_dates as $n => $birth_date) : ?> 346dd6b2bfcSGreg Roach <?= $birth_date->display(true) ?> 347dd6b2bfcSGreg Roach <br> 348dd6b2bfcSGreg Roach <?php endforeach ?> 34914147f6fSGreg Roach 350b2a8cedfSGreg Roach <?php if (empty($birth_dates) && $show_estimated_dates): ?> 35114147f6fSGreg Roach <?= $individual->getEstimatedBirthDate()->display(true) ?> 35214147f6fSGreg Roach <?php endif ?> 353dd6b2bfcSGreg Roach </td> 354dd6b2bfcSGreg Roach 355dd6b2bfcSGreg Roach <!-- Birth anniversary --> 356242a7862SGreg Roach <td class="text-center" data-sort="<?= -$individual->getEstimatedBirthDate()->julianDay() ?>"> 357c0935879SGreg Roach <?php if (isset($birth_dates[0]) && $birth_dates[0]->gregorianYear() >= 1550 && $birth_dates[0]->gregorianYear() < 2030 && !isset($unique_indis[$individual->xref()])) : ?> 3581b860509SRico Sonntag <?php 3591b860509SRico Sonntag ++$birt_by_decade[(int) ($birth_dates[0]->gregorianYear() / 10) * 10][$individual->sex()]; 3601b860509SRico Sonntag ?> 3611b860509SRico Sonntag <?= Date::getAge($birth_dates[0]) ?> 362dd6b2bfcSGreg Roach <?php endif ?> 363dd6b2bfcSGreg Roach </td> 364dd6b2bfcSGreg Roach 365dd6b2bfcSGreg Roach <!-- Birth place --> 366dd6b2bfcSGreg Roach <td> 367dd6b2bfcSGreg Roach <?php foreach ($individual->getAllBirthPlaces() as $n => $birth_place) : ?> 368392561bbSGreg Roach <?= $birth_place->shortName(true) ?> 369dd6b2bfcSGreg Roach <br> 370dd6b2bfcSGreg Roach <?php endforeach ?> 371dd6b2bfcSGreg Roach </td> 372dd6b2bfcSGreg Roach 373dd6b2bfcSGreg Roach <!-- Number of children --> 37439ca88baSGreg Roach <td class="text-center" data-sort="<?= $individual->numberOfChildren() ?>"> 37539ca88baSGreg Roach <?= I18N::number($individual->numberOfChildren()) ?> 376dd6b2bfcSGreg Roach </td> 377dd6b2bfcSGreg Roach 378dd6b2bfcSGreg Roach <!-- Death date --> 379dd6b2bfcSGreg Roach <?php $death_dates = $individual->getAllDeathDates() ?> 380dd6b2bfcSGreg Roach <td data-sort="<?= $individual->getEstimatedDeathDate()->julianDay() ?>"> 381dd6b2bfcSGreg Roach <?php foreach ($death_dates as $num => $death_date) : ?> 382dd6b2bfcSGreg Roach <?= $death_date->display(true) ?> 383dd6b2bfcSGreg Roach <br> 384dd6b2bfcSGreg Roach <?php endforeach ?> 38514147f6fSGreg Roach 386b2a8cedfSGreg Roach <?php if (empty($death_dates) && $show_estimated_dates && $individual->getEstimatedDeathDate()->minimumDate()->minimumJulianDay() < $today_jd): ?> 38714147f6fSGreg Roach <?= $individual->getEstimatedDeathDate()->display(true) ?> 38814147f6fSGreg Roach <?php endif ?> 389dd6b2bfcSGreg Roach </td> 390dd6b2bfcSGreg Roach 391dd6b2bfcSGreg Roach <!-- Death anniversary --> 392242a7862SGreg Roach <td class="text-center" data-sort="<?= -$individual->getEstimatedDeathDate()->julianDay() ?>"> 393c0935879SGreg Roach <?php if (isset($death_dates[0]) && $death_dates[0]->gregorianYear() >= 1550 && $death_dates[0]->gregorianYear() < 2030 && !isset($unique_indis[$individual->xref()])) : ?> 3941b860509SRico Sonntag <?php 3951b860509SRico Sonntag ++$deat_by_decade[(int) ($death_dates[0]->gregorianYear() / 10) * 10][$individual->sex()]; 3961b860509SRico Sonntag ?> 3971b860509SRico Sonntag <?= Date::getAge($death_dates[0]) ?> 398dd6b2bfcSGreg Roach <?php endif ?> 399dd6b2bfcSGreg Roach </td> 400dd6b2bfcSGreg Roach 401dd6b2bfcSGreg Roach <!-- Age at death --> 4023cfcc809SGreg Roach <?php if (isset($birth_dates[0], $death_dates[0])) : ?> 40357ab2231SGreg Roach <?php $age_at_death_years = Date::getAgeYears($birth_dates[0], $death_dates[0]); ?> 404dd6b2bfcSGreg Roach <?php $age_at_death_sort = Date::getAge($birth_dates[0], $death_dates[0]); ?> 4054e96702fSGreg Roach <?php $age_at_death_display = I18N::number($age_at_death_years); ?> 4064e96702fSGreg Roach <?php if (!isset($unique_indis[$individual->xref()]) && $age_at_death_years >= 0 && $age_at_death_years <= $max_age) : ?> 4071b860509SRico Sonntag <?php 4084e96702fSGreg Roach ++$deat_by_age[$age_at_death_years][$individual->sex()]; 4091b860509SRico Sonntag ?> 410dd6b2bfcSGreg Roach <?php endif ?> 411dd6b2bfcSGreg Roach <?php else : ?> 4124e96702fSGreg Roach <?php $age_at_death_display = ''; ?> 413dd6b2bfcSGreg Roach <?php $age_at_death_sort = PHP_INT_MAX; ?> 414dd6b2bfcSGreg Roach <?php endif ?> 415242a7862SGreg Roach <td class="text-center" data-sort="<?= e($age_at_death_sort) ?>"> 4164e96702fSGreg Roach <?= e($age_at_death_display) ?> 417dd6b2bfcSGreg Roach </td> 418dd6b2bfcSGreg Roach 419dd6b2bfcSGreg Roach <!-- Death place --> 420dd6b2bfcSGreg Roach <td> 421dd6b2bfcSGreg Roach <?php foreach ($individual->getAllDeathPlaces() as $n => $death_place) : ?> 422392561bbSGreg Roach <?= $death_place->shortName(true) ?> 423dd6b2bfcSGreg Roach <br> 424dd6b2bfcSGreg Roach <?php endforeach ?> 425dd6b2bfcSGreg Roach </td> 426dd6b2bfcSGreg Roach 427dd6b2bfcSGreg Roach <!-- Last change --> 4284459dc9aSGreg Roach <td data-sort="<?= $individual->lastChangeTimestamp()->unix() ?>"> 4294459dc9aSGreg Roach <?= view('components/datetime', ['timestamp' => $individual->lastChangeTimestamp()]) ?> 430dd6b2bfcSGreg Roach </td> 431dd6b2bfcSGreg Roach 432dd6b2bfcSGreg Roach <!-- Filter by sex --> 433dd6b2bfcSGreg Roach <td hidden> 43439ca88baSGreg Roach <?= $individual->sex() ?> 435dd6b2bfcSGreg Roach </td> 436dd6b2bfcSGreg Roach 437dd6b2bfcSGreg Roach <!-- Filter by birth date --> 438dd6b2bfcSGreg Roach <td hidden> 439*5373aac2SGreg Roach <?php if (!$individual->canShow() || $individual->getEstimatedBirthDate()->maximumJulianDay() > $hundred_years_ago) : ?> 440dd6b2bfcSGreg Roach Y100 441dd6b2bfcSGreg Roach <?php else : ?> 442dd6b2bfcSGreg Roach YES 443dd6b2bfcSGreg Roach <?php endif ?> 444dd6b2bfcSGreg Roach </td> 445dd6b2bfcSGreg Roach 446dd6b2bfcSGreg Roach <!-- Filter by death date --> 447dd6b2bfcSGreg Roach <td hidden> 448*5373aac2SGreg Roach <?php if ($individual->getEstimatedDeathDate()->maximumJulianDay() > $hundred_years_ago) : ?> 449dd6b2bfcSGreg Roach Y100 450dd6b2bfcSGreg Roach <?php elseif ($individual->isDead()) : ?> 451dd6b2bfcSGreg Roach YES 452dd6b2bfcSGreg Roach <?php else : ?> 453dd6b2bfcSGreg Roach N 454dd6b2bfcSGreg Roach <?php endif ?> 455dd6b2bfcSGreg Roach </td> 456dd6b2bfcSGreg Roach 457dd6b2bfcSGreg Roach <!-- Filter by roots/leaves --> 458dd6b2bfcSGreg Roach <td hidden> 45908662657SGreg Roach <?php if ($individual->childFamilies()->isEmpty()) : ?> 460dd6b2bfcSGreg Roach R 46139ca88baSGreg Roach <?php elseif (!$individual->isDead() && $individual->numberOfChildren() < 1) : ?> 462dd6b2bfcSGreg Roach L 463dd6b2bfcSGreg Roach <?php endif ?> 464dd6b2bfcSGreg Roach </td> 465dd6b2bfcSGreg Roach </tr> 466dd6b2bfcSGreg Roach 467c0935879SGreg Roach <?php $unique_indis[$individual->xref()] = true ?> 468dd6b2bfcSGreg Roach <?php endforeach ?> 469dd6b2bfcSGreg Roach </tbody> 470dd6b2bfcSGreg Roach </table> 4711b860509SRico Sonntag</div> 472dd6b2bfcSGreg Roach 4731b860509SRico Sonntag<div id="individual-charts-<?= e($table_id) ?>" style="display: none;"> 4741b860509SRico Sonntag <div class="mb-3"> 4751b860509SRico Sonntag <div class="card-deck"> 4761b860509SRico Sonntag <div class="col-lg-12 col-md-12 mb-3"> 4771b860509SRico Sonntag <div class="card m-0"> 4781b860509SRico Sonntag <div class="card-header"> 4791b860509SRico Sonntag <?= I18N::translate('Decade of birth') ?> 4801b860509SRico Sonntag </div> 4811b860509SRico Sonntag <div class="card-body"> 4821b860509SRico Sonntag <?php 4831b860509SRico Sonntag foreach ($birt_by_decade as $century => $values) { 4841b860509SRico Sonntag if (($values['M'] + $values['F']) > 0) { 4851b860509SRico Sonntag $birthData[] = [ 4861b860509SRico Sonntag [ 4871b860509SRico Sonntag 'v' => 'Date(' . $century . ', 0, 1)', 4881b860509SRico Sonntag 'f' => $century, 4891b860509SRico Sonntag ], 4901b860509SRico Sonntag $values['M'], 4911b860509SRico Sonntag $values['F'], 4921b860509SRico Sonntag ]; 4931b860509SRico Sonntag } 4941b860509SRico Sonntag } 4951b860509SRico Sonntag ?> 4961b860509SRico Sonntag <?= view('lists/chart-by-decade', ['data' => $birthData, 'title' => I18N::translate('Decade of birth')]) ?> 4971b860509SRico Sonntag </div> 4981b860509SRico Sonntag </div> 4991b860509SRico Sonntag </div> 5001b860509SRico Sonntag </div> 5011b860509SRico Sonntag <div class="card-deck"> 5021b860509SRico Sonntag <div class="col-lg-12 col-md-12 mb-3"> 5031b860509SRico Sonntag <div class="card m-0"> 5041b860509SRico Sonntag <div class="card-header"> 5051b860509SRico Sonntag <?= I18N::translate('Decade of death') ?> 5061b860509SRico Sonntag </div> 5071b860509SRico Sonntag <div class="card-body"> 5081b860509SRico Sonntag <?php 5091b860509SRico Sonntag foreach ($deat_by_decade as $century => $values) { 5101b860509SRico Sonntag if (($values['M'] + $values['F']) > 0) { 5111b860509SRico Sonntag $deathData[] = [ 5121b860509SRico Sonntag [ 5131b860509SRico Sonntag 'v' => 'Date(' . $century . ', 0, 1)', 5141b860509SRico Sonntag 'f' => $century, 5151b860509SRico Sonntag ], 5161b860509SRico Sonntag $values['M'], 5171b860509SRico Sonntag $values['F'], 5181b860509SRico Sonntag ]; 5191b860509SRico Sonntag } 5201b860509SRico Sonntag } 5211b860509SRico Sonntag ?> 5221b860509SRico Sonntag <?= view('lists/chart-by-decade', ['data' => $deathData, 'title' => I18N::translate('Decade of death')]) ?> 5231b860509SRico Sonntag </div> 5241b860509SRico Sonntag </div> 5251b860509SRico Sonntag </div> 5261b860509SRico Sonntag </div> 5271b860509SRico Sonntag <div class="card-deck"> 5281b860509SRico Sonntag <div class="col-lg-12 col-md-12 mb-3"> 5291b860509SRico Sonntag <div class="card m-0"> 5301b860509SRico Sonntag <div class="card-header"> 5311b860509SRico Sonntag <?= I18N::translate('Age related to death year') ?> 5321b860509SRico Sonntag </div> 5331b860509SRico Sonntag <div class="card-body"> 5341b860509SRico Sonntag <?php 5351b860509SRico Sonntag $totalAge = 0; 5361b860509SRico Sonntag $totalSum = 0; 5371b860509SRico Sonntag $max = 0; 5381b860509SRico Sonntag 5391b860509SRico Sonntag foreach ($deat_by_age as $age => $values) { 5401b860509SRico Sonntag if (($values['M'] + $values['F']) > 0) { 5411b860509SRico Sonntag if (($values['M'] + $values['F']) > $max) { 5421b860509SRico Sonntag $max = $values['M'] + $values['F']; 5431b860509SRico Sonntag } 5441b860509SRico Sonntag 5451b860509SRico Sonntag $totalAge += $age * ($values['M'] + $values['F']); 5461b860509SRico Sonntag $totalSum += $values['M'] + $values['F']; 5471b860509SRico Sonntag 5481b860509SRico Sonntag $deathAgeData[] = [ 5491b860509SRico Sonntag $age, 5501b860509SRico Sonntag $values['M'], 5511b860509SRico Sonntag $values['F'], 5521b860509SRico Sonntag null, 5531b860509SRico Sonntag ]; 5541b860509SRico Sonntag } 5551b860509SRico Sonntag } 5561b860509SRico Sonntag 5571b860509SRico Sonntag if ($totalSum > 0) { 5581b860509SRico Sonntag $deathAgeData[] = [ 5591b860509SRico Sonntag round($totalAge / $totalSum, 1), 5601b860509SRico Sonntag null, 5611b860509SRico Sonntag null, 5621b860509SRico Sonntag 0, 5631b860509SRico Sonntag ]; 5641b860509SRico Sonntag 5651b860509SRico Sonntag $deathAgeData[] = [ 5661b860509SRico Sonntag round($totalAge / $totalSum, 1), 5671b860509SRico Sonntag null, 5681b860509SRico Sonntag null, 5691b860509SRico Sonntag $max, 5701b860509SRico Sonntag ]; 5711b860509SRico Sonntag } 5721b860509SRico Sonntag ?> 5731b860509SRico Sonntag <?= view('lists/chart-by-age', ['data' => $deathAgeData, 'title' => I18N::translate('Age related to death year')]) ?> 5741b860509SRico Sonntag </div> 5751b860509SRico Sonntag </div> 5761b860509SRico Sonntag </div> 5771b860509SRico Sonntag </div> 578dd6b2bfcSGreg Roach </div> 579dd6b2bfcSGreg Roach</div> 580