{# uses cms block column count and all available thumbnails to determine the correct image size for the current viewport #}
{% if media.thumbnails|length > 0 %}
{% if columns and sizes is not defined %}
{# set image size for every viewport #}
{% set sizes = {
'xs': (shopware.theme.breakpoint.sm - 1) ~'px',
'sm': (shopware.theme.breakpoint.md - 1) ~'px',
'md': ((shopware.theme.breakpoint.lg - 1) / columns)|round(0, 'ceil') ~'px',
'lg': ((shopware.theme.breakpoint.xl - 1) / columns)|round(0, 'ceil') ~'px'
} %}
{# set image size for largest viewport depending on the cms block sizing mode (boxed or full-width) #}
{% if layout == 'full-width' %}
{% set container = 100 %}
{% set sizes = sizes|merge({ 'xl': (container / columns)|round(0, 'ceil') ~'vw'}) %}
{% else %}
{% set container = 1360 %}
{% set sizes = sizes|merge({ 'xl': (container / columns)|round(0, 'ceil') ~'px'}) %}
{% endif %}
{% endif %}
{% set boosters = media.extensions.mediaBoosters %}
{% if boosters.watermark %}
{% set thumbnails = boosters.watermarkThumbnails %}
{% set srcsetValue %}{% apply spaceless %}{{ boosters.watermark.generatedPath }} {{ thumbnails|first.width + 1 }}w,
{% for thumbnail in thumbnails %}
{% if boosters.watermark.width > thumbnail.width %}
{{ thumbnail.generatedPath | sw_encode_url }}
{% else %}
{{ boosters.watermark.generatedPath }}
{% endif%}
{{ thumbnail.width }}w
{% if not loop.last %}, {% endif %}
{% endfor %}
{% endapply %}{% endset %}
{% else %}
{% set thumbnails = media.thumbnails %}
{% set srcsetValue %}{% apply spaceless %}{{ media|sw_encode_media_url }} {{ thumbnails|first.width + 1 }}w, {% for thumbnail in thumbnails %}{{ thumbnail.url | sw_encode_url }} {{ thumbnail.width }}w{% if not loop.last %}, {% endif %}{% endfor %}
{% endapply %}{% endset %}
{% endif %}
{% set srcsetValueWebP %}{% apply spaceless %}
{% if boosters.webpMedia %}
{{ boosters.webpMedia.generatedPath }} {{ thumbnails|first.width + 1 }}w,
{% for thumbnail in boosters.webpThumbnails %}
{% if thumbnail.width < boosters.webpMedia.width %}{{ thumbnail.generatedPath | sw_encode_url }} {% else %}{{ boosters.webpMedia.generatedPath }}{% endif %}
{{ thumbnail.width }}w{% if not loop.last %}, {% endif %}{% endfor %}
{% endif %}
{% endapply %}{% endset %}
{% set srcsetValueAvif %}{% apply spaceless %}
{% if boosters.avifMedia %}
{{ boosters.avifMedia.generatedPath }} {{ thumbnails|first.width + 1 }}w, {% for thumbnail in boosters.avifThumbnails %}
{% if thumbnail.width < boosters.avifMedia.width %}{{ thumbnail.generatedPath | sw_encode_url }} {% else %}{{ boosters.avifMedia.generatedPath }}{% endif %}
{{ thumbnail.width }}w{% if not loop.last %}, {% endif %}{% endfor %}
{% endif %}
{% endapply %}{% endset %}
{# generate sizes #}
{% set sizesValue %}{% apply spaceless %}
{% set sizeFallback = 100 %}
{# set largest size depending on column count of cms block #}
{% if columns %}
{% set sizeFallback = (sizeFallback / columns)|round(0, 'ceil') %}
{% endif %}
{% if thumbnails|first.width > shopware.theme.breakpoint|reverse|first %}
{% set maxWidth = thumbnails|first.width %}
{% endif %}
{% for key, value in shopware.theme.breakpoint|reverse %}{% if maxWidth %}(max-width: {{ maxWidth }}px) and {% endif %}(min-width: {{ value }}px) {{ sizes[key] }}{% set maxWidth = value-1 %}{% if not loop.last %}, {% endif %}{% endfor %}, {{ sizeFallback }}vw
{% endapply %}{% endset %}
{% endif %}
<picture media-id="{{ media.id }}">
{% set mediaUrlCalculated %}{% apply spaceless %}
{% if media.extensions.mediaBoosters.watermark and media.extensions.mediaBoosters.watermark.generatedPath %}
{{ media.extensions.mediaBoosters.watermark.generatedPath }}
{% else %}
{{ media|sw_encode_media_url }}
{% endif %}
{% endapply %}{% endset %}
<source
srcset="{{ srcsetValueAvif }}"
{% if sizes['default'] %}
sizes="{{ sizes['default'] }}"
{% elseif sizes|length > 0 %}
sizes="{{ sizesValue }}"
{% endif %}
type="image/avif"
>
<source
srcset="{{ srcsetValueWebP }}"
{% if sizes['default'] %}
sizes="{{ sizes['default'] }}"
{% elseif sizes|length > 0 %}
sizes="{{ sizesValue }}"
{% endif %}
type="image/webp"
>
<img src="{{ mediaUrlCalculated }}"
{% if media.thumbnails|length > 0 %}
srcset="{{ srcsetValue }}"
{% if sizes['default'] %}
sizes="{{ sizes['default'] }}"
{% elseif sizes|length > 0 %}
sizes="{{ sizesValue }}"
{% endif %}
{% endif %}
{% for key, value in attributes %}{% if value != '' %} {{ key }}="{{ value }}"{% endif %}{% endfor %}
/>
</picture>