imgix
The image processing capabilities of the imgix image CDN are supported by a helper function provided to you by this library.
Setup
Make sure you have the @responsive-image/cdn package installed:
npm install @responsive-image/cdnyarn add @responsive-image/cdnpnpm add @responsive-image/cdnYou need to specify your imgix domain in your configuration, which you can set up in your application (e.g. app.js):
import { setConfig } from '@responsive-image/core';
setConfig('cdn', {
imgix: {
domain: 'my-org.imgix.net',
},
});Usage
IMPORTANT
Please make sure you have read the section on remote images first.
Use the imgix provider function passing the reference to the image on the CDN and optional transcustom parametersformations, and pass the return value to the image component:
import { ResponsiveImage } from '@responsive-image/ember';
import { imgix } from '@responsive-image/cdn';
<template>
<ResponsiveImage @src={{imgix 'path/to/uploaded/image.jpg'}} />
</template><ResponsiveImage @src={{responsive-image-imgix 'path/to/uploaded/image.jpg'}} />import { LitElement, html } from 'lit';
import { customElement } from 'lit/decorators.js';
import { imgix } from '@responsive-image/cdn';
import '@responsive-image/wc';
@customElement('my-app')
export class MyApp extends LitElement {
render() {
return html`<responsive-image
.src=${imgix('path/to/uploaded/image.jpg')}
></responsive-image>`;
}
}import { ResponsiveImage } from '@responsive-image/react';
import { imgix } from '@responsive-image/cdn';
export default function MyApp() {
return <ResponsiveImage src={imgix('path/to/uploaded/image.jpg')} />;
}import { ResponsiveImage } from '@responsive-image/solid';
import { imgix } from '@responsive-image/cdn';
export default function MyApp() {
return <ResponsiveImage src={imgix('path/to/uploaded/image.jpg')} />;
}<script>
import { ResponsiveImage } from '@responsive-image/svelte';
import { imgix } from '@responsive-image/cdn';
</script>
<ResponsiveImage src={imgix('path/to/uploaded/image.jpg')} />Aspect Ratio
For the image component to be able to render width and height attributes to prevent layout shifts after loading has completed, it needs to know the aspect ratio of the source image. Unlike local images it cannot know this upfront for remote images, that's why it is recommended to supply the aspectRatio parameter if possible:
import { ResponsiveImage } from '@responsive-image/ember';
import { imgix } from '@responsive-image/cdn';
<template>
<ResponsiveImage
@src={{imgix
'/path/to/image.jpg'
aspectRatio=1.5
}}
/>
</template><ResponsiveImage
@src={{responsive-image-imgix '/path/to/image.jpg' aspectRatio=1.5}}
/>import { LitElement, html } from 'lit';
import { customElement } from 'lit/decorators.js';
import { imgix } from '@responsive-image/cdn';
import '@responsive-image/wc';
@customElement('my-app')
export class MyApp extends LitElement {
render() {
return html`<responsive-image
.src=${imgix('/path/to/image.jpg', {
aspectRatio: 1.5,
})}
></responsive-image>`;
}
}import { ResponsiveImage } from '@responsive-image/react';
import { imgix } from '@responsive-image/cdn';
export default function MyApp() {
return (
<ResponsiveImage
src={imgix('path/to/uploaded/image.jpg', {
aspectRatio: 1.5,
})}
/>
);
}import { ResponsiveImage } from '@responsive-image/solid';
import { imgix } from '@responsive-image/cdn';
export default function MyApp() {
return (
<ResponsiveImage
src={imgix('path/to/uploaded/image.jpg', {
aspectRatio: 1.5,
})}
/>
);
}<script>
import { ResponsiveImage } from '@responsive-image/svelte';
import { imgix } from '@responsive-image/cdn';
</script>
<ResponsiveImage
src={imgix('path/to/uploaded/image.jpg', {
aspectRatio: 1.5,
})}
/>Custom parameters
Besides the transformations that the addon itself implicitly adds (related to resizing images) you can add your own imgix parameters by passing a params object:
import { ResponsiveImage } from '@responsive-image/ember';
import { imgix } from '@responsive-image/cdn';
<template>
<ResponsiveImage
@src={{imgix
'path/to/uploaded/image.jpg'
params=(hash monochrome='44768B' px=10)
}}
/>
</template><ResponsiveImage
@src={{responsive-image-imgix
'path/to/uploaded/image.jpg'
params=(hash monochrome='44768B' px=10)
}}
/>import { LitElement, html } from 'lit';
import { customElement } from 'lit/decorators.js';
import { imgix } from '@responsive-image/cdn';
import '@responsive-image/wc';
@customElement('my-app')
export class MyApp extends LitElement {
render() {
return html`<responsive-image
.src=${imgix('path/to/uploaded/image.jpg', {
monochrome: '44768B',
px: 10,
})}
></responsive-image>`;
}
}import { ResponsiveImage } from '@responsive-image/react';
import { imgix } from '@responsive-image/cdn';
export default function MyApp() {
return (
<ResponsiveImage
src={imgix('path/to/uploaded/image.jpg', {
monochrome: '44768B',
px: 10,
})}
/>
);
}import { ResponsiveImage } from '@responsive-image/solid';
import { imgix } from '@responsive-image/cdn';
export default function MyApp() {
return (
<ResponsiveImage
src={imgix('path/to/uploaded/image.jpg', {
monochrome: '44768B',
px: 10,
})}
/>
);
}<script>
import { ResponsiveImage } from '@responsive-image/svelte';
import { imgix } from '@responsive-image/cdn';
</script>
<ResponsiveImage
src={imgix('path/to/uploaded/image.jpg', {
monochrome: '44768B',
px: 10,
})}
/>Quality
Use the quality parameter to pass a custom quality setting instead of the default auto:
import { ResponsiveImage } from '@responsive-image/ember';
import { imgix } from '@responsive-image/cdn';
<template>
<ResponsiveImage
@src={{imgix
'path/to/uploaded/image.jpg'
quality=50
}}
/>
</template><ResponsiveImage
@src={{responsive-image-imgix 'path/to/uploaded/image.jpg' quality=50}}
/>import { LitElement, html } from 'lit';
import { customElement } from 'lit/decorators.js';
import { imgix } from '@responsive-image/cdn';
import '@responsive-image/wc';
@customElement('my-app')
export class MyApp extends LitElement {
render() {
return html`<responsive-image
.src=${imgix('path/to/uploaded/image.jpg', {
quality: 50,
})}
></responsive-image>`;
}
}import { ResponsiveImage } from '@responsive-image/react';
import { imgix } from '@responsive-image/cdn';
export default function MyApp() {
return (
<ResponsiveImage
src={imgix('path/to/uploaded/image.jpg', {
quality: 50,
})}
/>
);
}import { ResponsiveImage } from '@responsive-image/solid';
import { imgix } from '@responsive-image/cdn';
export default function MyApp() {
return (
<ResponsiveImage
src={imgix('path/to/uploaded/image.jpg', {
quality: 50,
})}
/>
);
}<script>
import { ResponsiveImage } from '@responsive-image/svelte';
import { imgix } from '@responsive-image/cdn';
</script>
<ResponsiveImage
src={imgix('path/to/uploaded/image.jpg', {
quality: 50,
})}
/>Image formats
By default the component uses the automatic image format selection in Imgix.
If you want a picture tag with one or more specific formats as source tags you can specify them using the formats argument:
import { ResponsiveImage } from '@responsive-image/ember';
import { imgix } from '@responsive-image/cdn';
<template>
<ResponsiveImage
@src={{imgix
'path/to/uploaded/image.jpg'
formats=(array 'webp' 'avif')
}}
/>
</template><ResponsiveImage
@src={{responsive-image-imgix
'path/to/uploaded/image.jpg'
formats=(array 'webp' 'avif')
}}
/>import { LitElement, html } from 'lit';
import { customElement } from 'lit/decorators.js';
import { imgix } from '@responsive-image/cdn';
import '@responsive-image/wc';
@customElement('my-app')
export class MyApp extends LitElement {
render() {
return html`<responsive-image
.src=${imgix('path/to/uploaded/image.jpg', {
formats: ['webp', 'avif'],
})}
></responsive-image>`;
}
}import { ResponsiveImage } from '@responsive-image/react';
import { imgix } from '@responsive-image/cdn';
export default function MyApp() {
return (
<ResponsiveImage
src={imgix('path/to/uploaded/image.jpg', {
formats: ['webp', 'avif'],
})}
/>
);
}import { ResponsiveImage } from '@responsive-image/solid';
import { imgix } from '@responsive-image/cdn';
export default function MyApp() {
return (
<ResponsiveImage
src={imgix('path/to/uploaded/image.jpg', {
formats: ['webp', 'avif'],
})}
/>
);
}<script>
import { ResponsiveImage } from '@responsive-image/svelte';
import { imgix } from '@responsive-image/cdn';
</script>
<ResponsiveImage
src={imgix('path/to/uploaded/image.jpg', {
formats: ['webp', 'avif'],
})}
/>