2017 © Pedro Peláez
 

symfony-bundle imgix-bundle

Generate and transform urls and responsive images in Symfony and Twig

image

sparwelt/imgix-bundle

Generate and transform urls and responsive images in Symfony and Twig

  • Wednesday, August 1, 2018
  • by federico.infanti
  • Repository
  • 3 Watchers
  • 0 Stars
  • 5 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 0 Forks
  • 0 Open issues
  • 7 Versions
  • 0 % Grown

The README.md

Build Status Coverage Status, (*1)

php5.6 + sf2 php7.1 + sf2 php5.6 + sf3 php7.1 + sf3 php7.1 + sf4
[Status][6] [Status][6] [Status][6] [Status][6] [Status][6]

Imgix Bundle for Symfony

Installation

composer require sparwelt/imgix-bundle

Basic configuration

sparwelt_imgix:
  cdn_configurations:
    my_cdn:
        cdn_domains: ['my.imgix.net']
        sign_key: '12345'

  image_filters:
    my_basic_filter:
        src: {w: 30, h: 60}

Basic usage

{# url generation #}
{{ imgix_url('/dir/test.png', {w: 100, h: 200}) }}
{# "https://my.imgix.net/dir/test.png?w=100&h=200" #}

{# image generation #}
{{ imgix_image('/dir/test.png', {src: {w: 100, h: 200}}) }};
{# <img src="https://my.imgix.net/dir/test.png?w=100&h=200"> #}

{# html conversion #}
{{ imgix_html('<li><img src="/test.png"><\li><li><img src="/test2.png">', {src: {w: 100, h:  200}}) }}
{# <li><img src="https://my.imgix.net/test.png?h=200&w=100"><\li><li><img src="https://my.imgix.net/test2.png?h=200&w=100"> #}

Responsive usage

{# image generation #}
{{ imgix_image('/dir/test.png', {
            src: {h: 150, w: 300},
            srcset: {
                100w: {h: 300, w: 600},
                500w: {h: 600, w: 900},
            },
            sizes: '(min-width: 900px) 1000px, (max-width: 900px)'
}) }}
{# <img src="https://test.imgix.net/dir/test.png?h=150&w=300"
        srcset="https://test.imgix.net/dir/test.png?h=300&w=600 100w, https://test.imgix.net/dir/test.png?h=600&w=900 500w"
        sizes="(min-width: 900px) 1000px, (max-width: 900px)"> #}

{# image generation #}
  <img srcset="{{imgix_attr('test.png', {
    '2x': {w: 400, h: 200}
    '3x': {w: 600, h: 300}
  }) }}">

{# <img srcset="https://test.imgix.net/test.png?h=200&w=400 2x, https://test.imgix.net/test.png?h=300&w=600 3x"> #}

Lazyloading

{{ imgix_image('/dir/test.png', {
    'src': {h: 30, w: 60},
    'srcset': 'data:image/gif;base64,R0lGODlhAQABAAAAACH5BAEKAAEALAAAAAABAAEAAAICTAEAOw==',
    'data-srcset': {
        '100w': {'h': 60, 'w': 120}
        '500w': {'h': 90, 'w': 180},
    },
    'data-sizes': 'auto',
    'class': 'lazyload',
}) }}
{# <img src="https://test.imgix.net/dir/test.png?h=30&w=60" 
       srcset="data:image/gif;base64,R0lGODlhAQABAAAAACH5BAEKAAEALAAAAAABAAEAAAICTAEAOw=="
       data-srcset="https://test.imgix.net/dir/test.png?h=60&w=120 100w, https://test.imgix.net/dir/test.png?h=90&w=180 500w"
       data-sizes="auto" 
       class="lazyload">
#}

Named filters

Instead of repeating filters at every usage, named filters can be configured once and called by name:, (*2)

sparwelt_imgix:
  image_filters:
    my_basic_filter:
        src: {w: 30, h: 60}
    my_blur_lazyload_filter:
        src: {w: 30, h: 60}
        data-src: {h: 30, w: 60, blur: 1000}
        data-srcset:
            100w: {h: 60, w: 120}
            500w: {h: 90, w: 180}
        data-sizes: 'auto'
        class: 'lazyload'

```twig {{ imgix_image('dir/test.png', 'my_basic_filter') }} {# #}, (*3)

{{ imgix_image('dir/test.png', 'my_blur_lazyload_filter') }} {# , (*4)

}

{{ imgix_url('dir/test.png', 'my_basic_filter.src') }} {# https://test.imgix.net/test.png?h=30&w=60 #}, (*5)

{{ imgix_url('dir/test.png', 'my_basic_filter.src', {q: 75}) }} {# https://test.imgix.net/test.png?h=30&w=60&q=75 #}, (*6)

{{ imgix_attr('dir/test.png', 'my_blur_lazyload_filter.data-srcset') }} {# https://test.imgix.net/dir/test.png?h=60&w=120 100w, https://test.imgix.net/dir/test.png?h=90&w=180 500w #}, (*7)

{{ imgix_html($html, 'my_blur_lazyload_filter') }} {# ... replaces all images with responsive ones #}, (*8)


### Multiple cdn configurations The image path will be evaluate against the configurations, from top to bottom, until a suitable match is found. Multiple domains can be specified for the same configuration (domain sharding). ```yaml sparwelt_imgix: cdn_configurations: # matches images with source domain 'mysite.com' (including subdomains) # AND path beginning with 'uploads/' OR 'media/' # Relative urls won't match source_domains_and_pattern: cdn_domains: ['my-cdn-1.imgix.net'] source_domains: ['mysite.com'] path_patterns: ['^[/]uploads/', '^[/]media/'] # matches images with source domain exactly 'www3.mysite.com' OR 'www4.mysite.com' # Relative urls won't match source_sub_domain: cdn_domains: ['my-cdn-2.imgix.net'] source_domains: ['www3.mysite.com', 'www4.mysite.com'] # matches images with source domain 'mysite.com' (including subdomains) # Relative urls won't match source_domains: cdn_domains: ['my-cdn-3.imgix.net'] source_domains: ['mysite.com'] # matches images with source domain 'mysite.com' (including subdomains) # AND relative urls (because of the 'null') source_domains_and_null: cdn_domains: ['my-cdn-4.imgix.net'] source_domains: ['mysite.com', null] # matches relative urls only, where path begins with 'uploads/'. # Absolute urls won't match. pattern: cdn_domains: ['my-cdn-5.imgix.net'] path_patterns: ['^[/]pattern/'] # matches relative urls only, where path begins with 'sign-key/'. # appends sign-key to the generated url (recommended) sign_key: cdn_domains: ['my-cdn-6.imgix.net'] path_patterns: ['[^]/sign-key/'] sign_key: '12345' # matches relative urls only, where path begins with 'shard-crc/'. # Will choose the cdn domains by the hash of the path (recommended) shard_crc: cdn_domains: ['my-cdn-7.imgix.net', 'my-cdn-8.imgix.net'] path_patterns: ['^[/]shard-crc/'] shard_strategy: 'crc' #default # matches relative urls only, where path begins with 'shard-cycle/'. # Will rotate between the 2 cdn domains (increase costs) shard_cycle: cdn_domains: ['my-cdn-9.imgix.net', 'my-cdn-10.imgix.net'] path_patterns: ['^[/]shard-cycle/'] shard_strategy: 'cycle' # default parameters can be added, useful for cache bursting or automatic formatting default_parameters: cdn_domains: ['my-cdn-11.imgix.net'] path_patterns: ['^[/]shard-cycle/'] default_query_params: cb: '1234' auto: 'quality' # disable parameters generation # (useful for development/testing environments) bypass_dev: cdn_domains: ['my-dev-domain.local'] source_domains: ['my-dev-domain.local'] generate_filter_params: false, use_ssl: false # matches all relative urls my_default: cdn_domains: ['my-cdn-12.imgix.net']

The Versions

01/08 2018

dev-master

9999999-dev

Generate and transform urls and responsive images in Symfony and Twig

  Sources   Download

MIT

The Requires

 

by Federico Infanti

01/08 2018

0.1.7

0.1.7.0

Generate and transform urls and responsive images in Symfony and Twig

  Sources   Download

MIT

The Requires

 

by Federico Infanti

01/08 2018

0.1.5

0.1.5.0

Generate and transform urls and responsive images in Symfony and Twig

  Sources   Download

MIT

The Requires

 

by Federico Infanti

25/07 2018

0.1.4

0.1.4.0

Generate and transform urls and responsive images in Symfony and Twig

  Sources   Download

MIT

The Requires

 

by Federico Infanti

25/07 2018

dev-develop

dev-develop

Generate and transform urls and responsive images in Symfony and Twig

  Sources   Download

MIT

The Requires

 

by Federico Infanti

25/07 2018

0.1.3

0.1.3.0

Generate and transform urls and responsive images in Symfony and Twig

  Sources   Download

MIT

The Requires

 

by Federico Infanti

25/07 2018

0.1.1

0.1.1.0

Generate and transform urls and responsive images in Symfony and Twig

  Sources   Download

MIT

The Requires

 

by Federico Infanti