xref: /webtrees/app/Elements/WhereWithinSource.php (revision c2ed51d13a57743094c11c8fe84befd9d4f158cd)
1*c2ed51d1SGreg Roach<?php
2*c2ed51d1SGreg Roach
3*c2ed51d1SGreg Roach/**
4*c2ed51d1SGreg Roach * webtrees: online genealogy
5*c2ed51d1SGreg Roach * Copyright (C) 2021 webtrees development team
6*c2ed51d1SGreg Roach * This program is free software: you can redistribute it and/or modify
7*c2ed51d1SGreg Roach * it under the terms of the GNU General Public License as published by
8*c2ed51d1SGreg Roach * the Free Software Foundation, either version 3 of the License, or
9*c2ed51d1SGreg Roach * (at your option) any later version.
10*c2ed51d1SGreg Roach * This program is distributed in the hope that it will be useful,
11*c2ed51d1SGreg Roach * but WITHOUT ANY WARRANTY; without even the implied warranty of
12*c2ed51d1SGreg Roach * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13*c2ed51d1SGreg Roach * GNU General Public License for more details.
14*c2ed51d1SGreg Roach * You should have received a copy of the GNU General Public License
15*c2ed51d1SGreg Roach * along with this program. If not, see <https://www.gnu.org/licenses/>.
16*c2ed51d1SGreg Roach */
17*c2ed51d1SGreg Roach
18*c2ed51d1SGreg Roachdeclare(strict_types=1);
19*c2ed51d1SGreg Roach
20*c2ed51d1SGreg Roachnamespace Fisharebest\Webtrees\Elements;
21*c2ed51d1SGreg Roach
22*c2ed51d1SGreg Roachuse Fisharebest\Webtrees\Http\RequestHandlers\AutoCompleteCitation;
23*c2ed51d1SGreg Roachuse Fisharebest\Webtrees\Tree;
24*c2ed51d1SGreg Roach
25*c2ed51d1SGreg Roachuse function e;
26*c2ed51d1SGreg Roachuse function route;
27*c2ed51d1SGreg Roach
28*c2ed51d1SGreg Roach/**
29*c2ed51d1SGreg Roach * WHERE_WITHIN_SOURCE := {Size=1:248}
30*c2ed51d1SGreg Roach * Specific location with in the information referenced. For a published work, this could include
31*c2ed51d1SGreg Roach * the volume of a multi-volume work and the page number(s). For a periodical, it could include
32*c2ed51d1SGreg Roach * volume, issue, and page numbers. For a newspaper, it could include a column number and page
33*c2ed51d1SGreg Roach * number. For an unpublished source or microfilmed works, this could be a film or sheet number,
34*c2ed51d1SGreg Roach * page number, frame number, etc. A census record might have an enumerating district, page number,
35*c2ed51d1SGreg Roach * line number, dwelling number, and family number. The data in this field should be in the form of
36*c2ed51d1SGreg Roach * a label and value pair, such as Label1: value, Label2: value, with each pair being separated by
37*c2ed51d1SGreg Roach * a comma. For example, Film: 1234567, Frame: 344, Line: 28.
38*c2ed51d1SGreg Roach */
39*c2ed51d1SGreg Roachclass WhereWithinSource extends AbstractElement
40*c2ed51d1SGreg Roach{
41*c2ed51d1SGreg Roach    /**
42*c2ed51d1SGreg Roach     * An edit control for this data.
43*c2ed51d1SGreg Roach     *
44*c2ed51d1SGreg Roach     * @param string $id
45*c2ed51d1SGreg Roach     * @param string $name
46*c2ed51d1SGreg Roach     * @param string $value
47*c2ed51d1SGreg Roach     * @param Tree   $tree
48*c2ed51d1SGreg Roach     *
49*c2ed51d1SGreg Roach     * @return string
50*c2ed51d1SGreg Roach     */
51*c2ed51d1SGreg Roach    public function edit(string $id, string $name, string $value, Tree $tree): string
52*c2ed51d1SGreg Roach    {
53*c2ed51d1SGreg Roach        return '<input data-autocomplete-url="' . e(route(AutoCompleteCitation::class, ['tree' => $tree->name()])) . '" data-autocomplete-extra="SOUR" autocomplete="off" class="form-control" type="text" id="' . e($id) . '" name="' . e($name) . '" value="' . e($value) . '">';
54*c2ed51d1SGreg Roach    }
55*c2ed51d1SGreg Roach}
56