A simple drop-in implementation of responsive images for Kirby CMS. Automatically generates thumbnails for low-resolution devices.
Note: This repository is no longer maintained. As of 3.1.0 Kirby supports native Srcset generation.
Download the latest release and unpack to your kirby /site/plugins
directory.
You can also rename the responsive-images.php
file to image.php
and move it to the site/tags
directory if you prefer to keep all your custom tags there.
There nothing you need to change in order to have responsive image support. Just include images as you would do normally:
(image:workflow@3x.jpg link:workflow@3x.jpg width:1244)
Make sure your /thumbs
directory is present and writable and ImageMagick is available.
Although the plugin works without configuration, these options are available and can be added to your /site/config/config.php
:
It is also possible to link the image to one of the generated sizes using the keyword set via the responsiveimages.sources
config. The following example will link to the smallest possible image size:
(image:workflow@3x.jpg link:small width:1244)
To control the sizes attribute you can use media queries.
<?php
c::set('responsiveimages.sizes', array(
array(
'size_value' => '10em',
'mq_value' => '60em',
'mq_name' => 'min-width'
),
array(
'size_value' => '$img_width',
'mq_value' => '30em',
'mq_name' => 'min-width'
),
'alignleft' => array(
'size_value' => 'calc(50vw - 30px)'
),
));
$img_width
is a placeholder that will be replaced by the images actual pixel width.- The array key will be matched against the
classes
attribute of the image. In the example above'size_value' => 'calc(50vw - 30px)'
will only be added if the image has thealignleft
attribute.
By default, the plugin will generate thumbnails that are 480, 768 and 1200 pixels wide. You can overwrite these settings like these:
<?php
c::set('responsiveimages.sources', array(
'small' => array('width' => 444),
'medium' => array('width' => 666),
'large' => array('width' => 999, 'grayscale' => true) // good for debugging
));
- The key names may be used to link the image or for default (see Usage and Fallbacks section).
- Each array item takes the same arguments as Kirbys thumb() function (
quality
,blur
,upscale
etc..).
Browsers that support responive images will ignore the src
attribute of the image and pick what ever is best for their device from the srcsset
attribute.
However, you might want to control what older browsers that don't support responsive images load. For that use case there is an option to set the default size based on the key name of the size (explained in the previous section).
<?php
c::set('responsiveimages.defaultsource', 'small');
This will show older browsers the "small" image size. If this option is not set, browsers will load the original image.
Please open an issue for support.
Please contribute using Github Flow. Create a branch, add commits, and open a pull request. See also the original issue.
The code is available under the MIT license.