18add1155SRico Sonntag<?php 28add1155SRico Sonntag/** 38add1155SRico Sonntag * webtrees: online genealogy 4242a7862SGreg Roach * Copyright (C) 2019 webtrees development team 58add1155SRico Sonntag * This program is free software: you can redistribute it and/or modify 68add1155SRico Sonntag * it under the terms of the GNU General Public License as published by 78add1155SRico Sonntag * the Free Software Foundation, either version 3 of the License, or 88add1155SRico Sonntag * (at your option) any later version. 98add1155SRico Sonntag * This program is distributed in the hope that it will be useful, 108add1155SRico Sonntag * but WITHOUT ANY WARRANTY; without even the implied warranty of 118add1155SRico Sonntag * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 128add1155SRico Sonntag * GNU General Public License for more details. 138add1155SRico Sonntag * You should have received a copy of the GNU General Public License 148add1155SRico Sonntag * along with this program. If not, see <http://www.gnu.org/licenses/>. 158add1155SRico Sonntag */ 168add1155SRico Sonntagdeclare(strict_types=1); 178add1155SRico Sonntag 188add1155SRico Sonntagnamespace Fisharebest\Webtrees\Statistics\Repository; 198add1155SRico Sonntag 208add1155SRico Sonntaguse Fisharebest\Webtrees\Date; 21*820b62dfSGreg Roachuse Fisharebest\Webtrees\Fact; 228add1155SRico Sonntaguse Fisharebest\Webtrees\GedcomRecord; 238add1155SRico Sonntaguse Fisharebest\Webtrees\Statistics\Repository\Interfaces\GedcomRepositoryInterface; 248add1155SRico Sonntaguse Fisharebest\Webtrees\Tree; 258add1155SRico Sonntaguse Illuminate\Database\Capsule\Manager as DB; 268add1155SRico Sonntaguse Illuminate\Database\Query\Builder; 278add1155SRico Sonntag 288add1155SRico Sonntag/** 298add1155SRico Sonntag * A repository providing methods for GEDCOM related statistics. 308add1155SRico Sonntag */ 318add1155SRico Sonntagclass GedcomRepository implements GedcomRepositoryInterface 328add1155SRico Sonntag{ 338add1155SRico Sonntag /** 348add1155SRico Sonntag * @var Tree 358add1155SRico Sonntag */ 368add1155SRico Sonntag private $tree; 378add1155SRico Sonntag 388add1155SRico Sonntag /** 398add1155SRico Sonntag * Constructor. 408add1155SRico Sonntag * 418add1155SRico Sonntag * @param Tree $tree 428add1155SRico Sonntag */ 438add1155SRico Sonntag public function __construct(Tree $tree) 448add1155SRico Sonntag { 458add1155SRico Sonntag $this->tree = $tree; 468add1155SRico Sonntag } 478add1155SRico Sonntag 488add1155SRico Sonntag /** 498add1155SRico Sonntag * Get information from the GEDCOM's HEAD record. 508add1155SRico Sonntag * 518add1155SRico Sonntag * @return string[] 528add1155SRico Sonntag */ 538add1155SRico Sonntag private function gedcomHead(): array 548add1155SRico Sonntag { 558add1155SRico Sonntag $title = ''; 568add1155SRico Sonntag $version = ''; 578add1155SRico Sonntag $source = ''; 588add1155SRico Sonntag 598add1155SRico Sonntag $head = GedcomRecord::getInstance('HEAD', $this->tree); 608add1155SRico Sonntag 61*820b62dfSGreg Roach if ($head instanceof GedcomRecord) { 62*820b62dfSGreg Roach $sour = $head->facts(['SOUR'])->first(); 638add1155SRico Sonntag 64*820b62dfSGreg Roach if ($sour instanceof Fact) { 658add1155SRico Sonntag $source = $sour->value(); 668add1155SRico Sonntag $title = $sour->attribute('NAME'); 678add1155SRico Sonntag $version = $sour->attribute('VERS'); 688add1155SRico Sonntag } 698add1155SRico Sonntag } 708add1155SRico Sonntag 718add1155SRico Sonntag return [ 728add1155SRico Sonntag $title, 738add1155SRico Sonntag $version, 748add1155SRico Sonntag $source, 758add1155SRico Sonntag ]; 768add1155SRico Sonntag } 778add1155SRico Sonntag 788add1155SRico Sonntag /** 798add1155SRico Sonntag * @inheritDoc 808add1155SRico Sonntag */ 818add1155SRico Sonntag public function gedcomFilename(): string 828add1155SRico Sonntag { 838add1155SRico Sonntag return $this->tree->name(); 848add1155SRico Sonntag } 858add1155SRico Sonntag 868add1155SRico Sonntag /** 878add1155SRico Sonntag * @inheritDoc 888add1155SRico Sonntag */ 898add1155SRico Sonntag public function gedcomId(): int 908add1155SRico Sonntag { 918add1155SRico Sonntag return $this->tree->id(); 928add1155SRico Sonntag } 938add1155SRico Sonntag 948add1155SRico Sonntag /** 958add1155SRico Sonntag * @inheritDoc 968add1155SRico Sonntag */ 978add1155SRico Sonntag public function gedcomTitle(): string 988add1155SRico Sonntag { 998add1155SRico Sonntag return e($this->tree->title()); 1008add1155SRico Sonntag } 1018add1155SRico Sonntag 1028add1155SRico Sonntag /** 1038add1155SRico Sonntag * @inheritDoc 1048add1155SRico Sonntag */ 1058add1155SRico Sonntag public function gedcomCreatedSoftware(): string 1068add1155SRico Sonntag { 1078add1155SRico Sonntag return $this->gedcomHead()[0]; 1088add1155SRico Sonntag } 1098add1155SRico Sonntag 1108add1155SRico Sonntag /** 1118add1155SRico Sonntag * @inheritDoc 1128add1155SRico Sonntag */ 1138add1155SRico Sonntag public function gedcomCreatedVersion(): string 1148add1155SRico Sonntag { 1158add1155SRico Sonntag $head = $this->gedcomHead(); 1168add1155SRico Sonntag 1178add1155SRico Sonntag if ($head === null) { 1188add1155SRico Sonntag return ''; 1198add1155SRico Sonntag } 1208add1155SRico Sonntag 1218add1155SRico Sonntag // Fix broken version string in Family Tree Maker 1228add1155SRico Sonntag if (strpos($head[1], 'Family Tree Maker ') !== false) { 1238add1155SRico Sonntag $p = strpos($head[1], '(') + 1; 1248add1155SRico Sonntag $p2 = strpos($head[1], ')'); 1258add1155SRico Sonntag $head[1] = substr($head[1], $p, $p2 - $p); 1268add1155SRico Sonntag } 1278add1155SRico Sonntag 1288add1155SRico Sonntag // Fix EasyTree version 1298add1155SRico Sonntag if ($head[2] === 'EasyTree') { 1308add1155SRico Sonntag $head[1] = substr($head[1], 1); 1318add1155SRico Sonntag } 1328add1155SRico Sonntag 1338add1155SRico Sonntag return $head[1]; 1348add1155SRico Sonntag } 1358add1155SRico Sonntag 1368add1155SRico Sonntag /** 1378add1155SRico Sonntag * @inheritDoc 1388add1155SRico Sonntag */ 1398add1155SRico Sonntag public function gedcomDate(): string 1408add1155SRico Sonntag { 1418add1155SRico Sonntag $head = GedcomRecord::getInstance('HEAD', $this->tree); 1428add1155SRico Sonntag 143*820b62dfSGreg Roach if ($head instanceof GedcomRecord) { 144*820b62dfSGreg Roach $fact = $head->facts(['DATE'])->first(); 1458add1155SRico Sonntag 146*820b62dfSGreg Roach if ($fact instanceof Fact) { 1478add1155SRico Sonntag return (new Date($fact->value()))->display(); 1488add1155SRico Sonntag } 1498add1155SRico Sonntag } 1508add1155SRico Sonntag 1518add1155SRico Sonntag return ''; 1528add1155SRico Sonntag } 1538add1155SRico Sonntag 1548add1155SRico Sonntag /** 1558add1155SRico Sonntag * @inheritDoc 1568add1155SRico Sonntag */ 1578add1155SRico Sonntag public function gedcomUpdated(): string 1588add1155SRico Sonntag { 1598add1155SRico Sonntag $row = DB::table('dates') 1608add1155SRico Sonntag ->select(['d_year', 'd_month', 'd_day']) 1618add1155SRico Sonntag ->where('d_julianday1', '=', function (Builder $query) { 1628add1155SRico Sonntag $query->selectRaw('MAX(d_julianday1)') 1638add1155SRico Sonntag ->from('dates') 1648add1155SRico Sonntag ->where('d_file', '=', $this->tree->id()) 1658add1155SRico Sonntag ->where('d_fact', '=', 'CHAN'); 1668add1155SRico Sonntag }) 1678add1155SRico Sonntag ->first(); 1688add1155SRico Sonntag 1698add1155SRico Sonntag if ($row) { 1708add1155SRico Sonntag $date = new Date("{$row->d_day} {$row->d_month} {$row->d_year}"); 1718add1155SRico Sonntag return $date->display(); 1728add1155SRico Sonntag } 1738add1155SRico Sonntag 1748add1155SRico Sonntag return $this->gedcomDate(); 1758add1155SRico Sonntag } 1768add1155SRico Sonntag 1778add1155SRico Sonntag /** 1788add1155SRico Sonntag * @inheritDoc 1798add1155SRico Sonntag */ 1808add1155SRico Sonntag public function gedcomRootId(): string 1818add1155SRico Sonntag { 1828add1155SRico Sonntag return $this->tree->getPreference('PEDIGREE_ROOT_ID'); 1838add1155SRico Sonntag } 1848add1155SRico Sonntag} 185