UNPKG

2.65 kBJavaScriptView Raw
1// src/observe/index.ts
2import {tw as defaultTW} from "twind";
3
4// src/internal/util.ts
5var ensureMaxSize = (map, max) => {
6 if (map.size > max) {
7 map.delete(map.keys().next().value);
8 }
9};
10var escape = typeof CSS !== "undefined" && CSS.escape || ((className) => className.replace(/[!"'`*+.,;:\\/<=>?@#$%&^|~()[\]{}]/g, "\\$&").replace(/^\d/, "\\3$& "));
11
12// src/observe/index.ts
13export * from "twind";
14var caches = new WeakMap();
15var 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};
23var uniq = (value, index, values) => values.indexOf(value) == index;
24var 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};
86function observe(target, config = typeof this == "function" ? void 0 : this) {
87 return createObserver(config).observe(target);
88}
89export {
90 createObserver,
91 observe
92};
93//# sourceMappingURL=observe.js.map