xref: /webtrees/app/Module/GoogleMaps.php (revision 5bfc689774bb9a6401271c4ed15a6d50652c991b)
1<?php
2
3/**
4 * webtrees: online genealogy
5 * Copyright (C) 2022 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
18declare(strict_types=1);
19
20namespace Fisharebest\Webtrees\Module;
21
22use Fisharebest\Webtrees\FlashMessages;
23use Fisharebest\Webtrees\I18N;
24use Psr\Http\Message\ResponseInterface;
25use Psr\Http\Message\ServerRequestInterface;
26
27use function redirect;
28
29/**
30 * Class GoogleMaps - use maps within webtrees
31 */
32class GoogleMaps extends AbstractModule implements ModuleConfigInterface, ModuleMapProviderInterface
33{
34    use ModuleConfigTrait;
35    use ModuleMapProviderTrait;
36
37    /**
38     * Name of the map provider.
39     *
40     * @return string
41     */
42    public function description(): string
43    {
44        $link = '<a href="https://www.google.com/maps" dir="ltr">www.google.com/maps</a>';
45
46        // I18N: %s is a link/URL
47        return I18N::translate('Create maps using %s.', $link);
48    }
49
50    /**
51     * Should this module be enabled when it is first installed?
52     *
53     * @return bool
54     */
55    public function isEnabledByDefault(): bool
56    {
57        return false;
58    }
59
60    /**
61     * @return ResponseInterface
62     */
63    public function getAdminAction(): ResponseInterface
64    {
65        $this->layout = 'layouts/administration';
66
67        $api_key = $this->getPreference('api_key');
68
69        return $this->viewResponse('modules/google-maps/config', [
70            'api_key' => $api_key,
71            'title'   => $this->title(),
72        ]);
73    }
74
75    /**
76     * Name of the map provider.
77     *
78     * @return string
79     */
80    public function title(): string
81    {
82        return I18N::translate('Google™ maps');
83    }
84
85    /**
86     * @param ServerRequestInterface $request
87     *
88     * @return ResponseInterface
89     */
90    public function postAdminAction(ServerRequestInterface $request): ResponseInterface
91    {
92        $params = (array) $request->getParsedBody();
93
94        $this->setPreference('api_key', $params['api_key'] ?? '');
95
96        FlashMessages::addMessage(I18N::translate('The preferences for the module “%s” have been updated.', $this->title()), 'success');
97
98        return redirect($this->getConfigLink());
99    }
100
101    /**
102     * Parameters to create a TileLayer in LeafletJs.
103     *
104     * @return array<object>
105     */
106    public function leafletJsTileLayers(): array
107    {
108        $api_key = $this->getPreference('api_key');
109
110        return [
111            (object) [
112                'GM_API_KEY'  => $api_key,
113                'attribution' => 'Map data &copy2021 Google LLC <a href="https://www.google.com/intl/en-GB_US/help/terms_maps">Terms of use</a>',
114                'default'     => true,
115                'lyrs'        => 'm',
116                'maxZoom'     => 20,
117                'minZoom'     => 2,
118                'subdomains'  => ['mt0', 'mt1', 'mt2', 'mt3'],
119                'label'       => 'Streets',
120                'url'         => 'https://{s}.google.com/vt/lyrs={lyrs}&x={x}&y={y}&z={z}',
121            ],
122            (object) [
123                'GM_API_KEY'  => $api_key,
124                'attribution' => 'Map data &copy2021 Google LLC <a href="https://www.google.com/intl/en-GB_US/help/terms_maps">Terms of use</a>',
125                'default'     => false,
126                'lyrs'        => 'y',
127                'maxZoom'     => 20,
128                'minZoom'     => 2,
129                'subdomains'  => ['mt0', 'mt1', 'mt2', 'mt3'],
130                'label'       => 'Hybrid',
131                'url'         => 'https://{s}.google.com/vt/lyrs={lyrs}&x={x}&y={y}&z={z}',
132            ],
133            (object) [
134                'GM_API_KEY'  => $api_key,
135                'attribution' => 'Map data &copy2021 Google LLC <a href="https://www.google.com/intl/en-GB_US/help/terms_maps">Terms of use</a>',
136                'default'     => false,
137                'lyrs'        => 's',
138                'maxZoom'     => 20,
139                'minZoom'     => 2,
140                'subdomains'  => ['mt0', 'mt1', 'mt2', 'mt3'],
141                'label'       => 'Satellite',
142                'url'         => 'https://{s}.google.com/vt/lyrs={lyrs}&x={x}&y={y}&z={z}',
143            ],
144            (object) [
145                'GM_API_KEY'  => $api_key,
146                'attribution' => 'Map data &copy2021 Google LLC <a href="https://www.google.com/intl/en-GB_US/help/terms_maps">Terms of use</a>',
147                'default'     => false,
148                'lyrs'        => 'p',
149                'maxZoom'     => 20,
150                'minZoom'     => 2,
151                'subdomains'  => ['mt0', 'mt1', 'mt2', 'mt3'],
152                'label'       => 'Terrain',
153                'url'         => 'https://{s}.google.com/vt/lyrs={lyrs}&x={x}&y={y}&z={z}',
154            ],
155        ];
156    }
157}
158