aberdeen 1.7.1 → 1.7.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/aberdeen.js CHANGED
@@ -1107,7 +1107,7 @@ function setSpacingCssVars(base = 1, unit = "rem") {
1107
1107
  cssVars[i] = 2 ** (i - 3) * base + unit;
1108
1108
  }
1109
1109
  }
1110
- var CSS_VAR_PATTERN = /(\([^)]*\))|("[^"]*")|(^| )\$(\w+)/g;
1110
+ var CSS_VAR_PATTERN = /(\burl\([^)]*\))|("[^"]*")|(^| )\$(\w+)/g;
1111
1111
  var DIGIT_FIRST = /^\d/;
1112
1112
  function cssVarRef(value) {
1113
1113
  if (value.indexOf("$") < 0)
@@ -1119,27 +1119,6 @@ function cssVarRef(value) {
1119
1119
  return `${prefix}var(--${varName})`;
1120
1120
  });
1121
1121
  }
1122
- if (typeof document !== "undefined") {
1123
- leakScope(() => {
1124
- $(() => {
1125
- if (!isEmpty(cssVars)) {
1126
- mount(document.head, () => {
1127
- $("style", () => {
1128
- let css = `:root {
1129
- `;
1130
- for (const [key, value] of Object.entries(cssVars)) {
1131
- const varName = DIGIT_FIRST.test(String(key)) ? `m${key}` : key;
1132
- css += ` --${varName}: ${value};
1133
- `;
1134
- }
1135
- css += "}";
1136
- $(`#${css}`);
1137
- });
1138
- });
1139
- }
1140
- });
1141
- });
1142
- }
1143
1122
  var darkModeState;
1144
1123
  function darkMode() {
1145
1124
  if (!darkModeState) {
@@ -1362,10 +1341,15 @@ var cssCount = 0;
1362
1341
  function insertCss(style) {
1363
1342
  const prefix = `.AbdStl${++cssCount}`;
1364
1343
  const css = typeof style === "string" ? styleStringToCss(style, prefix) : objectToCss(style, prefix);
1365
- if (css)
1366
- $(`style#${css}`);
1344
+ if (css) {
1345
+ let cnt = cssSnippetCount++;
1346
+ cssSnippets[cnt] = css;
1347
+ clean(() => delete cssSnippets[cnt]);
1348
+ }
1367
1349
  return prefix;
1368
1350
  }
1351
+ var cssSnippets = proxy({});
1352
+ var cssSnippetCount = 0;
1369
1353
  function combinePrefixSelector(prefix, key) {
1370
1354
  const sel = [];
1371
1355
  for (const p of prefix.split(",")) {
@@ -1434,8 +1418,11 @@ function styleStringToCss(styleStr, selector) {
1434
1418
  }
1435
1419
  function insertGlobalCss(style) {
1436
1420
  const css = objectToCss(style, "");
1437
- if (css)
1438
- $(`style#${css}`);
1421
+ if (css) {
1422
+ let cnt = cssSnippetCount++;
1423
+ cssSnippets[cnt] = css;
1424
+ clean(() => delete cssSnippets[cnt]);
1425
+ }
1439
1426
  }
1440
1427
  var CSS_SHORT = {
1441
1428
  m: "margin",
@@ -1639,6 +1626,33 @@ function withEmitHandler(handler, func) {
1639
1626
  emit = oldEmitHandler;
1640
1627
  }
1641
1628
  }
1629
+ if (typeof document !== "undefined") {
1630
+ leakScope(() => {
1631
+ $(() => {
1632
+ if (isEmpty(cssSnippets) && isEmpty(cssVars))
1633
+ return;
1634
+ mount(document.head, () => {
1635
+ $("style.abd", () => {
1636
+ onEach(cssSnippets, (value) => {
1637
+ $("#", value);
1638
+ });
1639
+ $(() => {
1640
+ if (isEmpty(cssVars))
1641
+ return;
1642
+ let css = ":root{";
1643
+ for (const [key, value] of Object.entries(cssVars)) {
1644
+ const varName = DIGIT_FIRST.test(String(key)) ? `m${key}` : key;
1645
+ css += `--${varName}:${value};`;
1646
+ }
1647
+ css += `}
1648
+ `;
1649
+ $("#", css);
1650
+ });
1651
+ });
1652
+ });
1653
+ });
1654
+ });
1655
+ }
1642
1656
  export {
1643
1657
  withEmitHandler,
1644
1658
  unproxy,
@@ -1673,5 +1687,5 @@ export {
1673
1687
  $
1674
1688
  };
1675
1689
 
1676
- //# debugId=453EEBC759CEDD8964756E2164756E21
1690
+ //# debugId=35DE752A41396D7264756E2164756E21
1677
1691
  //# sourceMappingURL=aberdeen.js.map