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>
49 lines
1.0 KiB
JavaScript
49 lines
1.0 KiB
JavaScript
const valueParser = require("postcss-value-parser");
|
|
|
|
function parseRuleDefinition(params) {
|
|
const { nodes } = valueParser(params);
|
|
if (
|
|
nodes.length !== 3 ||
|
|
nodes[0].type !== "word" ||
|
|
nodes[1].type !== "space" ||
|
|
nodes[2].type !== "function" ||
|
|
nodes[2].value !== "url" ||
|
|
nodes[2].nodes.length === 0
|
|
) {
|
|
throw Error('Invalid "@svg-load" definition');
|
|
}
|
|
return {
|
|
name: nodes[0].value,
|
|
url: nodes[2].nodes[0].value
|
|
};
|
|
}
|
|
|
|
function getRuleParams(rule) {
|
|
const params = {};
|
|
const selectors = {};
|
|
|
|
rule.each(node => {
|
|
if (node.type === "decl") {
|
|
params[node.prop] = node.value;
|
|
} else if (node.type === "rule") {
|
|
const selector = selectors[node.selectors] || {};
|
|
node.each(child => {
|
|
if (child.type === "decl") {
|
|
selector[child.prop] = child.value;
|
|
}
|
|
});
|
|
selectors[node.selectors] = selector;
|
|
}
|
|
});
|
|
|
|
return {
|
|
params,
|
|
selectors
|
|
};
|
|
}
|
|
|
|
module.exports = {
|
|
parseRuleDefinition,
|
|
getRuleParams
|
|
};
|