A plugin for Kirby 2 CMS that adds photoswipe.
Copy or link the photoswipe
directory to site/plugins/
or use the Kirby CLI:
kirby plugin:install schnti/kirby-photoswipe
bower install photoswipe --save
or
npm install photoswipe --save
Add sources
<!-- Core CSS file -->
<link rel="stylesheet" href="path/to/photoswipe.css">
<!-- Skin CSS file (styling of UI - buttons, caption, etc.)
In the folder of skin CSS file there are also:
- .png and .svg icons sprite,
- preloader.gif (for browsers that do not support CSS animations) -->
<link rel="stylesheet" href="path/to/default-skin/default-skin.css">
<!-- Core JS file -->
<script src="path/to/photoswipe.min.js"></script>
<!-- UI JS file -->
<script src="path/to/photoswipe-ui-default.min.js"></script>
use this right before closing </body>
tag
<?= \ka\kirby\PhotoSwipe::init(); ?>
The init()
function will add the PhotoSwipe (.pswp) element to DOM and the pure Vanilla JS implementation to build an array of slides from a list of links.
<div class="photoswipe" itemscope itemtype="http://schema.org/ImageGallery">
<figure itemprop="associatedMedia" itemscope itemtype="http://schema.org/ImageObject">
<a href="large-image.jpg" itemprop="contentUrl" data-size="600x400">
<img src="small-image.jpg" itemprop="thumbnail" alt="Image description" />
</a>
<figcaption itemprop="caption description">Image caption</figcaption>
</figure>
<figure itemprop="associatedMedia" itemscope itemtype="http://schema.org/ImageObject">
<a href="large-image.jpg" itemprop="contentUrl" data-size="600x400">
<img src="small-image.jpg" itemprop="thumbnail" alt="Image description" />
</a>
<figcaption itemprop="caption description">Image caption</figcaption>
</figure>
</div>
or add dynamic gallery with kirby markup (and Bootstrap 3.3 Grid)
<div class="photoswipe" itemscope itemtype="http://schema.org/ImageGallery">
<div class="row">
<?php foreach ($page->images()->sortBy('sort', 'asc') as $image): ?>
<?php $pic = $image->resize(1000, null, 90); ?>
<figure class="col-xs-6 col-sm-6 col-md-4 col-lg-4" itemprop="associatedMedia" itemscope itemtype="http://schema.org/ImageObject">
<a href="<?= $pic->url(); ?>" itemprop="contentUrl" data-size="<?= $pic->width(); ?>x<?= $pic->height(); ?>"
title="<?= $image->text()->value(); ?>">
<img src="<?= $image->crop(400, 300)->url(); ?>" itemprop="thumbnail"
alt="<?= $page->title()->value() ?> <?= $image->text()->value(); ?>"
class="img-responsive"/>
</a>
<figcaption itemprop="caption description"><?= $image->text()->kirbytext() ?></figcaption>
</figure>
<?php endforeach; ?>
</div>
</div>
(photoswipe: image.jpg
width: 200
height: 200
quality: 70
crop: true
class: img-thumbnail
text: figcaption text
)
- class: Integer (img-Tag class, default: 'img-responsive')
- text: String (Figcaption Content, default: '')
Thumbnail
- width: Integer (thumbnail resize width, default: 300)
- height: Integer (thumbnail resize height, default: null)
- quality: Integer (jpeg quality from 0 to 100, default: 70)
- crop: Boolean (enable cropping the file according to the given width and height parameters, default: false)
Image
- pwidth: Integer (image resize widt, default: 1000)
- pheight: Integer (image resize height, default: null)
- pquality: Integer (jpeg quality from 0 to 100, default: 80)