<figure class="image sg-image">
<img loading="lazy" src="' %}
{% set imgElement %}
<img
loading={% if eager and sizes %}"eager"{% else %}"lazy"{% endif %}
src="{{ placeholderSrc }}"
{% if eager and sizes %}
srcset="{{ data.srcset }}"
sizes="{{ sizes }}"
{% else %}
data-srcset="{{ data.srcset }}"
data-sizes="auto"
{% endif %}
alt="{{ data.alt }}"
{% if data.width %}width="{{ data.width }}"{% endif %}
{% if data.title %}title="{{ data.title }}"{% endif %}
class="image__img {% if not eager or not sizes %}lazyload{% endif %}"
>
{% endset %}
{% set image %}
{% if data.sources %}
<picture class="image__picture">
{% for source in data.sources %}
{% set sourcePlaceholder = source.aspectRatio ? '' %}
<source
srcset={% if eager and sizes %}"{{ source.srcset }}"{% else %}"{{ sourcePlaceholder }}"{% endif %}
data-srcset="{{ source.srcset }}"
media="{{ media[loop.index0] }}"
>
{% endfor %}
{{ imgElement }}
</picture>
{% else %}
{{ imgElement }}
{% endif %}
{% endset %}
<figure class="image {{ modifier }} {{ class }}">
{% if data.url %}
<a
class="image__link{% if data.anchorClass %} {{ data.anchorClass }}{% endif %}"
href="{{ data.url }}"
{% if data.target %}target="{{ data.target }}"{% endif %}
{% if data.rel %}rel="{{ data.rel }}"{% endif %}
{% if anchorAttributes %}{{ anchorAttributes }}{% endif %}
>
{{ image }}
</a>
{% else %}
{{ image }}
{% endif %}
{% if data.caption and not noCaption %}
<figcaption class="image__caption">{{ data.caption }}</figcaption>
{% endif %}
</figure>
{
"language": "en-US",
"class": "sg-image",
"data": {
"srcset": "//via.placeholder.com/100x100 100w, //via.placeholder.com/200x200 200w",
"alt": "image alt text",
"aspectRatio": {
"width": 100,
"height": 100
}
}
}
.image--align-right {
float: right;
}
.image--align-left {
float: left;
}
.image__img {
display: block;
&.lazyload,
&.lazyloading {
opacity: 0;
transition: opacity $transition-duration $transition-easing;
}
&.lazyloaded {
opacity: 1;
transition: opacity $transition-duration $transition-easing;
}
.image--fluid & {
max-width: 100%;
height: auto;
}
.image--full & {
width: 100%;
}
.image--round & {
border-radius: $border-radius-round;
}
.image--align-center & {
display: block;
margin-left: auto;
margin-right: auto;
}
}
.image__caption {
margin-top: 8px;
font-size: 14px;
line-height: 1.28;
}
import './image.scss';
<figure class="image image--fluid sg-image">
<img loading="lazy" src="' %}
{% set imgElement %}
<img
loading={% if eager and sizes %}"eager"{% else %}"lazy"{% endif %}
src="{{ placeholderSrc }}"
{% if eager and sizes %}
srcset="{{ data.srcset }}"
sizes="{{ sizes }}"
{% else %}
data-srcset="{{ data.srcset }}"
data-sizes="auto"
{% endif %}
alt="{{ data.alt }}"
{% if data.width %}width="{{ data.width }}"{% endif %}
{% if data.title %}title="{{ data.title }}"{% endif %}
class="image__img {% if not eager or not sizes %}lazyload{% endif %}"
>
{% endset %}
{% set image %}
{% if data.sources %}
<picture class="image__picture">
{% for source in data.sources %}
{% set sourcePlaceholder = source.aspectRatio ? '' %}
<source
srcset={% if eager and sizes %}"{{ source.srcset }}"{% else %}"{{ sourcePlaceholder }}"{% endif %}
data-srcset="{{ source.srcset }}"
media="{{ media[loop.index0] }}"
>
{% endfor %}
{{ imgElement }}
</picture>
{% else %}
{{ imgElement }}
{% endif %}
{% endset %}
<figure class="image {{ modifier }} {{ class }}">
{% if data.url %}
<a
class="image__link{% if data.anchorClass %} {{ data.anchorClass }}{% endif %}"
href="{{ data.url }}"
{% if data.target %}target="{{ data.target }}"{% endif %}
{% if data.rel %}rel="{{ data.rel }}"{% endif %}
{% if anchorAttributes %}{{ anchorAttributes }}{% endif %}
>
{{ image }}
</a>
{% else %}
{{ image }}
{% endif %}
{% if data.caption and not noCaption %}
<figcaption class="image__caption">{{ data.caption }}</figcaption>
{% endif %}
</figure>
{
"language": "en-US",
"class": "sg-image",
"data": {
"srcset": "//via.placeholder.com/100x100 100w, //via.placeholder.com/200x200 200w",
"alt": "image alt text",
"aspectRatio": {
"width": 100,
"height": 100
}
},
"modifier": "image--fluid"
}
.image--align-right {
float: right;
}
.image--align-left {
float: left;
}
.image__img {
display: block;
&.lazyload,
&.lazyloading {
opacity: 0;
transition: opacity $transition-duration $transition-easing;
}
&.lazyloaded {
opacity: 1;
transition: opacity $transition-duration $transition-easing;
}
.image--fluid & {
max-width: 100%;
height: auto;
}
.image--full & {
width: 100%;
}
.image--round & {
border-radius: $border-radius-round;
}
.image--align-center & {
display: block;
margin-left: auto;
margin-right: auto;
}
}
.image__caption {
margin-top: 8px;
font-size: 14px;
line-height: 1.28;
}
import './image.scss';
<figure class="image sg-image">
<picture class="image__picture">
<source srcset="' %}
{% set imgElement %}
<img
loading={% if eager and sizes %}"eager"{% else %}"lazy"{% endif %}
src="{{ placeholderSrc }}"
{% if eager and sizes %}
srcset="{{ data.srcset }}"
sizes="{{ sizes }}"
{% else %}
data-srcset="{{ data.srcset }}"
data-sizes="auto"
{% endif %}
alt="{{ data.alt }}"
{% if data.width %}width="{{ data.width }}"{% endif %}
{% if data.title %}title="{{ data.title }}"{% endif %}
class="image__img {% if not eager or not sizes %}lazyload{% endif %}"
>
{% endset %}
{% set image %}
{% if data.sources %}
<picture class="image__picture">
{% for source in data.sources %}
{% set sourcePlaceholder = source.aspectRatio ? '' %}
<source
srcset={% if eager and sizes %}"{{ source.srcset }}"{% else %}"{{ sourcePlaceholder }}"{% endif %}
data-srcset="{{ source.srcset }}"
media="{{ media[loop.index0] }}"
>
{% endfor %}
{{ imgElement }}
</picture>
{% else %}
{{ imgElement }}
{% endif %}
{% endset %}
<figure class="image {{ modifier }} {{ class }}">
{% if data.url %}
<a
class="image__link{% if data.anchorClass %} {{ data.anchorClass }}{% endif %}"
href="{{ data.url }}"
{% if data.target %}target="{{ data.target }}"{% endif %}
{% if data.rel %}rel="{{ data.rel }}"{% endif %}
{% if anchorAttributes %}{{ anchorAttributes }}{% endif %}
>
{{ image }}
</a>
{% else %}
{{ image }}
{% endif %}
{% if data.caption and not noCaption %}
<figcaption class="image__caption">{{ data.caption }}</figcaption>
{% endif %}
</figure>
{
"language": "en-US",
"class": "sg-image",
"data": {
"srcset": "//via.placeholder.com/100x100 100w, //via.placeholder.com/200x200 200w",
"alt": "image alt text",
"aspectRatio": {
"width": 100,
"height": 100
},
"sources": [
{
"srcset": "//via.placeholder.com/100x175 100w, //via.placeholder.com/200x350 200w",
"aspectRatio": {
"width": 100,
"height": 175
}
},
{
"srcset": "//via.placeholder.com/100x150 100w, //via.placeholder.com/200x300 200w",
"aspectRatio": {
"width": 100,
"height": 150
}
},
{
"srcset": "//via.placeholder.com/100x125 100w, //via.placeholder.com/200x250 200w",
"aspectRatio": {
"width": 100,
"height": 125
}
}
]
},
"media": [
"(min-width: 1170px)",
"(min-width: 1024px)",
"(min-width: 768px)"
]
}
.image--align-right {
float: right;
}
.image--align-left {
float: left;
}
.image__img {
display: block;
&.lazyload,
&.lazyloading {
opacity: 0;
transition: opacity $transition-duration $transition-easing;
}
&.lazyloaded {
opacity: 1;
transition: opacity $transition-duration $transition-easing;
}
.image--fluid & {
max-width: 100%;
height: auto;
}
.image--full & {
width: 100%;
}
.image--round & {
border-radius: $border-radius-round;
}
.image--align-center & {
display: block;
margin-left: auto;
margin-right: auto;
}
}
.image__caption {
margin-top: 8px;
font-size: 14px;
line-height: 1.28;
}
import './image.scss';
limit maximum render width of image by adding a width prop to data
<figure class="image sg-image">
<img loading="lazy" src="' %}
{% set imgElement %}
<img
loading={% if eager and sizes %}"eager"{% else %}"lazy"{% endif %}
src="{{ placeholderSrc }}"
{% if eager and sizes %}
srcset="{{ data.srcset }}"
sizes="{{ sizes }}"
{% else %}
data-srcset="{{ data.srcset }}"
data-sizes="auto"
{% endif %}
alt="{{ data.alt }}"
{% if data.width %}width="{{ data.width }}"{% endif %}
{% if data.title %}title="{{ data.title }}"{% endif %}
class="image__img {% if not eager or not sizes %}lazyload{% endif %}"
>
{% endset %}
{% set image %}
{% if data.sources %}
<picture class="image__picture">
{% for source in data.sources %}
{% set sourcePlaceholder = source.aspectRatio ? '' %}
<source
srcset={% if eager and sizes %}"{{ source.srcset }}"{% else %}"{{ sourcePlaceholder }}"{% endif %}
data-srcset="{{ source.srcset }}"
media="{{ media[loop.index0] }}"
>
{% endfor %}
{{ imgElement }}
</picture>
{% else %}
{{ imgElement }}
{% endif %}
{% endset %}
<figure class="image {{ modifier }} {{ class }}">
{% if data.url %}
<a
class="image__link{% if data.anchorClass %} {{ data.anchorClass }}{% endif %}"
href="{{ data.url }}"
{% if data.target %}target="{{ data.target }}"{% endif %}
{% if data.rel %}rel="{{ data.rel }}"{% endif %}
{% if anchorAttributes %}{{ anchorAttributes }}{% endif %}
>
{{ image }}
</a>
{% else %}
{{ image }}
{% endif %}
{% if data.caption and not noCaption %}
<figcaption class="image__caption">{{ data.caption }}</figcaption>
{% endif %}
</figure>
{
"language": "en-US",
"class": "sg-image",
"data": {
"srcset": "//via.placeholder.com/100x100 100w, //via.placeholder.com/200x200 200w",
"alt": "image alt text",
"aspectRatio": {
"width": 100,
"height": 100
},
"width": 300
}
}
.image--align-right {
float: right;
}
.image--align-left {
float: left;
}
.image__img {
display: block;
&.lazyload,
&.lazyloading {
opacity: 0;
transition: opacity $transition-duration $transition-easing;
}
&.lazyloaded {
opacity: 1;
transition: opacity $transition-duration $transition-easing;
}
.image--fluid & {
max-width: 100%;
height: auto;
}
.image--full & {
width: 100%;
}
.image--round & {
border-radius: $border-radius-round;
}
.image--align-center & {
display: block;
margin-left: auto;
margin-right: auto;
}
}
.image__caption {
margin-top: 8px;
font-size: 14px;
line-height: 1.28;
}
import './image.scss';
<figure class="image sg-image">
<a class="image__link" href="https://google.ee" target="_blank">
<img loading="lazy" src="' %}
{% set imgElement %}
<img
loading={% if eager and sizes %}"eager"{% else %}"lazy"{% endif %}
src="{{ placeholderSrc }}"
{% if eager and sizes %}
srcset="{{ data.srcset }}"
sizes="{{ sizes }}"
{% else %}
data-srcset="{{ data.srcset }}"
data-sizes="auto"
{% endif %}
alt="{{ data.alt }}"
{% if data.width %}width="{{ data.width }}"{% endif %}
{% if data.title %}title="{{ data.title }}"{% endif %}
class="image__img {% if not eager or not sizes %}lazyload{% endif %}"
>
{% endset %}
{% set image %}
{% if data.sources %}
<picture class="image__picture">
{% for source in data.sources %}
{% set sourcePlaceholder = source.aspectRatio ? '' %}
<source
srcset={% if eager and sizes %}"{{ source.srcset }}"{% else %}"{{ sourcePlaceholder }}"{% endif %}
data-srcset="{{ source.srcset }}"
media="{{ media[loop.index0] }}"
>
{% endfor %}
{{ imgElement }}
</picture>
{% else %}
{{ imgElement }}
{% endif %}
{% endset %}
<figure class="image {{ modifier }} {{ class }}">
{% if data.url %}
<a
class="image__link{% if data.anchorClass %} {{ data.anchorClass }}{% endif %}"
href="{{ data.url }}"
{% if data.target %}target="{{ data.target }}"{% endif %}
{% if data.rel %}rel="{{ data.rel }}"{% endif %}
{% if anchorAttributes %}{{ anchorAttributes }}{% endif %}
>
{{ image }}
</a>
{% else %}
{{ image }}
{% endif %}
{% if data.caption and not noCaption %}
<figcaption class="image__caption">{{ data.caption }}</figcaption>
{% endif %}
</figure>
{
"language": "en-US",
"class": "sg-image",
"data": {
"srcset": "//via.placeholder.com/100x100 100w, //via.placeholder.com/200x200 200w",
"alt": "image alt text",
"aspectRatio": {
"width": 100,
"height": 100
},
"url": "https://google.ee",
"target": "_blank"
}
}
.image--align-right {
float: right;
}
.image--align-left {
float: left;
}
.image__img {
display: block;
&.lazyload,
&.lazyloading {
opacity: 0;
transition: opacity $transition-duration $transition-easing;
}
&.lazyloaded {
opacity: 1;
transition: opacity $transition-duration $transition-easing;
}
.image--fluid & {
max-width: 100%;
height: auto;
}
.image--full & {
width: 100%;
}
.image--round & {
border-radius: $border-radius-round;
}
.image--align-center & {
display: block;
margin-left: auto;
margin-right: auto;
}
}
.image__caption {
margin-top: 8px;
font-size: 14px;
line-height: 1.28;
}
import './image.scss';
<figure class="image image--align-left sg-image">
<img loading="lazy" src="' %}
{% set imgElement %}
<img
loading={% if eager and sizes %}"eager"{% else %}"lazy"{% endif %}
src="{{ placeholderSrc }}"
{% if eager and sizes %}
srcset="{{ data.srcset }}"
sizes="{{ sizes }}"
{% else %}
data-srcset="{{ data.srcset }}"
data-sizes="auto"
{% endif %}
alt="{{ data.alt }}"
{% if data.width %}width="{{ data.width }}"{% endif %}
{% if data.title %}title="{{ data.title }}"{% endif %}
class="image__img {% if not eager or not sizes %}lazyload{% endif %}"
>
{% endset %}
{% set image %}
{% if data.sources %}
<picture class="image__picture">
{% for source in data.sources %}
{% set sourcePlaceholder = source.aspectRatio ? '' %}
<source
srcset={% if eager and sizes %}"{{ source.srcset }}"{% else %}"{{ sourcePlaceholder }}"{% endif %}
data-srcset="{{ source.srcset }}"
media="{{ media[loop.index0] }}"
>
{% endfor %}
{{ imgElement }}
</picture>
{% else %}
{{ imgElement }}
{% endif %}
{% endset %}
<figure class="image {{ modifier }} {{ class }}">
{% if data.url %}
<a
class="image__link{% if data.anchorClass %} {{ data.anchorClass }}{% endif %}"
href="{{ data.url }}"
{% if data.target %}target="{{ data.target }}"{% endif %}
{% if data.rel %}rel="{{ data.rel }}"{% endif %}
{% if anchorAttributes %}{{ anchorAttributes }}{% endif %}
>
{{ image }}
</a>
{% else %}
{{ image }}
{% endif %}
{% if data.caption and not noCaption %}
<figcaption class="image__caption">{{ data.caption }}</figcaption>
{% endif %}
</figure>
{
"language": "en-US",
"class": "sg-image",
"data": {
"srcset": "//via.placeholder.com/100x100 100w, //via.placeholder.com/200x200 200w",
"alt": "image alt text",
"aspectRatio": {
"width": 100,
"height": 100
},
"width": 200
},
"modifier": "image--align-left"
}
.image--align-right {
float: right;
}
.image--align-left {
float: left;
}
.image__img {
display: block;
&.lazyload,
&.lazyloading {
opacity: 0;
transition: opacity $transition-duration $transition-easing;
}
&.lazyloaded {
opacity: 1;
transition: opacity $transition-duration $transition-easing;
}
.image--fluid & {
max-width: 100%;
height: auto;
}
.image--full & {
width: 100%;
}
.image--round & {
border-radius: $border-radius-round;
}
.image--align-center & {
display: block;
margin-left: auto;
margin-right: auto;
}
}
.image__caption {
margin-top: 8px;
font-size: 14px;
line-height: 1.28;
}
import './image.scss';
<figure class="image image--align-right sg-image">
<img loading="lazy" src="' %}
{% set imgElement %}
<img
loading={% if eager and sizes %}"eager"{% else %}"lazy"{% endif %}
src="{{ placeholderSrc }}"
{% if eager and sizes %}
srcset="{{ data.srcset }}"
sizes="{{ sizes }}"
{% else %}
data-srcset="{{ data.srcset }}"
data-sizes="auto"
{% endif %}
alt="{{ data.alt }}"
{% if data.width %}width="{{ data.width }}"{% endif %}
{% if data.title %}title="{{ data.title }}"{% endif %}
class="image__img {% if not eager or not sizes %}lazyload{% endif %}"
>
{% endset %}
{% set image %}
{% if data.sources %}
<picture class="image__picture">
{% for source in data.sources %}
{% set sourcePlaceholder = source.aspectRatio ? '' %}
<source
srcset={% if eager and sizes %}"{{ source.srcset }}"{% else %}"{{ sourcePlaceholder }}"{% endif %}
data-srcset="{{ source.srcset }}"
media="{{ media[loop.index0] }}"
>
{% endfor %}
{{ imgElement }}
</picture>
{% else %}
{{ imgElement }}
{% endif %}
{% endset %}
<figure class="image {{ modifier }} {{ class }}">
{% if data.url %}
<a
class="image__link{% if data.anchorClass %} {{ data.anchorClass }}{% endif %}"
href="{{ data.url }}"
{% if data.target %}target="{{ data.target }}"{% endif %}
{% if data.rel %}rel="{{ data.rel }}"{% endif %}
{% if anchorAttributes %}{{ anchorAttributes }}{% endif %}
>
{{ image }}
</a>
{% else %}
{{ image }}
{% endif %}
{% if data.caption and not noCaption %}
<figcaption class="image__caption">{{ data.caption }}</figcaption>
{% endif %}
</figure>
{
"language": "en-US",
"class": "sg-image",
"data": {
"srcset": "//via.placeholder.com/100x100 100w, //via.placeholder.com/200x200 200w",
"alt": "image alt text",
"aspectRatio": {
"width": 100,
"height": 100
},
"width": 200
},
"modifier": "image--align-right"
}
.image--align-right {
float: right;
}
.image--align-left {
float: left;
}
.image__img {
display: block;
&.lazyload,
&.lazyloading {
opacity: 0;
transition: opacity $transition-duration $transition-easing;
}
&.lazyloaded {
opacity: 1;
transition: opacity $transition-duration $transition-easing;
}
.image--fluid & {
max-width: 100%;
height: auto;
}
.image--full & {
width: 100%;
}
.image--round & {
border-radius: $border-radius-round;
}
.image--align-center & {
display: block;
margin-left: auto;
margin-right: auto;
}
}
.image__caption {
margin-top: 8px;
font-size: 14px;
line-height: 1.28;
}
import './image.scss';
<figure class="image image--align-center sg-image">
<img loading="lazy" src="' %}
{% set imgElement %}
<img
loading={% if eager and sizes %}"eager"{% else %}"lazy"{% endif %}
src="{{ placeholderSrc }}"
{% if eager and sizes %}
srcset="{{ data.srcset }}"
sizes="{{ sizes }}"
{% else %}
data-srcset="{{ data.srcset }}"
data-sizes="auto"
{% endif %}
alt="{{ data.alt }}"
{% if data.width %}width="{{ data.width }}"{% endif %}
{% if data.title %}title="{{ data.title }}"{% endif %}
class="image__img {% if not eager or not sizes %}lazyload{% endif %}"
>
{% endset %}
{% set image %}
{% if data.sources %}
<picture class="image__picture">
{% for source in data.sources %}
{% set sourcePlaceholder = source.aspectRatio ? '' %}
<source
srcset={% if eager and sizes %}"{{ source.srcset }}"{% else %}"{{ sourcePlaceholder }}"{% endif %}
data-srcset="{{ source.srcset }}"
media="{{ media[loop.index0] }}"
>
{% endfor %}
{{ imgElement }}
</picture>
{% else %}
{{ imgElement }}
{% endif %}
{% endset %}
<figure class="image {{ modifier }} {{ class }}">
{% if data.url %}
<a
class="image__link{% if data.anchorClass %} {{ data.anchorClass }}{% endif %}"
href="{{ data.url }}"
{% if data.target %}target="{{ data.target }}"{% endif %}
{% if data.rel %}rel="{{ data.rel }}"{% endif %}
{% if anchorAttributes %}{{ anchorAttributes }}{% endif %}
>
{{ image }}
</a>
{% else %}
{{ image }}
{% endif %}
{% if data.caption and not noCaption %}
<figcaption class="image__caption">{{ data.caption }}</figcaption>
{% endif %}
</figure>
{
"language": "en-US",
"class": "sg-image",
"data": {
"srcset": "//via.placeholder.com/100x100 100w, //via.placeholder.com/200x200 200w",
"alt": "image alt text",
"aspectRatio": {
"width": 100,
"height": 100
},
"width": 200
},
"modifier": "image--align-center"
}
.image--align-right {
float: right;
}
.image--align-left {
float: left;
}
.image__img {
display: block;
&.lazyload,
&.lazyloading {
opacity: 0;
transition: opacity $transition-duration $transition-easing;
}
&.lazyloaded {
opacity: 1;
transition: opacity $transition-duration $transition-easing;
}
.image--fluid & {
max-width: 100%;
height: auto;
}
.image--full & {
width: 100%;
}
.image--round & {
border-radius: $border-radius-round;
}
.image--align-center & {
display: block;
margin-left: auto;
margin-right: auto;
}
}
.image__caption {
margin-top: 8px;
font-size: 14px;
line-height: 1.28;
}
import './image.scss';
<figure class="image image--full sg-image">
<img loading="lazy" src="' %}
{% set imgElement %}
<img
loading={% if eager and sizes %}"eager"{% else %}"lazy"{% endif %}
src="{{ placeholderSrc }}"
{% if eager and sizes %}
srcset="{{ data.srcset }}"
sizes="{{ sizes }}"
{% else %}
data-srcset="{{ data.srcset }}"
data-sizes="auto"
{% endif %}
alt="{{ data.alt }}"
{% if data.width %}width="{{ data.width }}"{% endif %}
{% if data.title %}title="{{ data.title }}"{% endif %}
class="image__img {% if not eager or not sizes %}lazyload{% endif %}"
>
{% endset %}
{% set image %}
{% if data.sources %}
<picture class="image__picture">
{% for source in data.sources %}
{% set sourcePlaceholder = source.aspectRatio ? '' %}
<source
srcset={% if eager and sizes %}"{{ source.srcset }}"{% else %}"{{ sourcePlaceholder }}"{% endif %}
data-srcset="{{ source.srcset }}"
media="{{ media[loop.index0] }}"
>
{% endfor %}
{{ imgElement }}
</picture>
{% else %}
{{ imgElement }}
{% endif %}
{% endset %}
<figure class="image {{ modifier }} {{ class }}">
{% if data.url %}
<a
class="image__link{% if data.anchorClass %} {{ data.anchorClass }}{% endif %}"
href="{{ data.url }}"
{% if data.target %}target="{{ data.target }}"{% endif %}
{% if data.rel %}rel="{{ data.rel }}"{% endif %}
{% if anchorAttributes %}{{ anchorAttributes }}{% endif %}
>
{{ image }}
</a>
{% else %}
{{ image }}
{% endif %}
{% if data.caption and not noCaption %}
<figcaption class="image__caption">{{ data.caption }}</figcaption>
{% endif %}
</figure>
{
"language": "en-US",
"class": "sg-image",
"data": {
"srcset": "//via.placeholder.com/100x100 100w, //via.placeholder.com/200x200 200w",
"alt": "image alt text",
"aspectRatio": {
"width": 100,
"height": 100
},
"width": 200
},
"modifier": "image--full"
}
.image--align-right {
float: right;
}
.image--align-left {
float: left;
}
.image__img {
display: block;
&.lazyload,
&.lazyloading {
opacity: 0;
transition: opacity $transition-duration $transition-easing;
}
&.lazyloaded {
opacity: 1;
transition: opacity $transition-duration $transition-easing;
}
.image--fluid & {
max-width: 100%;
height: auto;
}
.image--full & {
width: 100%;
}
.image--round & {
border-radius: $border-radius-round;
}
.image--align-center & {
display: block;
margin-left: auto;
margin-right: auto;
}
}
.image__caption {
margin-top: 8px;
font-size: 14px;
line-height: 1.28;
}
import './image.scss';
<figure class="image image--round sg-image">
<img loading="lazy" src="' %}
{% set imgElement %}
<img
loading={% if eager and sizes %}"eager"{% else %}"lazy"{% endif %}
src="{{ placeholderSrc }}"
{% if eager and sizes %}
srcset="{{ data.srcset }}"
sizes="{{ sizes }}"
{% else %}
data-srcset="{{ data.srcset }}"
data-sizes="auto"
{% endif %}
alt="{{ data.alt }}"
{% if data.width %}width="{{ data.width }}"{% endif %}
{% if data.title %}title="{{ data.title }}"{% endif %}
class="image__img {% if not eager or not sizes %}lazyload{% endif %}"
>
{% endset %}
{% set image %}
{% if data.sources %}
<picture class="image__picture">
{% for source in data.sources %}
{% set sourcePlaceholder = source.aspectRatio ? '' %}
<source
srcset={% if eager and sizes %}"{{ source.srcset }}"{% else %}"{{ sourcePlaceholder }}"{% endif %}
data-srcset="{{ source.srcset }}"
media="{{ media[loop.index0] }}"
>
{% endfor %}
{{ imgElement }}
</picture>
{% else %}
{{ imgElement }}
{% endif %}
{% endset %}
<figure class="image {{ modifier }} {{ class }}">
{% if data.url %}
<a
class="image__link{% if data.anchorClass %} {{ data.anchorClass }}{% endif %}"
href="{{ data.url }}"
{% if data.target %}target="{{ data.target }}"{% endif %}
{% if data.rel %}rel="{{ data.rel }}"{% endif %}
{% if anchorAttributes %}{{ anchorAttributes }}{% endif %}
>
{{ image }}
</a>
{% else %}
{{ image }}
{% endif %}
{% if data.caption and not noCaption %}
<figcaption class="image__caption">{{ data.caption }}</figcaption>
{% endif %}
</figure>
{
"language": "en-US",
"class": "sg-image",
"data": {
"srcset": "//via.placeholder.com/100x100 100w, //via.placeholder.com/200x200 200w",
"alt": "image alt text",
"aspectRatio": {
"width": 100,
"height": 100
},
"width": 200
},
"modifier": "image--round"
}
.image--align-right {
float: right;
}
.image--align-left {
float: left;
}
.image__img {
display: block;
&.lazyload,
&.lazyloading {
opacity: 0;
transition: opacity $transition-duration $transition-easing;
}
&.lazyloaded {
opacity: 1;
transition: opacity $transition-duration $transition-easing;
}
.image--fluid & {
max-width: 100%;
height: auto;
}
.image--full & {
width: 100%;
}
.image--round & {
border-radius: $border-radius-round;
}
.image--align-center & {
display: block;
margin-left: auto;
margin-right: auto;
}
}
.image__caption {
margin-top: 8px;
font-size: 14px;
line-height: 1.28;
}
import './image.scss';