Move manifest JSON from template to array

pull/8315/head
Hypolite Petovan 2020-02-19 13:29:55 -05:00
parent 930d395d7b
commit 33c7b62326
2 changed files with 22 additions and 30 deletions

View File

@ -31,23 +31,33 @@ class Manifest extends BaseModule
{
$config = DI::config();
header('Content-type: application/manifest+json');
$touch_icon = $config->get('system', 'touch_icon') ?: 'images/friendica-128.png';
$theme = DI::config()->get('system', 'theme');
$tpl = Core\Renderer::getMarkupTemplate('manifest.tpl');
$output = Core\Renderer::replaceMacros($tpl, [
'$touch_icon' => $touch_icon,
'$title' => $config->get('config', 'sitename', 'Friendica'),
'$description' => $config->get('config', 'info', DI::l10n()->t('A Decentralized Social Network')),
'$background_color' => Core\Theme::getBackgroundColor($theme),
'$theme_color' => Core\Theme::getThemeColor($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',
],
],
];
echo $output;
if ($background_color = Core\Theme::getBackgroundColor($theme)) {
$manifest['background_color'] = $background_color;
}
exit();
if ($theme_color = Core\Theme::getThemeColor($theme)) {
$manifest['theme_color'] = $theme_color;
}
Core\System::jsonExit($manifest, 'application/manifest+json');
}
}

View File

@ -1,18 +0,0 @@
{
"name": "{{$title}}",
"start_url": "{{$baseurl}}",
"display": "standalone",
"description": "{{$description}}",
{{if $background_color}}
"theme_color": "{{$theme_color}}",
{{/if}}
{{if $background_color}}
"background_color": "{{$background_color}}",
{{/if}}
"short_name": "Friendica",
"icons": [{
"src": "{{$baseurl}}/{{$touch_icon}}",
"sizes": "128x128",
"type": "image/png"
}]
}