xref: /webtrees/app/Elements/WhereWithinSource.php (revision d11be7027e34e3121be11cc025421873364403f9)
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\Elements;
21c2ed51d1SGreg Roach
22c2ed51d1SGreg Roachuse Fisharebest\Webtrees\Http\RequestHandlers\AutoCompleteCitation;
23c2ed51d1SGreg Roachuse Fisharebest\Webtrees\Tree;
24c2ed51d1SGreg Roach
25c2ed51d1SGreg Roachuse function e;
26c2ed51d1SGreg Roachuse function route;
27c2ed51d1SGreg Roach
28c2ed51d1SGreg Roach/**
29c2ed51d1SGreg Roach * WHERE_WITHIN_SOURCE := {Size=1:248}
30c2ed51d1SGreg Roach * Specific location with in the information referenced. For a published work, this could include
31c2ed51d1SGreg Roach * the volume of a multi-volume work and the page number(s). For a periodical, it could include
32c2ed51d1SGreg Roach * volume, issue, and page numbers. For a newspaper, it could include a column number and page
33c2ed51d1SGreg Roach * number. For an unpublished source or microfilmed works, this could be a film or sheet number,
34c2ed51d1SGreg Roach * page number, frame number, etc. A census record might have an enumerating district, page number,
35c2ed51d1SGreg Roach * line number, dwelling number, and family number. The data in this field should be in the form of
36c2ed51d1SGreg Roach * a label and value pair, such as Label1: value, Label2: value, with each pair being separated by
37c2ed51d1SGreg Roach * a comma. For example, Film: 1234567, Frame: 344, Line: 28.
38c2ed51d1SGreg Roach */
39c2ed51d1SGreg Roachclass WhereWithinSource extends AbstractElement
40c2ed51d1SGreg Roach{
41c2ed51d1SGreg Roach    /**
42c2ed51d1SGreg Roach     * An edit control for this data.
43c2ed51d1SGreg Roach     *
44c2ed51d1SGreg Roach     * @param string $id
45c2ed51d1SGreg Roach     * @param string $name
46c2ed51d1SGreg Roach     * @param string $value
47c2ed51d1SGreg Roach     * @param Tree   $tree
48c2ed51d1SGreg Roach     *
49c2ed51d1SGreg Roach     * @return string
50c2ed51d1SGreg Roach     */
51c2ed51d1SGreg Roach    public function edit(string $id, string $name, string $value, Tree $tree): string
52c2ed51d1SGreg Roach    {
53d4786c66SGreg Roach        return '<input data-wt-autocomplete-url="' . e(route(AutoCompleteCitation::class, ['tree' => $tree->name()])) . '" data-wt-autocomplete-extra="SOUR" autocomplete="off" class="form-control" type="text" id="' . e($id) . '" name="' . e($name) . '" value="' . e($value) . '" />';
54c2ed51d1SGreg Roach    }
55a3287c67SGreg Roach
56a3287c67SGreg Roach    /**
57a3287c67SGreg Roach     * Display the value of this type of element.
58a3287c67SGreg Roach     *
59a3287c67SGreg Roach     * @param string $value
60a3287c67SGreg Roach     * @param Tree   $tree
61a3287c67SGreg Roach     *
62a3287c67SGreg Roach     * @return string
63a3287c67SGreg Roach     */
64a3287c67SGreg Roach    public function value(string $value, Tree $tree): string
65a3287c67SGreg Roach    {
66a3287c67SGreg Roach        return $this->valueAutoLink($value);
67a3287c67SGreg Roach    }
68c2ed51d1SGreg Roach}
69