mirror of
https://github.com/owncast/owncast.git
synced 2024-10-10 19:16:02 +00:00
![dependabot[bot]](/assets/img/avatar_default.png)
* Commit updated Javascript packages * Bump preact from 10.5.4 to 10.5.5 in /build/javascript (#265) * Trying a new github workflow to install javascript packages * Bump tailwindcss from 1.9.2 to 1.9.4 in /build/javascript (#266) Bumps [tailwindcss](https://github.com/tailwindlabs/tailwindcss) from 1.9.2 to 1.9.4. - [Release notes](https://github.com/tailwindlabs/tailwindcss/releases) - [Changelog](https://github.com/tailwindlabs/tailwindcss/blob/master/CHANGELOG.md) - [Commits](https://github.com/tailwindlabs/tailwindcss/compare/v1.9.2...v1.9.4) Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> * Commit updated Javascript packages * Bump preact from 10.5.4 to 10.5.5 in /build/javascript Bumps [preact](https://github.com/preactjs/preact) from 10.5.4 to 10.5.5. - [Release notes](https://github.com/preactjs/preact/releases) - [Commits](https://github.com/preactjs/preact/compare/10.5.4...10.5.5) Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: Gabe Kangas <gabek@real-ity.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Owncast <owncast@owncast.online> * Bump @justinribeiro/lite-youtube in /build/javascript Bumps [@justinribeiro/lite-youtube](https://github.com/justinribeiro/lite-youtube) from 0.9.0 to 0.9.1. - [Release notes](https://github.com/justinribeiro/lite-youtube/releases) - [Commits](https://github.com/justinribeiro/lite-youtube/commits) Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: Owncast <owncast@owncast.online> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Gabe Kangas <gabek@real-ity.com>
129 lines
3.5 KiB
JavaScript
129 lines
3.5 KiB
JavaScript
const postcss = require("postcss");
|
|
const { parseRuleDefinition, getRuleParams } = require("./parseRule.js");
|
|
const parseDeclValue = require("./parseDeclValue.js");
|
|
const resolveId = require("./resolveId.js");
|
|
const load = require("./load.js");
|
|
|
|
function removeLoader(loader) {
|
|
if (!loader.error && loader.node.type === "atrule") {
|
|
loader.node.remove();
|
|
}
|
|
}
|
|
|
|
function applyInliner(inliner) {
|
|
if (!inliner.loader.error) {
|
|
inliner.valueNode.value = "url";
|
|
inliner.valueNode.nodes = [
|
|
{
|
|
type: "word",
|
|
value: inliner.loader.svg
|
|
}
|
|
];
|
|
}
|
|
}
|
|
|
|
function stringifyInliner(inliner) {
|
|
if (!inliner.loader.error) {
|
|
inliner.node.value = String(inliner.parsedValue);
|
|
}
|
|
}
|
|
|
|
module.exports = postcss.plugin(
|
|
"postcss-inline-svg",
|
|
(opts = {}) => (css, result) => {
|
|
const loadersMap = {};
|
|
const loaders = [];
|
|
const inliners = [];
|
|
|
|
css.walk(node => {
|
|
if (node.type === "atrule") {
|
|
if (node.name === "svg-load") {
|
|
try {
|
|
const file =
|
|
node.source && node.source.input && node.source.input.file;
|
|
const { name, url } = parseRuleDefinition(node.params);
|
|
const { params, selectors } = getRuleParams(node);
|
|
const loader = {
|
|
id: resolveId(file, url, opts),
|
|
parent: file,
|
|
params,
|
|
selectors,
|
|
node
|
|
};
|
|
loaders.push(loader);
|
|
loadersMap[name] = loader;
|
|
} catch (e) {
|
|
node.warn(result, e.message);
|
|
}
|
|
}
|
|
} else if (node.type === "decl") {
|
|
if (
|
|
node.value.indexOf("svg-load(") !== -1 ||
|
|
node.value.indexOf("svg-inline(") !== -1
|
|
) {
|
|
try {
|
|
const file =
|
|
node.source && node.source.input && node.source.input.file;
|
|
const statements = parseDeclValue(node.value);
|
|
statements.loaders.forEach(
|
|
({ url, params, valueNode, parsedValue }) => {
|
|
const loader = {
|
|
id: resolveId(file, url, opts),
|
|
parent: file,
|
|
params,
|
|
selectors: {},
|
|
node
|
|
};
|
|
loaders.push(loader);
|
|
inliners.push({
|
|
loader,
|
|
node,
|
|
valueNode,
|
|
parsedValue
|
|
});
|
|
}
|
|
);
|
|
statements.inliners.forEach(({ name, valueNode, parsedValue }) => {
|
|
const loader = loadersMap[name];
|
|
if (loader) {
|
|
inliners.push({
|
|
loader,
|
|
node,
|
|
valueNode,
|
|
parsedValue
|
|
});
|
|
} else {
|
|
node.warn(result, `"${name}" svg is not defined`);
|
|
}
|
|
});
|
|
} catch (e) {
|
|
node.warn(result, e.message);
|
|
}
|
|
}
|
|
}
|
|
});
|
|
|
|
const promises = loaders.map(loader => {
|
|
return load(loader.id, loader.params, loader.selectors, opts)
|
|
.then(code => {
|
|
loader.svg = code;
|
|
result.messages.push({
|
|
type: "dependency",
|
|
file: loader.id,
|
|
parent: loader.parent
|
|
});
|
|
})
|
|
.catch(err => {
|
|
loader.error = true;
|
|
loader.node.warn(result, err.message);
|
|
});
|
|
});
|
|
|
|
return Promise.all(promises).then(() => {
|
|
loaders.forEach(removeLoader);
|
|
inliners.forEach(applyInliner);
|
|
inliners.forEach(stringifyInliner);
|
|
});
|
|
}
|
|
);
|