152 lines
6.3 KiB
JavaScript
152 lines
6.3 KiB
JavaScript
"use strict";
|
|
|
|
Object.defineProperty(exports, "__esModule", {
|
|
value: true
|
|
});
|
|
exports.default = void 0;
|
|
var _path = _interopRequireDefault(require("path"));
|
|
var _utils = require("./utils");
|
|
var _options = _interopRequireDefault(require("./options.json"));
|
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
// eslint-disable-next-line consistent-return
|
|
const loader = function loader(content) {
|
|
if (this._compiler && this._compiler.options && this._compiler.options.experiments && this._compiler.options.experiments.css && this._module && (this._module.type === "css" || this._module.type === "css/global" || this._module.type === "css/module" || this._module.type === "css/auto")) {
|
|
return content;
|
|
}
|
|
};
|
|
loader.pitch = function pitch(request) {
|
|
if (this._compiler && this._compiler.options && this._compiler.options.experiments && this._compiler.options.experiments.css && this._module && (this._module.type === "css" || this._module.type === "css/global" || this._module.type === "css/module" || this._module.type === "css/auto")) {
|
|
this.emitWarning(new Error('You can\'t use `experiments.css` (`experiments.futureDefaults` enable built-in CSS support by default) and `style-loader` together, please set `experiments.css` to `false` or set `{ type: "javascript/auto" }` for rules with `style-loader` in your webpack config (now `style-loader` does nothing).'));
|
|
return;
|
|
}
|
|
const options = this.getOptions(_options.default);
|
|
const injectType = options.injectType || "styleTag";
|
|
const esModule = typeof options.esModule !== "undefined" ? options.esModule : true;
|
|
const runtimeOptions = {};
|
|
if (options.attributes) {
|
|
runtimeOptions.attributes = options.attributes;
|
|
}
|
|
if (options.base) {
|
|
runtimeOptions.base = options.base;
|
|
}
|
|
const insertType = typeof options.insert === "function" ? "function" : options.insert && _path.default.isAbsolute(options.insert) ? "module-path" : "selector";
|
|
const styleTagTransformType = typeof options.styleTagTransform === "function" ? "function" : options.styleTagTransform && _path.default.isAbsolute(options.styleTagTransform) ? "module-path" : "default";
|
|
switch (injectType) {
|
|
case "linkTag":
|
|
{
|
|
const hmrCode = this.hot ? (0, _utils.getLinkHmrCode)(esModule, this, request) : "";
|
|
|
|
// eslint-disable-next-line consistent-return
|
|
return `
|
|
${(0, _utils.getImportLinkAPICode)(esModule, this)}
|
|
${(0, _utils.getImportInsertBySelectorCode)(esModule, this, insertType, options)}
|
|
${(0, _utils.getImportLinkContentCode)(esModule, this, request)}
|
|
${esModule ? "" : `content = content.__esModule ? content.default : content;`}
|
|
|
|
var options = ${JSON.stringify(runtimeOptions)};
|
|
|
|
${(0, _utils.getInsertOptionCode)(insertType, options)}
|
|
|
|
var update = API(content, options);
|
|
|
|
${hmrCode}
|
|
|
|
${esModule ? "export default {}" : ""}`;
|
|
}
|
|
case "lazyStyleTag":
|
|
case "lazyAutoStyleTag":
|
|
case "lazySingletonStyleTag":
|
|
{
|
|
const isSingleton = injectType === "lazySingletonStyleTag";
|
|
const isAuto = injectType === "lazyAutoStyleTag";
|
|
const hmrCode = this.hot ? (0, _utils.getStyleHmrCode)(esModule, this, request, true) : "";
|
|
|
|
// eslint-disable-next-line consistent-return
|
|
return `
|
|
var exported = {};
|
|
|
|
${(0, _utils.getImportStyleAPICode)(esModule, this)}
|
|
${(0, _utils.getImportStyleDomAPICode)(esModule, this, isSingleton, isAuto)}
|
|
${(0, _utils.getImportInsertBySelectorCode)(esModule, this, insertType, options)}
|
|
${(0, _utils.getSetAttributesCode)(esModule, this, options)}
|
|
${(0, _utils.getImportInsertStyleElementCode)(esModule, this)}
|
|
${(0, _utils.getStyleTagTransformFnCode)(esModule, this, options, isSingleton, styleTagTransformType)}
|
|
${(0, _utils.getImportStyleContentCode)(esModule, this, request)}
|
|
${isAuto ? (0, _utils.getImportIsOldIECode)(esModule, this) : ""}
|
|
${esModule ? `if (content && content.locals) {
|
|
exported.locals = content.locals;
|
|
}
|
|
` : `content = content.__esModule ? content.default : content;
|
|
|
|
exported.locals = content.locals || {};`}
|
|
|
|
var refs = 0;
|
|
var update;
|
|
var options = ${JSON.stringify(runtimeOptions)};
|
|
|
|
${(0, _utils.getStyleTagTransformFn)(options, isSingleton)};
|
|
options.setAttributes = setAttributes;
|
|
${(0, _utils.getInsertOptionCode)(insertType, options)}
|
|
options.domAPI = ${(0, _utils.getdomAPI)(isAuto)};
|
|
options.insertStyleElement = insertStyleElement;
|
|
|
|
exported.use = function(insertOptions) {
|
|
options.options = insertOptions || {};
|
|
|
|
if (!(refs++)) {
|
|
update = API(content, options);
|
|
}
|
|
|
|
return exported;
|
|
};
|
|
exported.unuse = function() {
|
|
if (refs > 0 && !--refs) {
|
|
update();
|
|
update = null;
|
|
}
|
|
};
|
|
|
|
${hmrCode}
|
|
|
|
${(0, _utils.getExportLazyStyleCode)(esModule, this, request)}
|
|
`;
|
|
}
|
|
case "styleTag":
|
|
case "autoStyleTag":
|
|
case "singletonStyleTag":
|
|
default:
|
|
{
|
|
const isSingleton = injectType === "singletonStyleTag";
|
|
const isAuto = injectType === "autoStyleTag";
|
|
const hmrCode = this.hot ? (0, _utils.getStyleHmrCode)(esModule, this, request, false) : "";
|
|
|
|
// eslint-disable-next-line consistent-return
|
|
return `
|
|
${(0, _utils.getImportStyleAPICode)(esModule, this)}
|
|
${(0, _utils.getImportStyleDomAPICode)(esModule, this, isSingleton, isAuto)}
|
|
${(0, _utils.getImportInsertBySelectorCode)(esModule, this, insertType, options)}
|
|
${(0, _utils.getSetAttributesCode)(esModule, this, options)}
|
|
${(0, _utils.getImportInsertStyleElementCode)(esModule, this)}
|
|
${(0, _utils.getStyleTagTransformFnCode)(esModule, this, options, isSingleton, styleTagTransformType)}
|
|
${(0, _utils.getImportStyleContentCode)(esModule, this, request)}
|
|
${isAuto ? (0, _utils.getImportIsOldIECode)(esModule, this) : ""}
|
|
${esModule ? "" : `content = content.__esModule ? content.default : content;`}
|
|
|
|
var options = ${JSON.stringify(runtimeOptions)};
|
|
|
|
${(0, _utils.getStyleTagTransformFn)(options, isSingleton)};
|
|
options.setAttributes = setAttributes;
|
|
${(0, _utils.getInsertOptionCode)(insertType, options)}
|
|
options.domAPI = ${(0, _utils.getdomAPI)(isAuto)};
|
|
options.insertStyleElement = insertStyleElement;
|
|
|
|
var update = API(content, options);
|
|
|
|
${hmrCode}
|
|
|
|
${(0, _utils.getExportStyleCode)(esModule, this, request)}
|
|
`;
|
|
}
|
|
}
|
|
};
|
|
var _default = exports.default = loader; |