1c2ed51d1SGreg Roach<?php 2c2ed51d1SGreg Roach 3c2ed51d1SGreg Roach/** 4c2ed51d1SGreg Roach * webtrees: online genealogy 5*d11be702SGreg Roach * Copyright (C) 2023 webtrees development team 6c2ed51d1SGreg Roach * This program is free software: you can redistribute it and/or modify 7c2ed51d1SGreg Roach * it under the terms of the GNU General Public License as published by 8c2ed51d1SGreg Roach * the Free Software Foundation, either version 3 of the License, or 9c2ed51d1SGreg Roach * (at your option) any later version. 10c2ed51d1SGreg Roach * This program is distributed in the hope that it will be useful, 11c2ed51d1SGreg Roach * but WITHOUT ANY WARRANTY; without even the implied warranty of 12c2ed51d1SGreg Roach * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 13c2ed51d1SGreg Roach * GNU General Public License for more details. 14c2ed51d1SGreg Roach * You should have received a copy of the GNU General Public License 15c2ed51d1SGreg Roach * along with this program. If not, see <https://www.gnu.org/licenses/>. 16c2ed51d1SGreg Roach */ 17c2ed51d1SGreg Roach 18c2ed51d1SGreg Roachdeclare(strict_types=1); 19c2ed51d1SGreg Roach 20c2ed51d1SGreg Roachnamespace Fisharebest\Webtrees\Contracts; 21c2ed51d1SGreg Roach 22c2ed51d1SGreg Roachuse Fisharebest\Webtrees\Tree; 23c2ed51d1SGreg Roach 24c2ed51d1SGreg Roach/** 25c2ed51d1SGreg Roach * A GEDCOM element is a tag/primitive in a GEDCOM file. 26c2ed51d1SGreg Roach */ 27c2ed51d1SGreg Roachinterface ElementInterface 28c2ed51d1SGreg Roach{ 29c2ed51d1SGreg Roach /** 30c2ed51d1SGreg Roach * Convert a value to a canonical form. 31c2ed51d1SGreg Roach * 32c2ed51d1SGreg Roach * @param string $value 33c2ed51d1SGreg Roach * 34c2ed51d1SGreg Roach * @return string 35c2ed51d1SGreg Roach */ 36c2ed51d1SGreg Roach public function canonical(string $value): string; 37c2ed51d1SGreg Roach 38c2ed51d1SGreg Roach /** 394e09581bSGreg Roach * Should we collapse the children of this element when editing? 404e09581bSGreg Roach * 414e09581bSGreg Roach * @return bool 424e09581bSGreg Roach */ 434e09581bSGreg Roach public function collapseChildren(): bool; 444e09581bSGreg Roach 454e09581bSGreg Roach /** 46c2ed51d1SGreg Roach * Create a default value for this element. 47c2ed51d1SGreg Roach * 48c2ed51d1SGreg Roach * @param Tree $tree 49c2ed51d1SGreg Roach * 50c2ed51d1SGreg Roach * @return string 51c2ed51d1SGreg Roach */ 52c2ed51d1SGreg Roach public function default(Tree $tree): string; 53c2ed51d1SGreg Roach 54c2ed51d1SGreg Roach /** 55c2ed51d1SGreg Roach * An edit control for this data. 56c2ed51d1SGreg Roach * 57c2ed51d1SGreg Roach * @param string $id 58c2ed51d1SGreg Roach * @param string $name 59c2ed51d1SGreg Roach * @param string $value 60c2ed51d1SGreg Roach * @param Tree $tree 61c2ed51d1SGreg Roach * 62c2ed51d1SGreg Roach * @return string 63c2ed51d1SGreg Roach */ 64c2ed51d1SGreg Roach public function edit(string $id, string $name, string $value, Tree $tree): string; 65c2ed51d1SGreg Roach 66c2ed51d1SGreg Roach /** 67c2ed51d1SGreg Roach * Escape @ signs in a GEDCOM export. 68c2ed51d1SGreg Roach * 69c2ed51d1SGreg Roach * @param string $value 70c2ed51d1SGreg Roach * 71c2ed51d1SGreg Roach * @return string 72c2ed51d1SGreg Roach */ 73c2ed51d1SGreg Roach public function escape(string $value): string; 74c2ed51d1SGreg Roach 75c2ed51d1SGreg Roach /** 76c2ed51d1SGreg Roach * Name for this GEDCOM primitive. 77c2ed51d1SGreg Roach * 78c2ed51d1SGreg Roach * @return string 79c2ed51d1SGreg Roach */ 80c2ed51d1SGreg Roach public function label(): string; 81c2ed51d1SGreg Roach 82c2ed51d1SGreg Roach /** 83c2ed51d1SGreg Roach * Create a label/value pair for this element. 84c2ed51d1SGreg Roach * 85c2ed51d1SGreg Roach * @param string $value 86c2ed51d1SGreg Roach * @param Tree $tree 87c2ed51d1SGreg Roach * 88c2ed51d1SGreg Roach * @return string 89c2ed51d1SGreg Roach */ 90c2ed51d1SGreg Roach public function labelValue(string $value, Tree $tree): string; 91c2ed51d1SGreg Roach 92c2ed51d1SGreg Roach /** 934dbb2a39SGreg Roach * Set, remove or replace a subtag. 944dbb2a39SGreg Roach * 954dbb2a39SGreg Roach * @param string $subtag 964dbb2a39SGreg Roach * @param string $repeat 974da96842SGreg Roach * @param string $before 984dbb2a39SGreg Roach * 994dbb2a39SGreg Roach * @return void 1004dbb2a39SGreg Roach */ 1018c21658eSGreg Roach public function subtag(string $subtag, string $repeat, string $before = ''): void; 1024dbb2a39SGreg Roach 1034dbb2a39SGreg Roach /** 104c2ed51d1SGreg Roach * @return array<string,string> 105c2ed51d1SGreg Roach */ 1063d2c98d1SGreg Roach public function subtags(): array; 107c2ed51d1SGreg Roach 108c2ed51d1SGreg Roach /** 109c2ed51d1SGreg Roach * Display the value of this type of element. 110c2ed51d1SGreg Roach * 111c2ed51d1SGreg Roach * @param string $value 112c2ed51d1SGreg Roach * @param Tree $tree 113c2ed51d1SGreg Roach * 114c2ed51d1SGreg Roach * @return string 115c2ed51d1SGreg Roach */ 116c2ed51d1SGreg Roach public function value(string $value, Tree $tree): string; 117c2ed51d1SGreg Roach 118c2ed51d1SGreg Roach /** 119c2ed51d1SGreg Roach * A list of controlled values for this element 120c2ed51d1SGreg Roach * 121c2ed51d1SGreg Roach * @return array<int|string,string> 122c2ed51d1SGreg Roach */ 123c2ed51d1SGreg Roach public function values(): array; 124c2ed51d1SGreg Roach} 125