xref: /webtrees/app/Elements/NameRomanizedVariation.php (revision e751be7452a90150e681e0a0f10eaad7af335fb0)
1c2ed51d1SGreg Roach<?php
2c2ed51d1SGreg Roach
3c2ed51d1SGreg Roach/**
4c2ed51d1SGreg Roach * webtrees: online genealogy
55bfc6897SGreg Roach * Copyright (C) 2022 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\Elements;
21c2ed51d1SGreg Roach
22c2ed51d1SGreg Roachuse Fisharebest\Webtrees\Tree;
23c2ed51d1SGreg Roach
24*e751be74SGreg Roachuse function e;
25c2ed51d1SGreg Roachuse function view;
26c2ed51d1SGreg Roach
27c2ed51d1SGreg Roach/**
28c2ed51d1SGreg Roach * NAME_ROMANIZED_VARIATION := {Size=1:120}
29c2ed51d1SGreg Roach * The romanized variation of the name is written in the same form prescribed
30c2ed51d1SGreg Roach * for the name used in the superior <NAME_PERSONAL> context. The method used
31c2ed51d1SGreg Roach * to romanize the name is indicated by the line_value of the subordinate
32c2ed51d1SGreg Roach * <ROMANIZED_TYPE>, for example if romaji was used to provide a reading of a
33c2ed51d1SGreg Roach * name written in kanji, then the ROMANIZED_TYPE subordinate to the ROMN tag
34c2ed51d1SGreg Roach * would indicate romaji. See page 61.
35c2ed51d1SGreg Roach */
36c96df257SGreg Roachclass NameRomanizedVariation extends NamePersonal
37c2ed51d1SGreg Roach{
384da96842SGreg Roach    protected const SUBTAGS = [
396a988794SGreg Roach        'TYPE' => '1:1',
404da96842SGreg Roach        'NPFX' => '0:1',
414da96842SGreg Roach        'GIVN' => '0:1',
424da96842SGreg Roach        'SPFX' => '0:1',
434da96842SGreg Roach        'SURN' => '0:1',
444da96842SGreg Roach        'NSFX' => '0:1',
454da96842SGreg Roach        'NICK' => '0:1',
4603c55594SGreg Roach        'NOTE' => '0:M',
4703c55594SGreg Roach        'SOUR' => '0:M',
484da96842SGreg Roach    ];
494da96842SGreg Roach
50c2ed51d1SGreg Roach    /**
51*e751be74SGreg Roach     * Convert a value to a canonical form.
52*e751be74SGreg Roach     *
53*e751be74SGreg Roach     * @param string $value
54*e751be74SGreg Roach     *
55*e751be74SGreg Roach     * @return string
56*e751be74SGreg Roach     */
57*e751be74SGreg Roach    public function canonical(string $value): string
58*e751be74SGreg Roach    {
59*e751be74SGreg Roach        $value = parent::canonical($value);
60*e751be74SGreg Roach
61*e751be74SGreg Roach        if ($value === '//') {
62*e751be74SGreg Roach            return '';
63*e751be74SGreg Roach        }
64*e751be74SGreg Roach
65*e751be74SGreg Roach        return $value;
66*e751be74SGreg Roach    }
67*e751be74SGreg Roach
68*e751be74SGreg Roach    /**
6903c55594SGreg Roach     * Should we collapse the children of this element when editing?
7003c55594SGreg Roach     *
7103c55594SGreg Roach     * @return bool
7203c55594SGreg Roach     */
7303c55594SGreg Roach    public function collapseChildren(): bool
7403c55594SGreg Roach    {
7503c55594SGreg Roach        return true;
7603c55594SGreg Roach    }
7703c55594SGreg Roach
7803c55594SGreg Roach    /**
79c2ed51d1SGreg Roach     * An edit control for this data.
80c2ed51d1SGreg Roach     *
81c2ed51d1SGreg Roach     * @param string $id
82c2ed51d1SGreg Roach     * @param string $name
83c2ed51d1SGreg Roach     * @param string $value
84c2ed51d1SGreg Roach     * @param Tree   $tree
85c2ed51d1SGreg Roach     *
86c2ed51d1SGreg Roach     * @return string
87c2ed51d1SGreg Roach     */
88c2ed51d1SGreg Roach    public function edit(string $id, string $name, string $value, Tree $tree): string
89c2ed51d1SGreg Roach    {
90c2ed51d1SGreg Roach        return
91c2ed51d1SGreg Roach            '<div class="input-group">' .
92*e751be74SGreg Roach            view('edit/input-addon-edit-name', ['id' => $id]) .
93*e751be74SGreg Roach            '<input class="form-control" type="text" id="' . e($id) . '" name="' . e($name) . '" value="' . e($value) . '" readonly="readonly" />' .
94*e751be74SGreg Roach            view('edit/input-addon-keyboard', ['id' => $id]) .
95ab7d502dSGreg Roach            view('edit/input-addon-help', ['topic' => 'ROMN']) .
96c2ed51d1SGreg Roach            '</div>';
97c2ed51d1SGreg Roach    }
98c2ed51d1SGreg Roach}
99