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.
- package/dist/StyleBucket.d.ts +11 -0
- package/dist/StyleBucket.d.ts.map +1 -0
- package/dist/StyleBucket.js +11 -0
- package/dist/insertWithBucket.d.ts +3 -0
- package/dist/insertWithBucket.d.ts.map +1 -0
- package/dist/insertWithBucket.js +36 -0
- package/dist/makeResetStyles.d.ts.map +1 -1
- package/dist/makeResetStyles.js +3 -2
- package/dist/makeStaticStyles.d.ts.map +1 -1
- package/dist/makeStaticStyles.js +4 -5
- package/dist/makeStyles.d.ts +2 -1
- package/dist/makeStyles.d.ts.map +1 -1
- package/dist/makeStyles.js +4 -3
- package/package.json +1 -1
|
@@ -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 @@
|
|
|
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;
|
|
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"}
|
package/dist/makeResetStyles.js
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { camelToKebab, resolveValue } from './utils/css';
|
|
2
2
|
import { hashString } from './utils/hash';
|
|
3
|
-
import {
|
|
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
|
-
|
|
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;
|
|
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"}
|
package/dist/makeStaticStyles.js
CHANGED
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { camelToKebab, resolveValue } from './utils/css';
|
|
2
|
-
import {
|
|
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
|
-
|
|
67
|
+
insertRulesWithBucket(rules, StyleBucket.Base);
|
|
69
68
|
}
|
|
70
69
|
};
|
|
71
70
|
}
|
package/dist/makeStyles.d.ts
CHANGED
|
@@ -1,3 +1,4 @@
|
|
|
1
1
|
import type { StylesBySlots, ClassNamesBySlot } from './types';
|
|
2
|
-
|
|
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
|
package/dist/makeStyles.d.ts.map
CHANGED
|
@@ -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;
|
|
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"}
|
package/dist/makeStyles.js
CHANGED
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import { resolveStyleRulesForSlots } from './resolveStyleRules';
|
|
2
|
-
import { insertRulesOnce } from './insertOnce';
|
|
3
2
|
import { AtomicRuleCache } from './atomicCache';
|
|
4
|
-
|
|
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
|
-
|
|
14
|
+
insertRulesWithBucket(cssRules, bucket);
|
|
14
15
|
inserted = true;
|
|
15
16
|
}
|
|
16
17
|
}
|