X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=src%2FModule%2FManifest.php;h=4148b0ddf41ec11381a1c9eb739ce99b8aa14bf0;hb=dfcfae6bcca54a27b1bf5099d96d54f2bba997d3;hp=0f9112d11f0efd799be7cc48c3e625236f0ae073;hpb=38a5358bfa646ae13a4a1a385741890fa88d9b7f;p=friendica.git diff --git a/src/Module/Manifest.php b/src/Module/Manifest.php index 0f9112d11f..4148b0ddf4 100644 --- a/src/Module/Manifest.php +++ b/src/Module/Manifest.php @@ -1,6 +1,6 @@ get('system', 'touch_icon') ?: 'images/friendica-192.png'; - $theme = DI::config()->get('system', 'theme'); $manifest = [ @@ -44,18 +42,6 @@ class Manifest extends BaseModule 'lang' => $config->get('system', 'language'), 'dir' => 'auto', 'categories' => ['social network', 'internet'], - 'icons' => [ - [ - 'src' => DI::baseUrl()->get() . '/' . $touch_icon, - 'sizes' => '192x192', - 'type' => 'image/png', - ], - [ - 'src' => DI::baseUrl()->get() . '/' . $touch_icon, - 'sizes' => '512x512', - 'type' => 'image/png', - ], - ], 'shortcuts' => [ [ 'name' => 'Latest posts', @@ -74,12 +60,71 @@ class Manifest extends BaseModule 'url' => '/contact' ], [ - 'name' => 'Events', - 'url' => '/events' + 'name' => 'Calendar', + 'url' => '/calendar' ] ] ]; + /// @TODO If the admin provides their own touch icon, the manifest will regress + /// to a smaller set of icons that do not follow the web app manifest spec. + /// There should be a mechanism to allow the admin to provide all of the 6 + /// different images that are required for a fully valid web app manifest. + $touch_icon = $config->get('system', 'touch_icon'); + if($touch_icon){ + $manifest['icons'] = [ + [ + 'src' => DI::baseUrl()->get() . '/' . $touch_icon, + 'sizes' => '192x192', + 'type' => 'image/png', + ], + [ + 'src' => DI::baseUrl()->get() . '/' . $touch_icon, + 'sizes' => '512x512', + 'type' => 'image/png', + ], + ]; + } else { + $manifest['icons'] = [ + [ + 'src' => DI::baseUrl()->get() . '/images/friendica.svg', + 'sizes' => 'any', + 'type' => 'image/svg+xml', + 'purpose' => 'any', + ], + [ + 'src' => DI::baseUrl()->get() . '/images/friendica-192.png', + 'sizes' => '192x192', + 'type' => 'image/png', + 'purpose' => 'any', + ], + [ + 'src' => DI::baseUrl()->get() . '/images/friendica-512.png', + 'sizes' => '512x512', + 'type' => 'image/png', + 'purpose' => 'any', + ], + [ + 'src' => DI::baseUrl()->get() . '/images/friendica-maskable.svg', + 'sizes' => 'any', + 'type' => 'image/svg+xml', + 'purpose' => 'maskable', + ], + [ + 'src' => DI::baseUrl()->get() . '/images/friendica-maskable-192.png', + 'sizes' => '192x192', + 'type' => 'image/png', + 'purpose' => 'maskable', + ], + [ + 'src' => DI::baseUrl()->get() . '/images/friendica-maskable-512.png', + 'sizes' => '512x512', + 'type' => 'image/png', + 'purpose' => 'maskable', + ], + ]; + } + if ($background_color = Core\Theme::getBackgroundColor($theme)) { $manifest['background_color'] = $background_color; }