X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=src%2FModule%2FManifest.php;h=ed14bbbb707ce68d51dd0b10ada4db8b633beeee;hb=5ae03319936f70d12eaf4a09dfcda020de429380;hp=bfe758fa9782a5a22cae9cede356603d6a072306;hpb=aa0b485f3dca72c5448076e913fa54d948cd7731;p=friendica.git diff --git a/src/Module/Manifest.php b/src/Module/Manifest.php index bfe758fa97..ed14bbbb70 100644 --- a/src/Module/Manifest.php +++ b/src/Module/Manifest.php @@ -1,6 +1,6 @@ get('system', 'touch_icon') ?: 'images/friendica-128.png'; - $theme = DI::config()->get('system', 'theme'); $manifest = [ - 'name' => $config->get('config', 'sitename', 'Friendica'), - 'start_url' => DI::baseUrl()->get(), - 'display' => 'standalone', - 'description' => $config->get('config', 'info', DI::l10n()->t('A Decentralized Social Network')), - 'short_name' => 'Friendica', - 'icons' => [ - [ - 'src' => DI::baseUrl()->get() . '/' . $touch_icon, - 'sizes' => '128x128', - 'type' => 'image/png', + 'name' => $config->get('config', 'sitename', 'Friendica'), + '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'], + 'shortcuts' => [ + [ + 'name' => 'Latest posts', + 'url' => '/network' + ], + [ + 'name' => 'Messages', + 'url' => '/message' + ], + [ + 'name' => 'Notifications', + 'url' => '/notifications/system' + ], + [ + 'name' => 'Contacts', + 'url' => '/contact' ], - ], + [ + '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; } @@ -58,6 +133,6 @@ class Manifest extends BaseModule $manifest['theme_color'] = $theme_color; } - Core\System::jsonExit($manifest, 'application/manifest+json'); + $this->jsonExit($manifest, 'application/manifest+json'); } }