memories/lib/Controller/MapController.php

82 lines
2.7 KiB
PHP
Raw Normal View History

<?php
declare(strict_types=1);
/**
* @copyright Copyright (c) 2022 Varun Patil <radialapps@gmail.com>
* @author Varun Patil <radialapps@gmail.com>
* @license AGPL-3.0-or-later
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
namespace OCA\Memories\Controller;
use OCA\Memories\Errors;
use OCP\AppFramework\Http\JSONResponse;
2023-02-08 22:13:13 +00:00
class MapController extends ApiBase
{
/**
* @NoAdminRequired
*/
public function clusters(): JSONResponse
{
// Get the folder to show
$root = null;
2023-02-08 21:53:38 +00:00
try {
$root = $this->getRequestRoot();
} catch (\Exception $e) {
return Errors::NoRequestRoot();
}
2023-02-08 21:53:38 +00:00
// Make sure we have bounds and zoom level
2023-02-08 18:52:53 +00:00
// Zoom level is used to determine the grid length
2023-02-08 21:53:38 +00:00
$bounds = $this->request->getParam('bounds');
$zoomLevel = $this->request->getParam('zoom');
2023-02-08 21:53:38 +00:00
if (!$bounds || !$zoomLevel || !is_numeric($zoomLevel)) {
return Errors::MissingParameter('bounds or zoom');
}
// A tweakable parameter to determine the number of boxes in the map
2023-02-10 19:42:16 +00:00
// Note: these parameters need to be changed in MapSplitMatter.vue as well
2023-02-09 07:55:54 +00:00
$clusterDensity = 1;
2023-02-08 21:53:38 +00:00
$gridLen = 180.0 / (2 ** $zoomLevel * $clusterDensity);
try {
2023-02-08 21:53:38 +00:00
$clusters = $this->timelineQuery->getMapClusters($gridLen, $bounds, $root);
2023-02-09 08:35:35 +00:00
2023-02-10 01:27:03 +00:00
// Get previews for each cluster
$clusterIds = array_map(function ($cluster) {
return (int) $cluster['id'];
}, $clusters);
$previews = $this->timelineQuery->getMapClusterPreviews($clusterIds, $root);
// Merge the responses
$fileMap = [];
foreach ($previews as &$preview) {
$fileMap[$preview['mapcluster']] = $preview;
}
foreach ($clusters as &$cluster) {
$cluster['preview'] = $fileMap[$cluster['id']] ?? null;
}
return new JSONResponse($clusters);
} catch (\Exception $e) {
return Errors::Generic($e);
}
}
}