Issues (2502)

app/Module/ModuleMapLinkTrait.php (2 issues)

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\Module;
21
22
use Fisharebest\Webtrees\Fact;
23
use Fisharebest\Webtrees\I18N;
0 ignored issues
show
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...
24
25
use function e;
26
27
/**
28
 * Trait ModuleMapLinkTrait - default implementation of ModuleMapLinkInterface
29
 */
30
trait ModuleMapLinkTrait
31
{
32
    public function title(): string
33
    {
34
        return $this->providerName() . ' — ' . I18N::translate('Map link');
35
    }
36
37
    public function description(): string
38
    {
39
        return I18N::translate('Show the location of an event on an external map.');
40
    }
41
42
    /**
43
     * @param Fact $fact
44
     *
45
     * @return string
46
     */
47
    public function mapLink(Fact $fact): string
48
    {
49
        if ($this->isMapAvailableForLocation($fact)) {
50
            $icon  = $this->icon();
51
            $url   = $this->mapUrl($fact);
52
            $title = I18N::translate('View this location using %s', $this->providerName());
53
54
            return '<a href="' . e($url) . '" rel="nofollow" target="_top" title="' . $title . '">' . $icon . '</a>';
55
        }
56
57
        return '';
58
    }
59
60
    /**
61
     * Name of the map provider.
62
     *
63
     * @return string
64
     */
65
    protected function providerName(): string
66
    {
67
        return 'example.com';
68
    }
69
70
    /**
71
     * @param Fact $fact
72
     *
73
     * @return bool
74
     */
75
    protected function isMapAvailableForLocation(Fact $fact): bool
76
    {
77
        return $fact->latitude() !== null && $fact->longitude() !== null;
78
    }
79
80
    /**
81
     * @return string
82
     */
83
    protected function icon(): string
84
    {
85
        return 'icon';
86
    }
87
88
    /**
89
     * @param Fact $fact
90
     *
91
     * @return string
92
     */
93
    protected function mapUrl(Fact $fact): string
0 ignored issues
show
The parameter $fact is not used and could be removed. ( Ignorable by Annotation )

If this is a false-positive, you can also ignore this issue in your code via the ignore-unused  annotation

93
    protected function mapUrl(/** @scrutinizer ignore-unused */ Fact $fact): string

This check looks for parameters that have been defined for a function or method, but which are not used in the method body.

Loading history...
94
    {
95
        return 'https://example.com';
96
    }
97
}
98