]> git.mxchange.org Git - friendica.git/blobdiff - src/Module/Manifest.php
Merge pull request #13110 from anubis2814/develop
[friendica.git] / src / Module / Manifest.php
index 2ae8009e251617092a9ba07420606db4901039a8..e98c83a6136b79147d2e772479ee7ae5382fdfd1 100644 (file)
@@ -1,6 +1,6 @@
 <?php
 /**
- * @copyright Copyright (C) 2010-2022, the Friendica project
+ * @copyright Copyright (C) 2010-2023, the Friendica project
  *
  * @license GNU AGPL version 3 or any later version
  *
@@ -31,31 +31,17 @@ class Manifest extends BaseModule
        {
                $config = DI::config();
 
-               $touch_icon = $config->get('system', 'touch_icon') ?: 'images/friendica-192.png';
-
                $theme = DI::config()->get('system', 'theme');
 
                $manifest = [
                        'name'          => $config->get('config', 'sitename', 'Friendica'),
-                       'start_url'     => DI::baseUrl()->get(),
+                       'start_url'     => DI::baseUrl(),
                        'display'       => 'standalone',
                        'description'   => $config->get('config', 'info', DI::l10n()->t('A Decentralized Social Network')),
                        'short_name'    => 'Friendica',
                        '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() . '/' . $touch_icon,
+                                       'sizes' => '192x192',
+                                       'type'  => 'image/png',
+                               ],
+                               [
+                                       'src'   => DI::baseUrl() . '/' . $touch_icon,
+                                       'sizes' => '512x512',
+                                       'type'  => 'image/png',
+                               ],
+                       ];
+               } else {
+                       $manifest['icons'] = [
+                               [
+                                       'src'   => DI::baseUrl() . '/images/friendica.svg',
+                                       'sizes' => 'any',
+                                       'type'  => 'image/svg+xml',
+                                       'purpose' => 'any',
+                               ],
+                               [
+                                       'src'   => DI::baseUrl() . '/images/friendica-192.png',
+                                       'sizes' => '192x192',
+                                       'type'  => 'image/png',
+                                       'purpose' => 'any',
+                               ],
+                               [
+                                       'src'   => DI::baseUrl() . '/images/friendica-512.png',
+                                       'sizes' => '512x512',
+                                       'type'  => 'image/png',
+                                       'purpose' => 'any',
+                               ],
+                               [
+                                       'src'   => DI::baseUrl() . '/images/friendica-maskable.svg',
+                                       'sizes' => 'any',
+                                       'type'  => 'image/svg+xml',
+                                       'purpose' => 'maskable',
+                               ],
+                               [
+                                       'src'   => DI::baseUrl() . '/images/friendica-maskable-192.png',
+                                       'sizes' => '192x192',
+                                       'type'  => 'image/png',
+                                       'purpose' => 'maskable',
+                               ],
+                               [
+                                       'src'   => DI::baseUrl() . '/images/friendica-maskable-512.png',
+                                       'sizes' => '512x512',
+                                       'type'  => 'image/png',
+                                       'purpose' => 'maskable',
+                               ],
+                       ];
+               }
+
                if ($background_color = Core\Theme::getBackgroundColor($theme)) {
                        $manifest['background_color'] = $background_color;
                }