@prismicio/client
Version:
The official JavaScript + TypeScript client library for Prismic
79 lines (77 loc) • 2.88 kB
JavaScript
const require_isFilled = require('./isFilled.cjs');
let imgix_url_builder = require("imgix-url-builder");
//#region src/helpers/asImageWidthSrcSet.ts
/**
* The default widths used to generate a `srcset` value.
*/
const DEFAULT_WIDTHS = [
640,
828,
1200,
2048,
3840
];
/**
* Creates a width-based `srcset` from an image field with optional image
* transformations via imgix URL parameters.
*
* If a `widths` parameter is not given, the following widths (in pixels) will
* be used by default: 640, 750, 828, 1080, 1200, 1920, 2048, 3840.
*
* If the image field contains responsive views, each responsive view can be
* used as a width in the resulting `srcset` by passing `"thumbnails"` as the
* `widths` parameter.
*
* @example
*
* ```ts
* const srcset = asImageWidthSrcSet(document.data.photo, {
* widths: [400, 800, 1600],
* sat: -100,
* })
* // => {
* // src: "https://images.prismic.io/repo/image.png?sat=-100",
* // srcset: "https://images.prismic.io/repo/image.png?sat=-100&width=400 400w, " +
* // "https://images.prismic.io/repo/image.png?sat=-100&width=800 800w, " +
* // "https://images.prismic.io/repo/image.png?sat=-100&width=1600 1600w"
* // }
* ```
*
* @param field - An image field (or one of its responsive views) from which to
* get an image URL.
* @param config - An object of imgix URL API parameters. The `widths` parameter
* defines the resulting `srcset` widths. Pass `"thumbnails"` to automatically
* use the field's responsive views.
*
* @returns A `srcset` attribute value for the image field with imgix URL
* parameters, or `null` if the field is empty.
*
* @see Learn how to optimize images with imgix: {@link https://prismic.io/docs/fields/image}
* @see imgix URL parameters reference: {@link https://docs.imgix.com/apis/rendering}
*/
const asImageWidthSrcSet = (field, config = {}) => {
if (field && require_isFilled.imageThumbnail(field)) {
let { widths = DEFAULT_WIDTHS,...imgixParams } = config;
const { url, dimensions, id: _id, alt: _alt, copyright: _copyright, edit: _edit,...responsiveViews } = field;
const responsiveViewObjects = Object.values(responsiveViews);
if (widths === "thumbnails" && responsiveViewObjects.length < 1) widths = DEFAULT_WIDTHS;
return {
src: (0, imgix_url_builder.buildURL)(url, imgixParams),
srcset: widths === "thumbnails" ? [(0, imgix_url_builder.buildWidthSrcSet)(url, {
...imgixParams,
widths: [dimensions.width]
}), ...responsiveViewObjects.map((thumbnail) => {
return (0, imgix_url_builder.buildWidthSrcSet)(thumbnail.url, {
...imgixParams,
widths: [thumbnail.dimensions.width]
});
})].join(", ") : (0, imgix_url_builder.buildWidthSrcSet)(field.url, {
...imgixParams,
widths
})
};
} else return null;
};
//#endregion
exports.asImageWidthSrcSet = asImageWidthSrcSet;
//# sourceMappingURL=asImageWidthSrcSet.cjs.map