53 lines
2.6 KiB
JavaScript
53 lines
2.6 KiB
JavaScript
|
"use strict";
|
||
|
Object.defineProperty(exports, "__esModule", {
|
||
|
value: true
|
||
|
});
|
||
|
Object.defineProperty(exports, "default", {
|
||
|
enumerable: true,
|
||
|
get: function() {
|
||
|
return _default;
|
||
|
}
|
||
|
});
|
||
|
function defaultLoader(param) {
|
||
|
let { config, src, width, quality } = param;
|
||
|
if (process.env.NODE_ENV !== "production") {
|
||
|
const missingValues = [];
|
||
|
// these should always be provided but make sure they are
|
||
|
if (!src) missingValues.push("src");
|
||
|
if (!width) missingValues.push("width");
|
||
|
if (missingValues.length > 0) {
|
||
|
throw new Error("Next Image Optimization requires " + missingValues.join(", ") + " to be provided. Make sure you pass them as props to the `next/image` component. Received: " + JSON.stringify({
|
||
|
src,
|
||
|
width,
|
||
|
quality
|
||
|
}));
|
||
|
}
|
||
|
if (src.startsWith("//")) {
|
||
|
throw new Error('Failed to parse src "' + src + '" on `next/image`, protocol-relative URL (//) must be changed to an absolute URL (http:// or https://)');
|
||
|
}
|
||
|
if (!src.startsWith("/") && (config.domains || config.remotePatterns)) {
|
||
|
let parsedSrc;
|
||
|
try {
|
||
|
parsedSrc = new URL(src);
|
||
|
} catch (err) {
|
||
|
console.error(err);
|
||
|
throw new Error('Failed to parse src "' + src + '" on `next/image`, if using relative image it must start with a leading slash "/" or be an absolute URL (http:// or https://)');
|
||
|
}
|
||
|
if (process.env.NODE_ENV !== "test" && // micromatch isn't compatible with edge runtime
|
||
|
process.env.NEXT_RUNTIME !== "edge") {
|
||
|
// We use dynamic require because this should only error in development
|
||
|
const { hasMatch } = require("./match-remote-pattern");
|
||
|
if (!hasMatch(config.domains, config.remotePatterns, parsedSrc)) {
|
||
|
throw new Error("Invalid src prop (" + src + ') on `next/image`, hostname "' + parsedSrc.hostname + '" is not configured under images in your `next.config.js`\n' + "See more info: https://nextjs.org/docs/messages/next-image-unconfigured-host");
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
return config.path + "?url=" + encodeURIComponent(src) + "&w=" + width + "&q=" + (quality || 75) + (process.env.NEXT_DEPLOYMENT_ID ? "&dpl=" + process.env.NEXT_DEPLOYMENT_ID : "");
|
||
|
}
|
||
|
// We use this to determine if the import is the default loader
|
||
|
// or a custom loader defined by the user in next.config.js
|
||
|
defaultLoader.__next_img_default = true;
|
||
|
const _default = defaultLoader;
|
||
|
|
||
|
//# sourceMappingURL=image-loader.js.map
|