rrb/twig-utils-bundle

This package is abandoned and no longer maintained. No replacement package was suggested.

A Symfony bundle with some twig utilities

0.0.2 2016-06-26 10:10 UTC

This package is auto-updated.

Last update: 2020-08-29 17:08:08 UTC


README

This is a Symfony bundle that provides some useful Twig functions ready to use in your projects.

HTML and CSS thanks to Gemma Casals.

Installation

Step 1: Download the Bundle

Open a command console, enter your project directory and execute the following command to download the latest stable version of this bundle:

$ composer require rrb/twig-utils-bundle "*"

This command requires you to have Composer installed globally, as explained in the installation chapter of the Composer documentation.

Step 2: Enable the Bundle

Then, enable the bundle by adding it to the list of registered bundles in the app/AppKernel.php file of your project:

<?php
// app/AppKernel.php

// ...
class AppKernel extends Kernel
{
    public function registerBundles()
    {
        $bundles = array(
            // ...

            new Rrb\TwigUtilsBundle\RrbTwigUtilsBundle(),
        );

        // ...
    }

    // ...
}

Usage

Lazy loading images

The bundles provides a custom implementation for lazy loading images based on the explanation showed in this video of the Polymer Project.

The idea is to render a low-resolution image of the image whilst it is loading, so the user may start reading the content without having to wait for all images to load.

The strategy is to show the low-resolution image as a base64 encoded image, so the browser can immediately render it, avoiding a new request. Thus, the low-resolution image should be at most 10px width by 10px height.

The low-resolution image is rendered as a background of a <div> that wraps the <img> tag.

You can see a demo here .

lazy_image_render

{{ lazy_image_render(imageUrl, imageBase46, title='', alt='') }}

imageUrl: the url of the image to load.

    type: string

imageBase64

    type: string

title (optional)

    type: string default: ''

alt (optional)

    type: string default: ''

Renders the <img> tag wrapped in a <div> whose background is the base64 encoded image. It optionally accepts the title and alt of the image.

The HTML rendered is as follows:

<div class="lazy-image-wrapper" style="background-image: url('...');">
    <img class="lazy-image"
         title="title of the image"
         alt="alt of the image"
         src="http://www.example.com/image1.png"
         onload="this.style.opacity = '1'"
    />
</div>

lazy_image_css

{{ lazy_image_css() }}

Renders a stylesheet for the lazy images to work. You have to call this function just once in your <head> tag. Of course, you may also add the styles on your own stylesheet if you want to tweak them.

The CSS content included in the stylesheet is:

.lazy-image{
    opacity:0;
    -webkit-transition: all 0.5s ease-in-out;
    transition: all 0.5s ease-in-out;
    max-width: 100%
}
.lazy-image-wrapper{
    background-size: cover;
    background-repeat: no-repeat;
}