1701f5d18SGreg Roach<?php 2701f5d18SGreg Roach 3701f5d18SGreg Roach/** 4701f5d18SGreg Roach * webtrees: online genealogy 5d11be702SGreg Roach * Copyright (C) 2023 webtrees development team 6701f5d18SGreg Roach * This program is free software: you can redistribute it and/or modify 7701f5d18SGreg Roach * it under the terms of the GNU General Public License as published by 8701f5d18SGreg Roach * the Free Software Foundation, either version 3 of the License, or 9701f5d18SGreg Roach * (at your option) any later version. 10701f5d18SGreg Roach * This program is distributed in the hope that it will be useful, 11701f5d18SGreg Roach * but WITHOUT ANY WARRANTY; without even the implied warranty of 12701f5d18SGreg Roach * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 13701f5d18SGreg Roach * GNU General Public License for more details. 14701f5d18SGreg Roach * You should have received a copy of the GNU General Public License 15701f5d18SGreg Roach * along with this program. If not, see <https://www.gnu.org/licenses/>. 16701f5d18SGreg Roach */ 17701f5d18SGreg Roach 18701f5d18SGreg Roachdeclare(strict_types=1); 19701f5d18SGreg Roach 20701f5d18SGreg Roachnamespace Fisharebest\Webtrees\Contracts; 21701f5d18SGreg Roach 22701f5d18SGreg Roachuse Closure; 23701f5d18SGreg Roachuse Fisharebest\Webtrees\SharedNote; 24701f5d18SGreg Roachuse Fisharebest\Webtrees\Tree; 25701f5d18SGreg Roach 26701f5d18SGreg Roach/** 27701f5d18SGreg Roach * Make a SharedNote object. 28701f5d18SGreg Roach */ 29*eb7ab465SGreg Roachinterface SharedNoteFactoryInterface extends GedcomRecordFactoryInterface 30701f5d18SGreg Roach{ 31701f5d18SGreg Roach /** 32701f5d18SGreg Roach * Create a note. 33701f5d18SGreg Roach * 34701f5d18SGreg Roach * @param string $xref 35701f5d18SGreg Roach * @param Tree $tree 36701f5d18SGreg Roach * @param string|null $gedcom 37701f5d18SGreg Roach * 38701f5d18SGreg Roach * @return SharedNote|null 39701f5d18SGreg Roach */ 40701f5d18SGreg Roach public function make(string $xref, Tree $tree, string $gedcom = null): ?SharedNote; 41701f5d18SGreg Roach 42701f5d18SGreg Roach /** 43701f5d18SGreg Roach * Create a note from a row in the database. 44701f5d18SGreg Roach * 45701f5d18SGreg Roach * @param Tree $tree 46701f5d18SGreg Roach * 47c6921a17SGreg Roach * @return Closure(object):SharedNote 48701f5d18SGreg Roach */ 49701f5d18SGreg Roach public function mapper(Tree $tree): Closure; 50701f5d18SGreg Roach 51701f5d18SGreg Roach /** 52701f5d18SGreg Roach * Create a note from raw GEDCOM data. 53701f5d18SGreg Roach * 54701f5d18SGreg Roach * @param string $xref 55701f5d18SGreg Roach * @param string $gedcom an empty string for new/pending records 56701f5d18SGreg Roach * @param string|null $pending null for a record with no pending edits, 57701f5d18SGreg Roach * empty string for records with pending deletions 58701f5d18SGreg Roach * @param Tree $tree 59701f5d18SGreg Roach * 60701f5d18SGreg Roach * @return SharedNote 61701f5d18SGreg Roach */ 62701f5d18SGreg Roach public function new(string $xref, string $gedcom, ?string $pending, Tree $tree): SharedNote; 63701f5d18SGreg Roach} 64