xref: /webtrees/app/Module/GoogleMaps.php (revision d11be7027e34e3121be11cc025421873364403f9)
1c9c6f2ecSGreg Roach<?php
2c9c6f2ecSGreg Roach
3c9c6f2ecSGreg Roach/**
4c9c6f2ecSGreg Roach * webtrees: online genealogy
5*d11be702SGreg Roach * Copyright (C) 2023 webtrees development team
6c9c6f2ecSGreg Roach * This program is free software: you can redistribute it and/or modify
7c9c6f2ecSGreg Roach * it under the terms of the GNU General Public License as published by
8c9c6f2ecSGreg Roach * the Free Software Foundation, either version 3 of the License, or
9c9c6f2ecSGreg Roach * (at your option) any later version.
10c9c6f2ecSGreg Roach * This program is distributed in the hope that it will be useful,
11c9c6f2ecSGreg Roach * but WITHOUT ANY WARRANTY; without even the implied warranty of
12c9c6f2ecSGreg Roach * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13c9c6f2ecSGreg Roach * GNU General Public License for more details.
14c9c6f2ecSGreg Roach * You should have received a copy of the GNU General Public License
15c9c6f2ecSGreg Roach * along with this program. If not, see <https://www.gnu.org/licenses/>.
16c9c6f2ecSGreg Roach */
17c9c6f2ecSGreg Roach
18c9c6f2ecSGreg Roachdeclare(strict_types=1);
19c9c6f2ecSGreg Roach
20c9c6f2ecSGreg Roachnamespace Fisharebest\Webtrees\Module;
21c9c6f2ecSGreg Roach
22a94016a5SGreg Roachuse Fisharebest\Webtrees\Auth;
23c9c6f2ecSGreg Roachuse Fisharebest\Webtrees\FlashMessages;
24a94016a5SGreg Roachuse Fisharebest\Webtrees\Http\Exceptions\HttpServerErrorException;
25c9c6f2ecSGreg Roachuse Fisharebest\Webtrees\I18N;
26748dbe15SGreg Roachuse Fisharebest\Webtrees\Validator;
27c9c6f2ecSGreg Roachuse Psr\Http\Message\ResponseInterface;
28c9c6f2ecSGreg Roachuse Psr\Http\Message\ServerRequestInterface;
29c9c6f2ecSGreg Roach
30a94016a5SGreg Roachuse function e;
31c9c6f2ecSGreg Roachuse function redirect;
32c9c6f2ecSGreg Roach
33c9c6f2ecSGreg Roach/**
34c9c6f2ecSGreg Roach * Class GoogleMaps - use maps within webtrees
35c9c6f2ecSGreg Roach */
36c9c6f2ecSGreg Roachclass GoogleMaps extends AbstractModule implements ModuleConfigInterface, ModuleMapProviderInterface
37c9c6f2ecSGreg Roach{
38c9c6f2ecSGreg Roach    use ModuleConfigTrait;
39c9c6f2ecSGreg Roach    use ModuleMapProviderTrait;
40c9c6f2ecSGreg Roach
41c9c6f2ecSGreg Roach    /**
42c9c6f2ecSGreg Roach     * Name of the map provider.
43c9c6f2ecSGreg Roach     *
44c9c6f2ecSGreg Roach     * @return string
45c9c6f2ecSGreg Roach     */
46c9c6f2ecSGreg Roach    public function description(): string
47c9c6f2ecSGreg Roach    {
48c9c6f2ecSGreg Roach        $link = '<a href="https://www.google.com/maps" dir="ltr">www.google.com/maps</a>';
49c9c6f2ecSGreg Roach
50c9c6f2ecSGreg Roach        // I18N: %s is a link/URL
51c9c6f2ecSGreg Roach        return I18N::translate('Create maps using %s.', $link);
52c9c6f2ecSGreg Roach    }
53c9c6f2ecSGreg Roach
54c9c6f2ecSGreg Roach    /**
55c9c6f2ecSGreg Roach     * Should this module be enabled when it is first installed?
56c9c6f2ecSGreg Roach     *
57c9c6f2ecSGreg Roach     * @return bool
58c9c6f2ecSGreg Roach     */
59c9c6f2ecSGreg Roach    public function isEnabledByDefault(): bool
60c9c6f2ecSGreg Roach    {
61c9c6f2ecSGreg Roach        return false;
62c9c6f2ecSGreg Roach    }
63c9c6f2ecSGreg Roach
64c9c6f2ecSGreg Roach    /**
65c9c6f2ecSGreg Roach     * @return ResponseInterface
66c9c6f2ecSGreg Roach     */
67c9c6f2ecSGreg Roach    public function getAdminAction(): ResponseInterface
68c9c6f2ecSGreg Roach    {
69c9c6f2ecSGreg Roach        $this->layout = 'layouts/administration';
70c9c6f2ecSGreg Roach
71c9c6f2ecSGreg Roach        $api_key = $this->getPreference('api_key');
72c9c6f2ecSGreg Roach
73c9c6f2ecSGreg Roach        return $this->viewResponse('modules/google-maps/config', [
74c9c6f2ecSGreg Roach            'api_key' => $api_key,
75c9c6f2ecSGreg Roach            'title'   => $this->title(),
76c9c6f2ecSGreg Roach        ]);
77c9c6f2ecSGreg Roach    }
78c9c6f2ecSGreg Roach
79c9c6f2ecSGreg Roach    /**
80c9c6f2ecSGreg Roach     * Name of the map provider.
81c9c6f2ecSGreg Roach     *
82c9c6f2ecSGreg Roach     * @return string
83c9c6f2ecSGreg Roach     */
84c9c6f2ecSGreg Roach    public function title(): string
85c9c6f2ecSGreg Roach    {
865bfe8724SGreg Roach        return I18N::translate('Google™ maps');
87c9c6f2ecSGreg Roach    }
88c9c6f2ecSGreg Roach
89c9c6f2ecSGreg Roach    /**
90c9c6f2ecSGreg Roach     * @param ServerRequestInterface $request
91c9c6f2ecSGreg Roach     *
92c9c6f2ecSGreg Roach     * @return ResponseInterface
93c9c6f2ecSGreg Roach     */
94c9c6f2ecSGreg Roach    public function postAdminAction(ServerRequestInterface $request): ResponseInterface
95c9c6f2ecSGreg Roach    {
96748dbe15SGreg Roach        $api_key = Validator::parsedBody($request)->string('api_key');
97c9c6f2ecSGreg Roach
98748dbe15SGreg Roach        $this->setPreference('api_key', $api_key);
99c9c6f2ecSGreg Roach
100c9c6f2ecSGreg Roach        FlashMessages::addMessage(I18N::translate('The preferences for the module “%s” have been updated.', $this->title()), 'success');
101c9c6f2ecSGreg Roach
102c9c6f2ecSGreg Roach        return redirect($this->getConfigLink());
103c9c6f2ecSGreg Roach    }
104c9c6f2ecSGreg Roach
105c9c6f2ecSGreg Roach    /**
106c9c6f2ecSGreg Roach     * Parameters to create a TileLayer in LeafletJs.
107c9c6f2ecSGreg Roach     *
108c9c6f2ecSGreg Roach     * @return array<object>
109c9c6f2ecSGreg Roach     */
110c9c6f2ecSGreg Roach    public function leafletJsTileLayers(): array
111c9c6f2ecSGreg Roach    {
112c9c6f2ecSGreg Roach        $api_key = $this->getPreference('api_key');
113c9c6f2ecSGreg Roach
114a94016a5SGreg Roach        if ($api_key === '') {
115a94016a5SGreg Roach            $message = I18N::translate('This service requires an API key.');
116a94016a5SGreg Roach
117a94016a5SGreg Roach            if (Auth::isAdmin()) {
118a94016a5SGreg Roach                $message = '<a href="' . e($this->getConfigLink()) . '">' . $message . '</a>';
119a94016a5SGreg Roach            }
120a94016a5SGreg Roach
121a94016a5SGreg Roach            throw new HttpServerErrorException($message);
122a94016a5SGreg Roach        }
123a94016a5SGreg Roach
124c9c6f2ecSGreg Roach        return [
125c9c6f2ecSGreg Roach            (object) [
126c9c6f2ecSGreg Roach                'GM_API_KEY'  => $api_key,
127c9c6f2ecSGreg Roach                'attribution' => 'Map data &copy2021 Google LLC <a href="https://www.google.com/intl/en-GB_US/help/terms_maps">Terms of use</a>',
128c9c6f2ecSGreg Roach                'default'     => true,
129c9c6f2ecSGreg Roach                'lyrs'        => 'm',
130c9c6f2ecSGreg Roach                'maxZoom'     => 20,
131c9c6f2ecSGreg Roach                'minZoom'     => 2,
132c9c6f2ecSGreg Roach                'subdomains'  => ['mt0', 'mt1', 'mt2', 'mt3'],
133c9c6f2ecSGreg Roach                'label'       => 'Streets',
134c9c6f2ecSGreg Roach                'url'         => 'https://{s}.google.com/vt/lyrs={lyrs}&x={x}&y={y}&z={z}',
135c9c6f2ecSGreg Roach            ],
136c9c6f2ecSGreg Roach            (object) [
137c9c6f2ecSGreg Roach                'GM_API_KEY'  => $api_key,
138c9c6f2ecSGreg Roach                'attribution' => 'Map data &copy2021 Google LLC <a href="https://www.google.com/intl/en-GB_US/help/terms_maps">Terms of use</a>',
139c9c6f2ecSGreg Roach                'default'     => false,
140c9c6f2ecSGreg Roach                'lyrs'        => 'y',
141c9c6f2ecSGreg Roach                'maxZoom'     => 20,
142c9c6f2ecSGreg Roach                'minZoom'     => 2,
143c9c6f2ecSGreg Roach                'subdomains'  => ['mt0', 'mt1', 'mt2', 'mt3'],
144c9c6f2ecSGreg Roach                'label'       => 'Hybrid',
145c9c6f2ecSGreg Roach                'url'         => 'https://{s}.google.com/vt/lyrs={lyrs}&x={x}&y={y}&z={z}',
146c9c6f2ecSGreg Roach            ],
147c9c6f2ecSGreg Roach            (object) [
148c9c6f2ecSGreg Roach                'GM_API_KEY'  => $api_key,
149c9c6f2ecSGreg Roach                'attribution' => 'Map data &copy2021 Google LLC <a href="https://www.google.com/intl/en-GB_US/help/terms_maps">Terms of use</a>',
150c9c6f2ecSGreg Roach                'default'     => false,
151c9c6f2ecSGreg Roach                'lyrs'        => 's',
152c9c6f2ecSGreg Roach                'maxZoom'     => 20,
153c9c6f2ecSGreg Roach                'minZoom'     => 2,
154c9c6f2ecSGreg Roach                'subdomains'  => ['mt0', 'mt1', 'mt2', 'mt3'],
155c9c6f2ecSGreg Roach                'label'       => 'Satellite',
156c9c6f2ecSGreg Roach                'url'         => 'https://{s}.google.com/vt/lyrs={lyrs}&x={x}&y={y}&z={z}',
157c9c6f2ecSGreg Roach            ],
158c9c6f2ecSGreg Roach            (object) [
159c9c6f2ecSGreg Roach                'GM_API_KEY'  => $api_key,
160c9c6f2ecSGreg Roach                'attribution' => 'Map data &copy2021 Google LLC <a href="https://www.google.com/intl/en-GB_US/help/terms_maps">Terms of use</a>',
161c9c6f2ecSGreg Roach                'default'     => false,
162c9c6f2ecSGreg Roach                'lyrs'        => 'p',
163c9c6f2ecSGreg Roach                'maxZoom'     => 20,
164c9c6f2ecSGreg Roach                'minZoom'     => 2,
165c9c6f2ecSGreg Roach                'subdomains'  => ['mt0', 'mt1', 'mt2', 'mt3'],
166c9c6f2ecSGreg Roach                'label'       => 'Terrain',
167c9c6f2ecSGreg Roach                'url'         => 'https://{s}.google.com/vt/lyrs={lyrs}&x={x}&y={y}&z={z}',
168c9c6f2ecSGreg Roach            ],
169c9c6f2ecSGreg Roach        ];
170c9c6f2ecSGreg Roach    }
171c9c6f2ecSGreg Roach}
172