xref: /webtrees/app/Http/RequestHandlers/CreateSourceAction.php (revision 00b1984e374faddab4698e73088f0c964e529b65)
1<?php
2
3/**
4 * webtrees: online genealogy
5 * Copyright (C) 2019 webtrees development team
6 * This program is free software: you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation, either version 3 of the License, or
9 * (at your option) any later version.
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
14 * You should have received a copy of the GNU General Public License
15 * along with this program. If not, see <http://www.gnu.org/licenses/>.
16 */
17
18declare(strict_types=1);
19
20namespace Fisharebest\Webtrees\Http\RequestHandlers;
21
22use Fisharebest\Webtrees\I18N;
23use Fisharebest\Webtrees\Tree;
24use Psr\Http\Message\ResponseInterface;
25use Psr\Http\Message\ServerRequestInterface;
26use Psr\Http\Server\RequestHandlerInterface;
27
28use function assert;
29
30/**
31 * Process a form to create a new source.
32 */
33class CreateSourceAction implements RequestHandlerInterface
34{
35    /**
36     * @param ServerRequestInterface $request
37     *
38     * @return ResponseInterface
39     */
40    public function handle(ServerRequestInterface $request): ResponseInterface
41    {
42        $tree = $request->getAttribute('tree');
43        assert($tree instanceof Tree);
44
45        $params              = (array) $request->getParsedBody();
46        $title               = $params['source-title'];
47        $abbreviation        = $params['source-abbreviation'];
48        $author              = $params['source-author'];
49        $publication         = $params['source-publication'];
50        $repository          = $params['source-repository'];
51        $call_number         = $params['source-call-number'];
52        $text                = $params['source-text'];
53        $privacy_restriction = $params['privacy-restriction'];
54        $edit_restriction    = $params['edit-restriction'];
55
56        // Fix whitespace
57        $title        = trim(preg_replace('/\s+/', ' ', $title));
58        $abbreviation = trim(preg_replace('/\s+/', ' ', $abbreviation));
59        $author       = trim(preg_replace('/\s+/', ' ', $author));
60        $publication  = trim(preg_replace('/\s+/', ' ', $publication));
61        $repository   = trim(preg_replace('/\s+/', ' ', $repository));
62        $call_number  = trim(preg_replace('/\s+/', ' ', $call_number));
63
64        // Convert HTML line endings to GEDCOM continuations
65        $text = strtr($text, ["\r\n" => "\n2 CONT "]);
66
67        $gedcom = "0 @@ SOUR\n\n1 TITL " . $title;
68
69        if ($abbreviation !== '') {
70            $gedcom .= "\n1 ABBR " . $abbreviation;
71        }
72
73        if ($author !== '') {
74            $gedcom .= "\n1 AUTH " . $author;
75        }
76
77        if ($publication !== '') {
78            $gedcom .= "\n1 PUBL " . $publication;
79        }
80
81        if ($text !== '') {
82            $gedcom .= "\n1 TEXT " . $text;
83        }
84
85        if ($repository !== '') {
86            $gedcom .= "\n1 REPO @" . $repository . '@';
87
88            if ($call_number !== '') {
89                $gedcom .= "\n2 CALN " . $call_number;
90            }
91        }
92
93        if (in_array($privacy_restriction, ['none', 'privacy', 'confidential'], true)) {
94            $gedcom .= "\n1 RESN " . $privacy_restriction;
95        }
96
97        if ($edit_restriction === 'locked') {
98            $gedcom .= "\n1 RESN " . $edit_restriction;
99        }
100
101        $record = $tree->createRecord($gedcom);
102
103        // id and text are for select2 / autocomplete
104        // html is for interactive modals
105        return response([
106            'id'   => $record->xref(),
107            'text' => view('selects/source', [
108                'source' => $record,
109            ]),
110            'html' => view('modals/record-created', [
111                'title' => I18N::translate('The source has been created'),
112                'name'  => $record->fullName(),
113                'url'   => $record->url(),
114            ]),
115        ]);
116    }
117}
118