-
Notifications
You must be signed in to change notification settings - Fork 6
/
lightbox-gallery.php
executable file
·114 lines (93 loc) · 4.13 KB
/
lightbox-gallery.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
<?php
/**
* Lightbox-Gallery Plugin
*
* @package Kirby CMS
* @author Dennis Kerzig <hi@wottpal.com>
*/
// Helpers
include_once __DIR__ . DS . 'helpers.php';
// Dynamic Tagname
$tagname = c::get('lightboxgallery.kirbytext.tagname', 'gallery');
$kirby->set('tag', $tagname, [
'attr' => [ 'limit', 'stretch', 'cols', 'mobilecols', 'id', 'class', 'page', 'order' ],
'html' => function($tag) use ($tagname) {
// Options
$class = $tag->attr('class', c::get('lightboxgallery.class', ''));
$id = $tag->attr('id', c::get('lightboxgallery.id', ''));
$combine = c::get('lightboxgallery.combine', false);
$limit = $tag->attr('limit', c::get('lightboxgallery.limit', false));
// Determine Stretch-Properties
$stretch = strtolower($tag->attr('stretch', c::get('lightboxgallery.stretch', 'first')));
$stretch_last = $stretch === 'last';
$stretch = $stretch === 'last' || $stretch === 'first';
// Columns-Definition (get it from config or as tag-attribute)
$cols = c::get('lightboxgallery.cols', ['min' => 3, 'max' => 4]);
$cols_attr = columnsFromString($tag->attr('cols', false));
if ($cols_attr) $cols = $cols_attr;
$mobilecols = c::get('lightboxgallery.mobilecols', ['min' => 2, 'max' => 2]);
$mobilecols_attr = columnsFromString($tag->attr('mobilecols', false));
if ($mobilecols_attr) $mobilecols = $mobilecols_attr;
// Allow other pages as file-source (esp. for the `kirbytag` function)
$source = $tag->page();
$custom_page = $tag->attr('page', false);
if ($custom_page) $custom_page = page($custom_page);
if ($custom_page) $source = $custom_page;
// Title and caption field name options
$field_title = strtolower(c::get('lightboxgallery.field.title', 'title'));
$field_caption = strtolower(c::get('lightboxgallery.field.caption', 'caption'));
// Dominant color option
$dominant_color = c::get('lightboxgallery.field.dominantcolor', false);
$dominant_color_name = c::get('lightboxgallery.field.dominantcolor.name', 'color');
// Thumb-Options
$thumb_provider = strtolower(c::get('lightboxgallery.thumb.provider', 'thumb'));
$thumb_options = c::get('lightboxgallery.thumb.options', [
"width" => 800,
"height" => 800,
"crop" => true
]);
// Ensure necessary ’thumb.options' are given
$thumb_options_given = c::get('lightboxgallery.thumb.options', false) != false;
if ($thumb_provider && $thumb_provider != 'thumb' && !$thumb_options_given) {
throw new Exception("If something else than 'thumb' is set as 'thumb.provider', 'thumb.options' has to be specified, too.");
}
// Gather Images
$images_string = $tag->attr($tagname);
$use_all = strtolower(trim($images_string)) === 'all';
$images_string = str::split($images_string, ' ');
$images = $use_all ? $source->images()->keys() : $images_string;
$image_files = [];
foreach ($images as $image) {
$image_file = $source->file(trim($image));
if ($image_file) array_push($image_files, $image_file);
}
// Order Images
$order = strtolower($tag->attr('order', 'default'));
if ($order === 'reverse') $image_files = array_reverse($image_files);
if ($order === 'random' || $order === 'shuffle') shuffle($image_files);
// Determine Count of displayed Thumbnails
$use_limit = $limit && $limit < count($image_files);
$preview_count = $use_limit ? $limit : count($image_files);
if (!empty($image_files)) {
// Create Gallery-HTML from Template
$gallery = tpl::load(__DIR__ . DS . 'template.php', [
'images' => $image_files,
'id' => $id,
'class' => $class,
'combine' => $combine,
'field_caption' => $field_caption,
'field_title' => $field_title,
'thumb_provider' => $thumb_provider,
'thumb_options' => $thumb_options,
'preview_count' => $preview_count,
'field_color' => $dominant_color_name,
'use_color' => $dominant_color,
'cols' => $cols,
'mobilecols' => $mobilecols,
'stretch' => $stretch,
'stretch_last' => $stretch_last
], true);
return html($gallery);
}
}
]);