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 */ 29eb7ab465SGreg Roachinterface SharedNoteFactoryInterface extends GedcomRecordFactoryInterface 30701f5d18SGreg Roach{ 31701f5d18SGreg Roach /** 32701f5d18SGreg Roach * Create a note. 33701f5d18SGreg Roach */ 34*1ff45046SGreg Roach public function make(string $xref, Tree $tree, string|null $gedcom = null): SharedNote|null; 35701f5d18SGreg Roach 36701f5d18SGreg Roach /** 37701f5d18SGreg Roach * Create a note from a row in the database. 38701f5d18SGreg Roach * 39701f5d18SGreg Roach * @param Tree $tree 40701f5d18SGreg Roach * 41c6921a17SGreg Roach * @return Closure(object):SharedNote 42701f5d18SGreg Roach */ 43701f5d18SGreg Roach public function mapper(Tree $tree): Closure; 44701f5d18SGreg Roach 45701f5d18SGreg Roach /** 46701f5d18SGreg Roach * Create a note from raw GEDCOM data. 47701f5d18SGreg Roach * 48701f5d18SGreg Roach * @param string $xref 49701f5d18SGreg Roach * @param string $gedcom an empty string for new/pending records 50701f5d18SGreg Roach * @param string|null $pending null for a record with no pending edits, 51701f5d18SGreg Roach * empty string for records with pending deletions 52701f5d18SGreg Roach * @param Tree $tree 53701f5d18SGreg Roach * 54701f5d18SGreg Roach * @return SharedNote 55701f5d18SGreg Roach */ 56*1ff45046SGreg Roach public function new(string $xref, string $gedcom, string|null $pending, Tree $tree): SharedNote; 57701f5d18SGreg Roach} 58