seiger/sgallery

Evocms package for work with Gallery for Resource in Evolution CMS and manipulate images with an expressive API

Fund package maintenance!
Ko Fi

Installs: 133

Dependents: 1

Suggesters: 0

Security: 0

Stars: 7

Watchers: 1

Forks: 0

Open Issues: 0

Type:evolutioncms-plugin

v1.3.2 2024-11-15 13:24 UTC

This package is auto-updated.

Last update: 2024-12-04 20:55:20 UTC


README

sGallery Latest Stable Version CMS Evolution PHP version License Issues Stars Total Downloads

sGallery emerges as a versatile and indispensable plugin tailor-made for Evolution CMS, revolutionizing the way you manage media assets within your website. Specifically designed for the Evolution CMS admin panel, this dynamic plugin introduces a host of powerful features to elevate your content presentation.

sGallery stands as a testament to Evolution CMS's commitment to robust and user-friendly content management. Whether you are a content creator or an administrator, this plugin empowers you to curate a visually stunning and engaging website with unparalleled ease. Elevate your media management experience with sGallery today.

Features

  • Image and Video Attachment.
  • Effortless Media Upload.
  • YouTube Integration.
  • Sortable Positions.
  • Text Fields for File Management.
  • Image Resize and AVIF or WEBP Conversion.
  • Integration with Custom Modules.
  • sLang Integration.
  • More than one tab.

Supported formats

The following image formats are tested and supported by the package. If your GD/Imagick installation supports a format that is not listed you are probably fine to use it but your mileage may vary.

Minimum requirements

  • Evolution CMS 3.2.0
  • PHP 8.2.0
  • Composer 2.2.0
  • PostgreSQL 10.23.0
  • MySQL 8.0.3
  • MariaDB 10.5.2
  • SQLite 3.25.0

Install by artisan package installer

Go to You /core/ folder:

cd core

Run php artisan command

php artisan package:installrequire seiger/sgallery "*"

Generate the config file in ../core/custom/config/seiger/settings with name sgallery.php the file should return a comma-separated list of templates.

php artisan vendor:publish --provider="Seiger\sGallery\sGalleryServiceProvider"

Run make DB structure with command:

php artisan migrate

Configure

Templates for displaying gallery tabs are configured in the

core/custom/config/seiger/settings/sGallery.php

file, where the array contains template IDs for connecting the gallery.

Usage in blade

Sow all files with Image filter:

@foreach(sGallery::collections()->get() as $item)
    @if(sGallery::hasImage($item->type))
        <a class="swiper-slide" @if(trim($item->link))href="{{$item->link}}"@endif>
            <div class="container">
                <img loading="lazy" class="intro__img" src="{{$item->src}}" alt="{{$item->alt}}" width="1440" height="456">
                <div class="intro__inner">
                    <div class="h1__title">{{$item->title}}</div>
                    <p class="intro__text">{{$item->description}}</p>
                    @if(trim($item->link_text))<div class="btn background__mod">{{$item->link_text}}</div>@endif
                </div>
            </div>
        </a>
    @endif
@endforeach

or YouTube filter

@foreach(sGallery::collections()->get() as $item)
    @if(sGallery::hasYoutube($item->type))
        <div class="item">
            <div class="video">
                <iframe width="560" height="315" src="https://www.youtube.com/embed/{{$item->file}}" title="YouTube video player" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture" allowfullscreen></iframe>
            </div>
            <p>{{$item->title}}</p>
        </div>
    @endif
@endforeach

or

@foreach(sGallery::collections()->documentId($product->id)->itemType('product')->get() as $item)
    <div class="swiper-slide">
        <a class="js-trigger-fancybox" href="{{$item->src}}" data-fancybox="product-gallery">
            <img loading="lazy" src="{{$item->src}}" width="440" height="440" />
        </a>
    </div>
@endforeach

Integration into the products module

Just paste this code in your View backend

{!!sGallery::initialiseView()->viewType('section')->itemType('product')->idType('i')!!}

See full documentation here