1 |
|
2 | import {tw as defaultTW} from "twind";
|
3 |
|
4 |
|
5 | var ensureMaxSize = (map, max) => {
|
6 | if (map.size > max) {
|
7 | map.delete(map.keys().next().value);
|
8 | }
|
9 | };
|
10 | var escape = typeof CSS !== "undefined" && CSS.escape || ((className) => className.replace(/[!"'`*+.,;:\\/<=>?@#$%&^|~()[\]{}]/g, "\\$&").replace(/^\d/, "\\3$& "));
|
11 |
|
12 |
|
13 | export * from "twind";
|
14 | var caches = new WeakMap();
|
15 | var getCache = (tw) => {
|
16 | let rulesToClassCache = caches.get(tw);
|
17 | if (!rulesToClassCache) {
|
18 | rulesToClassCache = new Map();
|
19 | caches.set(tw, rulesToClassCache);
|
20 | }
|
21 | return rulesToClassCache;
|
22 | };
|
23 | var uniq = (value, index, values) => values.indexOf(value) == index;
|
24 | var createObserver = ({tw = defaultTW} = {}) => {
|
25 | if (typeof MutationObserver == "function") {
|
26 | const rulesToClassCache = getCache(tw);
|
27 | const handleMutation = ({target, addedNodes}) => {
|
28 | var _a;
|
29 | const rules = (_a = target.getAttribute) == null ? void 0 : _a.call(target, "class");
|
30 | if (rules) {
|
31 | let className = rulesToClassCache.get(rules);
|
32 | if (!className) {
|
33 | className = tw(rules).split(/ +/g).filter(uniq).join(" ");
|
34 | rulesToClassCache.set(rules, className);
|
35 | rulesToClassCache.set(className, className);
|
36 | ensureMaxSize(rulesToClassCache, 3e4);
|
37 | }
|
38 | if (rules !== className) {
|
39 | ;
|
40 | target.setAttribute("class", className);
|
41 | }
|
42 | }
|
43 | for (let index = addedNodes.length; index--; ) {
|
44 | const node = addedNodes[index];
|
45 | handleMutations([
|
46 | {
|
47 | target: node,
|
48 | addedNodes: node.children || []
|
49 | }
|
50 | ]);
|
51 | }
|
52 | };
|
53 | const handleMutations = (mutations) => {
|
54 | mutations.forEach(handleMutation);
|
55 | mutations = observer.takeRecords();
|
56 | if (mutations)
|
57 | mutations.forEach(handleMutation);
|
58 | };
|
59 | const observer = new MutationObserver(handleMutations);
|
60 | return {
|
61 | observe(target) {
|
62 | handleMutations([{target, addedNodes: [target]}]);
|
63 | observer.observe(target, {
|
64 | attributes: true,
|
65 | attributeFilter: ["class"],
|
66 | subtree: true,
|
67 | childList: true
|
68 | });
|
69 | return this;
|
70 | },
|
71 | disconnect() {
|
72 | observer.disconnect();
|
73 | return this;
|
74 | }
|
75 | };
|
76 | }
|
77 | return {
|
78 | observe() {
|
79 | return this;
|
80 | },
|
81 | disconnect() {
|
82 | return this;
|
83 | }
|
84 | };
|
85 | };
|
86 | function observe(target, config = typeof this == "function" ? void 0 : this) {
|
87 | return createObserver(config).observe(target);
|
88 | }
|
89 | export {
|
90 | createObserver,
|
91 | observe
|
92 | };
|
93 |
|