css-in-js-engine-pb 0.1.0 → 0.1.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.
@@ -0,0 +1,11 @@
1
+ export declare enum StyleBucket {
2
+ Reset = 0,
3
+ Base = 1,
4
+ Appearance = 2,
5
+ Size = 3,
6
+ Shape = 4,
7
+ State = 5,
8
+ Focus = 6,
9
+ User = 7
10
+ }
11
+ //# sourceMappingURL=StyleBucket.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"StyleBucket.d.ts","sourceRoot":"","sources":["../src/StyleBucket.ts"],"names":[],"mappings":"AAAA,oBAAY,WAAW;IACnB,KAAK,IAAI;IACT,IAAI,IAAI;IACR,UAAU,IAAI;IACd,IAAI,IAAI;IACR,KAAK,IAAI;IACT,KAAK,IAAI;IACT,KAAK,IAAI;IACT,IAAI,IAAI;CACX"}
@@ -0,0 +1,11 @@
1
+ export var StyleBucket;
2
+ (function (StyleBucket) {
3
+ StyleBucket[StyleBucket["Reset"] = 0] = "Reset";
4
+ StyleBucket[StyleBucket["Base"] = 1] = "Base";
5
+ StyleBucket[StyleBucket["Appearance"] = 2] = "Appearance";
6
+ StyleBucket[StyleBucket["Size"] = 3] = "Size";
7
+ StyleBucket[StyleBucket["Shape"] = 4] = "Shape";
8
+ StyleBucket[StyleBucket["State"] = 5] = "State";
9
+ StyleBucket[StyleBucket["Focus"] = 6] = "Focus";
10
+ StyleBucket[StyleBucket["User"] = 7] = "User";
11
+ })(StyleBucket || (StyleBucket = {}));
@@ -0,0 +1,3 @@
1
+ import { StyleBucket } from './StyleBucket';
2
+ export declare function insertRulesWithBucket(rules: string[], bucket: StyleBucket): void;
3
+ //# sourceMappingURL=insertWithBucket.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"insertWithBucket.d.ts","sourceRoot":"","sources":["../src/insertWithBucket.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAiB5C,wBAAgB,qBAAqB,CACjC,KAAK,EAAE,MAAM,EAAE,EACf,MAAM,EAAE,WAAW,QAwBtB"}
@@ -0,0 +1,36 @@
1
+ import { insertRulesOnce } from './insertOnce';
2
+ import { StyleBucket } from './StyleBucket';
3
+ const bucketRules = new Map();
4
+ let highestFlushedBucket = -1;
5
+ const ORDER = [
6
+ StyleBucket.Reset,
7
+ StyleBucket.Base,
8
+ StyleBucket.Appearance,
9
+ StyleBucket.Size,
10
+ StyleBucket.Shape,
11
+ StyleBucket.State,
12
+ StyleBucket.Focus,
13
+ StyleBucket.User,
14
+ ];
15
+ export function insertRulesWithBucket(rules, bucket) {
16
+ if (!rules.length)
17
+ return;
18
+ const existing = bucketRules.get(bucket);
19
+ if (existing) {
20
+ existing.push(...rules);
21
+ }
22
+ else {
23
+ bucketRules.set(bucket, [...rules]);
24
+ }
25
+ const bucketIndex = ORDER.indexOf(bucket);
26
+ // Flush all buckets up to this one
27
+ for (let i = highestFlushedBucket + 1; i <= bucketIndex; i++) {
28
+ const b = ORDER[i];
29
+ const r = bucketRules.get(b);
30
+ if (r && r.length) {
31
+ insertRulesOnce(r);
32
+ bucketRules.set(b, []);
33
+ }
34
+ }
35
+ highestFlushedBucket = Math.max(highestFlushedBucket, bucketIndex);
36
+ }
@@ -1 +1 @@
1
- {"version":3,"file":"makeResetStyles.d.ts","sourceRoot":"","sources":["../src/makeResetStyles.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AAgDzC,wBAAgB,eAAe,CAAC,MAAM,EAAE,SAAS,SAGX,MAAM,CAa3C"}
1
+ {"version":3,"file":"makeResetStyles.d.ts","sourceRoot":"","sources":["../src/makeResetStyles.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AAiDzC,wBAAgB,eAAe,CAAC,MAAM,EAAE,SAAS,SAGX,MAAM,CAc3C"}
@@ -1,6 +1,7 @@
1
1
  import { camelToKebab, resolveValue } from './utils/css';
2
2
  import { hashString } from './utils/hash';
3
- import { insertRulesOnce } from './insertOnce';
3
+ import { insertRulesWithBucket } from './insertWithBucket';
4
+ import { StyleBucket } from './StyleBucket';
4
5
  const resetCache = new Map();
5
6
  function stringifyResetRule(selector, styles, atRule) {
6
7
  const rules = [];
@@ -38,7 +39,7 @@ export function makeResetStyles(styles) {
38
39
  const className = `r${hashString(signature)}`;
39
40
  const selector = `.${className}`;
40
41
  const rules = stringifyResetRule(selector, styles);
41
- insertRulesOnce(rules);
42
+ insertRulesWithBucket(rules, StyleBucket.Reset);
42
43
  resetCache.set(signature, className);
43
44
  return className;
44
45
  };
@@ -1 +1 @@
1
- {"version":3,"file":"makeStaticStyles.d.ts","sourceRoot":"","sources":["../src/makeStaticStyles.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AAwEzC,wBAAgB,gBAAgB,CAC5B,MAAM,EAAE,MAAM,GAAG,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,SAMP,IAAI,CAyB1C"}
1
+ {"version":3,"file":"makeStaticStyles.d.ts","sourceRoot":"","sources":["../src/makeStaticStyles.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AAyEzC,wBAAgB,gBAAgB,CAC5B,MAAM,EAAE,MAAM,GAAG,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,SAKP,IAAI,CAyB1C"}
@@ -1,5 +1,6 @@
1
1
  import { camelToKebab, resolveValue } from './utils/css';
2
- import { insertRulesOnce } from './insertOnce';
2
+ import { insertRulesWithBucket } from './insertWithBucket';
3
+ import { StyleBucket } from './StyleBucket';
3
4
  const staticCache = new Set();
4
5
  function stringifyStaticRule(selector, styles, atRule) {
5
6
  const rules = [];
@@ -46,9 +47,7 @@ function stringifyKeyframes(name, frames) {
46
47
  return `@keyframes ${name}{${blocks.join('')}}`;
47
48
  }
48
49
  export function makeStaticStyles(styles) {
49
- const signature = typeof styles === 'string'
50
- ? styles
51
- : JSON.stringify(styles);
50
+ const signature = typeof styles === 'string' ? styles : JSON.stringify(styles);
52
51
  return function useStaticStyles() {
53
52
  if (staticCache.has(signature))
54
53
  return;
@@ -65,7 +64,7 @@ export function makeStaticStyles(styles) {
65
64
  }
66
65
  rules.push(...stringifyStaticRule(selector, styles[selector]));
67
66
  }
68
- insertRulesOnce(rules);
67
+ insertRulesWithBucket(rules, StyleBucket.Base);
69
68
  }
70
69
  };
71
70
  }
@@ -1,3 +1,4 @@
1
1
  import type { StylesBySlots, ClassNamesBySlot } from './types';
2
- export declare function makeStyles<Slots extends string | number>(stylesBySlots: StylesBySlots<Slots>): () => ClassNamesBySlot<Slots>;
2
+ import { StyleBucket } from './StyleBucket';
3
+ export declare function makeStyles<Slots extends string | number>(stylesBySlots: StylesBySlots<Slots>, bucket?: StyleBucket): () => ClassNamesBySlot<Slots>;
3
4
  //# sourceMappingURL=makeStyles.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"makeStyles.d.ts","sourceRoot":"","sources":["../src/makeStyles.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;AAK/D,wBAAgB,UAAU,CAAC,KAAK,SAAS,MAAM,GAAG,MAAM,EACpD,aAAa,EAAE,aAAa,CAAC,KAAK,CAAC,SAON,gBAAgB,CAAC,KAAK,CAAC,CAevD"}
1
+ {"version":3,"file":"makeStyles.d.ts","sourceRoot":"","sources":["../src/makeStyles.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;AAG/D,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAG5C,wBAAgB,UAAU,CAAC,KAAK,SAAS,MAAM,GAAG,MAAM,EACpD,aAAa,EAAE,aAAa,CAAC,KAAK,CAAC,EACnC,MAAM,GAAE,WAAoC,SAOf,gBAAgB,CAAC,KAAK,CAAC,CAevD"}
@@ -1,7 +1,8 @@
1
1
  import { resolveStyleRulesForSlots } from './resolveStyleRules';
2
- import { insertRulesOnce } from './insertOnce';
3
2
  import { AtomicRuleCache } from './atomicCache';
4
- export function makeStyles(stylesBySlots) {
3
+ import { StyleBucket } from './StyleBucket';
4
+ import { insertRulesWithBucket } from './insertWithBucket';
5
+ export function makeStyles(stylesBySlots, bucket = StyleBucket.Appearance) {
5
6
  let cachedClassNames = null;
6
7
  let inserted = false;
7
8
  const atomicCache = new AtomicRuleCache();
@@ -10,7 +11,7 @@ export function makeStyles(stylesBySlots) {
10
11
  const { classNamesBySlot, cssRules } = resolveStyleRulesForSlots(stylesBySlots, atomicCache);
11
12
  cachedClassNames = classNamesBySlot;
12
13
  if (!inserted) {
13
- insertRulesOnce(cssRules);
14
+ insertRulesWithBucket(cssRules, bucket);
14
15
  inserted = true;
15
16
  }
16
17
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "css-in-js-engine-pb",
3
- "version": "0.1.0",
3
+ "version": "0.1.2",
4
4
  "description": "A lightweight atomic CSS-in-JS engine built on the native CSS cascade",
5
5
  "license": "MIT",
6
6
  "type": "module",