germania-kg / favicons
Get your Favicons in line with Twig and Slim
Installs: 81
Dependents: 0
Suggesters: 0
Security: 0
Stars: 1
Watchers: 3
Forks: 1
Open Issues: 0
Language:Smarty
pkg:composer/germania-kg/favicons
Requires (Dev)
- php-coveralls/php-coveralls: ^2.0
- phpunit/phpunit: ^5.7|^6.0|^7.0
README
Get your favicons in line with Twig and Slim3 Framework
Installation with Composer
$ composer require germania-kg/favicons
Setup Twig Template Loader
Add the favicons template path vendor/germania-kg/favicons/templates (usually within Composer's package directory) to your Twig template loader:
<?php // 1. Setup Twig Filesystem Loader, add Favicons' template dir as well $loader = new Twig_Loader_Filesystem( [ 'path/to/your/templates', 'vendor/germania-kg/favicons/templates' ]); // 2. Setup Twig, pass loader $twig = new Twig_Environment($loader, array( // other Twig settings ));
Just in case the template directory is located elsewhere, you can use a mock instance of the Favicons class and use its getTemplatesPath method:
<?php $favicons = new Germania\Favicons\Favicons; echo $favicons->getTemplatesPath(); // Usually outputs something like // "vendor/germania-kg/favicons/templates"
Your website template
Inside your website template that renders your HTML head, include the Favicons Markup template. Twig will it look up in the template path defined in “Setup Twig Template Loader” section above:
{% include 'favicons.website.tpl' with { 
   'app_url':     '/app', 
   'base_url':    '/path/to/static', 
   'theme_color': '#ffffff',
   'icon_color':  '#e21e79',
   'cache_bust':  '134p38rfwef'
} only %}
The cache_bust variable is optional. However, this will output a bunch of link and meta elements similar to this:
<link rel="apple-touch-icon" sizes="180x180" href="/path/to/static/apple-touch-icon.png?v=134p38rfwef"> <link rel="icon" type="image/png" href="/path/to/static/favicon-32x32.png?v=134p38rfwef" sizes="32x32"> <link rel="icon" type="image/png" href="/path/to/static/favicon-16x16.png?v=134p38rfwef" sizes="16x16"> <link rel="manifest" href="/app/manifest.json?v=134p38rfwef"> <link rel="mask-icon" href="/path/to/static/safari-pinned-tab.svg?v=134p38rfwef" color="#e21e79"> <link rel="shortcut icon" href="/path/to/static/favicon.ico?v=134p38rfwef"> <meta name="msapplication-TileColor" content="#ffffff"> <meta name="msapplication-TileImage" content="/path/to/static/mstile-144x144.png?v=134p38rfwef"> <meta name="msapplication-config" content="/app/browserconfig.xml?v=134p38rfwef"> <meta name="theme-color" content="#ffffff">
Please note the two referenced files manifest.json and browserconfig.xml. Use an appropriate router like Slim framework to render these files according to your URL and theme color values, like shown in the “Routing” section below:
Routing browserconfig and manifest files
Simple Slim 3 example:
<?php use Germania\Favicons\SlimRouter; use Slim\App; use Twig_Environment; // Have your Slim v3 app and Twig ready $app = new App; $twig = new Twig_Environment( ... ); // Setup favicon data $favicon_data = [ 'app_name' => 'My App', 'app_url' => '/app', 'base_url' => '/path/to/icons', 'theme_color' => '#ffffff', 'icon_color' => '#e21e79' 'display' => 'minimal-ui', // This is optional 'cache_bust' => '134p38rfwef' ]; // Setup routes new SlimRouter( $app, $twig, $favicon_data);
Advanced example: Instead of using the FaviconRouter instance above, you may want to define the routes yourself. This may be useful when you want to use your own templates:
<?php // Have your Slim app, Twig and favicon data ready $favicon_data = [ ... ]; $app->get('/browserconfig.xml', function (Request $request, Response $response) use ($twig, $favicon_data) { $output = $twig->render('favicons.browserconfig.xml.tpl', $favicon_data); $newResponse = $response->withHeader('Content-type', 'application/xml'); $newResponse->getBody()->write($output); return $newResponse; }); $app->get('/manifest.json', function (Request $request, Response $response) use ($twig, $favicon_data) { $output = $twig->render('favicons.manifest.json.tpl', $favicon_data); $newResponse = $response->withHeader('Content-type', 'application/manifest+json'); $newResponse->getBody()->write($output); return $newResponse; });
Force Safari to update the Pinned Tab icons
It seems that Safari will ignore any new color after a pinned tab icon has been stored locally.
<link rel="mask-icon" href="/path/to/static/safari-pinned-tab.svg" color="#e21e79">
On OS X, force safari by emptying the Icon Folder in "~/Library/Safari/Template Icons". See Jonathan Hollin's article Managing Safari 9’s Pinned-tab Icon Cache. It basically goes like this:
rm ~/Library/Safari/Template\ Icons/*
Development
$ git clone https://github.com/GermaniaKG/Favicons.git
$ cd Favicons
$ composer install
Unit tests
Either copy phpunit.xml.dist to phpunit.xml and adapt to your needs, or leave as is. Run PhpUnit test or composer scripts like this:
$ composer test # or $ vendor/bin/phpunit
###Todo: Make SlimRouterTest perfect There is a SlimRouterTest class, but it does not more than creating a SlimRouter instance, using concrete Slim and Twig_Environment constructor parameters. For I do not know how to check if the Slim routing actually works, this test will be content if SlimRouter instantiation does not throw any error.