CreateNoteAction::handle()   A
last analyzed

Complexity

Conditions 2
Paths 2

Size

Total Lines 26
Code Lines 16

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
cc 2
eloc 16
nc 2
nop 1
dl 0
loc 26
rs 9.7333
c 0
b 0
f 0
1
<?php
2
3
/**
4
 * webtrees: online genealogy
5
 * Copyright (C) 2025 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 <https://www.gnu.org/licenses/>.
16
 */
17
18
declare(strict_types=1);
19
20
namespace Fisharebest\Webtrees\Http\RequestHandlers;
21
22
use Fisharebest\Webtrees\I18N;
0 ignored issues
show
Bug introduced by
The type Fisharebest\Webtrees\I18N was not found. Maybe you did not declare it correctly or list all dependencies?

The issue could also be caused by a filter entry in the build configuration. If the path has been excluded in your configuration, e.g. excluded_paths: ["lib/*"], you can move it to the dependency path list as follows:

filter:
    dependency_paths: ["lib/*"]

For further information see https://scrutinizer-ci.com/docs/tools/php/php-scrutinizer/#list-dependency-paths

Loading history...
23
use Fisharebest\Webtrees\Registry;
24
use Fisharebest\Webtrees\Validator;
25
use Psr\Http\Message\ResponseInterface;
26
use Psr\Http\Message\ServerRequestInterface;
27
use Psr\Http\Server\RequestHandlerInterface;
28
29
/**
30
 * Process a form to create a new note object.
31
 */
32
class CreateNoteAction implements RequestHandlerInterface
33
{
34
    /**
35
     * @param ServerRequestInterface $request
36
     *
37
     * @return ResponseInterface
38
     */
39
    public function handle(ServerRequestInterface $request): ResponseInterface
40
    {
41
        $tree        = Validator::attributes($request)->tree();
42
        $note        = Validator::parsedBody($request)->isNotEmpty()->string('note');
43
        $restriction = Validator::parsedBody($request)->string('restriction');
44
45
        $note        = Registry::elementFactory()->make('NOTE:CONT')->canonical($note);
46
        $restriction = Registry::elementFactory()->make('NOTE:RESN')->canonical($restriction);
47
48
        $gedcom = '0 @@ NOTE ' . strtr($note, ["\n" => "\n1 CONT "]);
49
50
        if ($restriction !== '') {
51
            $gedcom .= "\n1 RESN " . strtr($restriction, ["\n" => "\n2 CONT "]);
52
        }
53
54
        $record = $tree->createRecord($gedcom);
55
56
        // value and text are for autocomplete
57
        // html is for interactive modals
58
        return response([
59
            'value' => '@' . $record->xref() . '@',
60
            'text'  => view('selects/note', ['note' => $record]),
61
            'html'  => view('modals/record-created', [
62
                'title' => I18N::translate('The note has been created'),
63
                'name'  => $record->fullName(),
64
                'url'   => $record->url(),
65
            ]),
66
        ]);
67
    }
68
}
69