@codefast/image-loader
Version:
Flexible image loader for Next.js supporting multiple CDN providers
78 lines (77 loc) • 2.64 kB
JavaScript
;
var __webpack_require__ = {};
(()=>{
__webpack_require__.n = (module)=>{
var getter = module && module.__esModule ? ()=>module['default'] : ()=>module;
__webpack_require__.d(getter, {
a: getter
});
return getter;
};
})();
(()=>{
__webpack_require__.d = (exports1, definition)=>{
for(var key in definition)if (__webpack_require__.o(definition, key) && !__webpack_require__.o(exports1, key)) Object.defineProperty(exports1, key, {
enumerable: true,
get: definition[key]
});
};
})();
(()=>{
__webpack_require__.o = (obj, prop)=>Object.prototype.hasOwnProperty.call(obj, prop);
})();
(()=>{
__webpack_require__.r = (exports1)=>{
if ('undefined' != typeof Symbol && Symbol.toStringTag) Object.defineProperty(exports1, Symbol.toStringTag, {
value: 'Module'
});
Object.defineProperty(exports1, '__esModule', {
value: true
});
};
})();
var __webpack_exports__ = {};
__webpack_require__.r(__webpack_exports__);
__webpack_require__.d(__webpack_exports__, {
ImgixLoader: ()=>ImgixLoader
});
const external_query_string_namespaceObject = require("query-string");
var external_query_string_default = /*#__PURE__*/ __webpack_require__.n(external_query_string_namespaceObject);
const external_base_loader_cjs_namespaceObject = require("../base-loader.cjs");
class ImgixLoader extends external_base_loader_cjs_namespaceObject.BaseImageLoader {
static DOMAIN_PATTERN = /\.imgix\.net$/;
static NAME = "imgix";
getName() {
return ImgixLoader.NAME;
}
canHandle(source) {
const domain = this.extractDomain(source);
return ImgixLoader.DOMAIN_PATTERN.test(domain);
}
transformUrl(config) {
const { quality, src, width } = config;
try {
const params = {
auto: "format,compress",
crop: "faces,entropy",
fit: "crop",
q: quality,
w: width
};
return external_query_string_default().stringifyUrl({
query: params,
url: src
});
} catch (error) {
console.warn(`Failed to transform Imgix URL: ${src}`, error);
return src;
}
}
}
exports.ImgixLoader = __webpack_exports__.ImgixLoader;
for(var __webpack_i__ in __webpack_exports__)if (-1 === [
"ImgixLoader"
].indexOf(__webpack_i__)) exports[__webpack_i__] = __webpack_exports__[__webpack_i__];
Object.defineProperty(exports, '__esModule', {
value: true
});