mirror of
https://github.com/notion-enhancer/notion-enhancer.git
synced 2025-04-05 13:19:03 +00:00
134 lines
5.0 KiB
JavaScript
134 lines
5.0 KiB
JavaScript
/**
|
|
* Twind v0.16.16
|
|
* @license MIT
|
|
* @source https://unpkg.com/twind@0.16.16/css/css.js?module
|
|
*/
|
|
|
|
// src/css/index.ts
|
|
import { apply, hash, directive } from "./twind.mjs";
|
|
|
|
// src/internal/util.ts
|
|
var includes = (value, search) => !!~value.indexOf(search);
|
|
var join = (parts, separator = "-") => parts.join(separator);
|
|
var hyphenate = value => value.replace(/[A-Z]/g, "-$&").toLowerCase();
|
|
var evalThunk = (value, context) => {
|
|
while (typeof value == "function") {
|
|
value = value(context);
|
|
}
|
|
return value;
|
|
};
|
|
var isCSSProperty = (key, value) => !includes("@:&", key[0]) && (includes("rg", (typeof value)[5]) || Array.isArray(value));
|
|
var merge = (target, source, context) => source ? Object.keys(source).reduce((target2, key) => {
|
|
const value = evalThunk(source[key], context);
|
|
if (isCSSProperty(key, value)) {
|
|
target2[hyphenate(key)] = value;
|
|
} else {
|
|
target2[key] = key[0] == "@" && includes("figa", key[1]) ? (target2[key] || []).concat(value) : merge(target2[key] || {}, value, context);
|
|
}
|
|
return target2;
|
|
}, target) : target;
|
|
var escape = typeof CSS !== "undefined" && CSS.escape || (className => className.replace(/[!"'`*+.,;:\\/<=>?@#$%&^|~()[\]{}]/g, "\\$&").replace(/^\d/, "\\3$& "));
|
|
var buildMediaQuery = screen2 => {
|
|
if (!Array.isArray(screen2)) {
|
|
screen2 = [screen2];
|
|
}
|
|
return "@media " + join(screen2.map(screen3 => {
|
|
if (typeof screen3 == "string") {
|
|
screen3 = { min: screen3 };
|
|
}
|
|
return screen3.raw || join(Object.keys(screen3).map(feature => `(${feature}-width:${screen3[feature]})`), " and ");
|
|
}), ",");
|
|
};
|
|
|
|
// src/css/index.ts
|
|
var translate = (tokens, context) => {
|
|
const collect = (target, token) => Array.isArray(token) ? token.reduce(collect, target) : merge(target, evalThunk(token, context), context);
|
|
return tokens.reduce(collect, {});
|
|
};
|
|
var newRule = /\s*(?:([\w-%@]+)\s*:?\s*([^{;]+?)\s*(?:;|$|})|([^;}{]*?)\s*{)|(})/gi;
|
|
var ruleClean = /\/\*[\s\S]*?\*\/|\s+|\n/gm;
|
|
var decorate = (selectors, currentBlock) => selectors.reduceRight((rules, selector) => ({ [selector]: rules }), currentBlock);
|
|
var saveBlock = (rules, selectors, currentBlock) => {
|
|
if (currentBlock) {
|
|
rules.push(decorate(selectors, currentBlock));
|
|
}
|
|
};
|
|
var interleave = (strings, interpolations, context) => {
|
|
let buffer = strings[0];
|
|
const result = [];
|
|
for (let index = 0; index < interpolations.length;) {
|
|
const interpolation = evalThunk(interpolations[index], context);
|
|
if (interpolation && typeof interpolation == "object") {
|
|
result.push(buffer, interpolation);
|
|
buffer = strings[++index];
|
|
} else {
|
|
buffer += (interpolation || "") + strings[++index];
|
|
}
|
|
}
|
|
result.push(buffer);
|
|
return result;
|
|
};
|
|
var astish = (values, context) => {
|
|
const selectors = [];
|
|
const rules = [];
|
|
let currentBlock;
|
|
let match;
|
|
for (let index = 0; index < values.length; index++) {
|
|
const value = values[index];
|
|
if (typeof value == "string") {
|
|
while (match = newRule.exec(value.replace(ruleClean, " "))) {
|
|
if (!match[0])
|
|
continue;
|
|
if (match[4]) {
|
|
currentBlock = saveBlock(rules, selectors, currentBlock);
|
|
selectors.pop();
|
|
}
|
|
if (match[3]) {
|
|
currentBlock = saveBlock(rules, selectors, currentBlock);
|
|
selectors.push(match[3]);
|
|
} else if (!match[4]) {
|
|
if (!currentBlock)
|
|
currentBlock = {};
|
|
const value2 = match[2] && /\S/.test(match[2]) ? match[2] : values[++index];
|
|
if (value2) {
|
|
if (match[1] == "@apply") {
|
|
merge(currentBlock, evalThunk(apply(value2), context), context);
|
|
} else {
|
|
currentBlock[match[1]] = value2;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
} else {
|
|
currentBlock = saveBlock(rules, selectors, currentBlock);
|
|
rules.push(decorate(selectors, value));
|
|
}
|
|
}
|
|
saveBlock(rules, selectors, currentBlock);
|
|
return rules;
|
|
};
|
|
var cssFactory = (tokens, context) => translate(Array.isArray(tokens[0]) && Array.isArray(tokens[0].raw) ? astish(interleave(tokens[0], tokens.slice(1), context), context) : tokens, context);
|
|
var css = (...tokens) => directive(cssFactory, tokens);
|
|
var keyframesFactory = (tokens, context) => {
|
|
const waypoints = cssFactory(tokens, context);
|
|
const id = hash(JSON.stringify(waypoints));
|
|
context.tw(() => ({ [`@keyframes ${id}`]: waypoints }));
|
|
return id;
|
|
};
|
|
var keyframes = (...tokens) => directive(keyframesFactory, tokens);
|
|
var animation = (value, waypoints) => waypoints === void 0 ? (...args) => animation(value, keyframes(...args)) : css({
|
|
...(value && typeof value == "object" ? value : { animation: value }),
|
|
animationName: typeof waypoints == "function" ? waypoints : keyframes(waypoints) });
|
|
|
|
var screenFactory = ({ size, rules }, context) => {
|
|
const media = buildMediaQuery(context.theme("screens", size));
|
|
return rules === void 0 ? media : {
|
|
[media]: typeof rules == "function" ? evalThunk(rules, context) : cssFactory([rules], context) };
|
|
|
|
};
|
|
var screen = (size, rules) => directive(screenFactory, { size, rules });
|
|
export {
|
|
animation,
|
|
css,
|
|
keyframes,
|
|
screen }; |