Files
2024-07-16 13:57:46 +00:00

82 lines
3.4 KiB
PHP

<?php
/* Prohibit direct script loading */
defined('ABSPATH') || die('No direct script access allowed!');
wp_enqueue_script('jquery-masonry');
wp_enqueue_script('wpmf-gallery');
// getting rid of float
$class[] = 'gallery_life gallery-' . $display;
$class[] = 'gallery-columns-' . $columns;
$class[] = 'gallery-size-' . $size_class;
$class[] = 'wpmf-gallery-bottomspace-' . $bottomspace;
$class[] = 'wpmf-gallery-clear';
$class[] = 'wpmf-has-border-radius-' . $img_border_radius;
$class[] = 'wpmf-gutterwidth-' . $gutterwidth;
$class = implode(' ', $class);
$padding_masonry = get_option('wpmf_padding_masonry');
if (!isset($padding_masonry) && $padding_masonry === '') {
$padding_masonry = 5;
}
$gutterwidth = isset($gutterwidth) ? $gutterwidth : $padding_masonry;
$style = '';
if ($img_shadow !== '') {
$style .= '#' . $selector . ' .wpmf-gallery-item img:hover {box-shadow: ' . $img_shadow . ' !important; transition: all 200ms ease;}';
}
if ($border_style !== 'none') {
$style .= '#' . $selector . ' .wpmf-gallery-item img {border: ' . $border_color . ' '. $border_width .'px '. $border_style .'}';
}
$galleryStyle = '';
if ($align === 'alignleft' || $align === 'alignright' || $align === 'aligncenter') {
$galleryStyle = 'style="width: 100%; max-width: 620px!important;"';
} elseif ($align === 'none') {
$align = '';
}
wp_add_inline_style('wpmf-gallery-style', $style);
$output = '';
if (!empty($is_divi)) {
$output .= '<style>' . $style . '</style>';
}
$output .= '<div class="wpmf-gallerys wpmf-gallerys-life '. $align .'" '.$galleryStyle.'>';
$output .= '<div id="' . $selector . '"
data-gutter-width="' . $gutterwidth . '"
data-wpmfcolumns="' . $columns . '" class="' . $class . '">';
$pos = 0;
foreach ($gallery_items as $item_id => $attachment) {
$link_target = get_post_meta($attachment->ID, '_gallery_link_target', true);
$link_target = ($link_target !== '') ? $link_target : '_self';
$downloads = $this->wpmfGalleryGetDownloadLink($attachment->ID);
switch ($link) {
case 'file':
$image_output = $this->getAttachmentLink($item_id, $size, false, $targetsize, false, $link_target, $pos);
break;
case 'post':
$image_output = $this->getAttachmentLink($item_id, $size, true, $targetsize, false, $link_target, $pos);
break;
case 'none':
$image_output = wp_get_attachment_image($item_id, $size, false, array('data-type' => 'wpmfgalleryimg'));
break;
case 'custom':
$image_output = $this->getAttachmentLink($item_id, $size, false, $targetsize, true, $link_target, $pos);
break;
default:
$image_output = $this->getAttachmentLink($item_id, $size, false, $targetsize, false, $link_target, $pos);
}
if ($enable_download) {
$image_output .= '<a href="'.esc_url($downloads['download_link']).'" '. (($downloads['type'] === 'local') ? 'download' : '') .' class="wpmf_gallery_download_icon"><span class="material-icons-outlined"> file_download </span></a>';
}
$output .= '<div class="wpmf-gallery-item
wpmf-gallery-item-position-' . $pos . ' wpmf-gallery-item-attachment-' . $item_id . '" data-index="'. esc_attr($pos) .'">';
$output .= '<div class="wpmf-gallery-icon">';
$output .= wpmfRenderVideoIcon($attachment->ID);
$output .= $image_output;
$output .= '</div>';
$output .= '</div>';
$pos++;
}
$output .= "</div></div>\n";