@tenphi/tasty 2.2.0 → 2.3.1
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/README.md +4 -1
- package/dist/{collector-LuU1vZ68.d.ts → collector-BQHl-atL.d.ts} +12 -2
- package/dist/{collector-MOYY2SOr.js → collector-DROCOiaT.js} +24 -11
- package/dist/collector-DROCOiaT.js.map +1 -0
- package/dist/{config-vuCRkBWX.d.ts → config-CzzTHmtS.d.ts} +48 -4
- package/dist/{config-A237aY9H.js → config-JokB1Lc8.js} +193 -77
- package/dist/config-JokB1Lc8.js.map +1 -0
- package/dist/core/index.d.ts +5 -5
- package/dist/core/index.js +6 -6
- package/dist/{core-BkKav78f.js → core-CW4XEUFk.js} +18 -12
- package/dist/core-CW4XEUFk.js.map +1 -0
- package/dist/{css-writer-Cos9tQRM.js → css-writer-Jv468wSl.js} +28 -6
- package/dist/css-writer-Jv468wSl.js.map +1 -0
- package/dist/{format-rules-C2oiTsEO.js → format-rules-B0vbh8Qz.js} +2 -2
- package/dist/{format-rules-C2oiTsEO.js.map → format-rules-B0vbh8Qz.js.map} +1 -1
- package/dist/{hydrate-miFzWIKR.js → hydrate-BO6nlAeD.js} +2 -2
- package/dist/{hydrate-miFzWIKR.js.map → hydrate-BO6nlAeD.js.map} +1 -1
- package/dist/{index-dUtwpOux.d.ts → index-Dy74C11K.d.ts} +8 -1
- package/dist/{index-ZRxZWzlj.d.ts → index-mWACW3QW.d.ts} +32 -6
- package/dist/index.d.ts +5 -5
- package/dist/index.js +10 -10
- package/dist/index.js.map +1 -1
- package/dist/{keyframes-DDtNo_hl.js → keyframes-J_JNrpdh.js} +3 -2
- package/dist/{keyframes-DDtNo_hl.js.map → keyframes-J_JNrpdh.js.map} +1 -1
- package/dist/{merge-styles-CtDJMhpJ.d.ts → merge-styles-BS-mpcci.d.ts} +2 -2
- package/dist/{merge-styles-D_HbBOlq.js → merge-styles-Du-eC7zp.js} +2 -2
- package/dist/{merge-styles-D_HbBOlq.js.map → merge-styles-Du-eC7zp.js.map} +1 -1
- package/dist/{resolve-recipes-B7-823LL.js → resolve-recipes-DPRT3FMM.js} +3 -3
- package/dist/{resolve-recipes-B7-823LL.js.map → resolve-recipes-DPRT3FMM.js.map} +1 -1
- package/dist/ssr/astro-client.js +1 -1
- package/dist/ssr/astro.js +3 -3
- package/dist/ssr/astro.js.map +1 -1
- package/dist/ssr/index.d.ts +1 -1
- package/dist/ssr/index.js +3 -3
- package/dist/ssr/next.d.ts +1 -1
- package/dist/ssr/next.js +4 -4
- package/dist/ssr/next.js.map +1 -1
- package/dist/static/index.d.ts +2 -2
- package/dist/static/index.js +1 -1
- package/dist/static/index.js.map +1 -1
- package/dist/zero/babel.d.ts +1 -1
- package/dist/zero/babel.js +16 -8
- package/dist/zero/babel.js.map +1 -1
- package/dist/zero/index.d.ts +1 -1
- package/dist/zero/index.js +1 -1
- package/docs/configuration.md +44 -0
- package/docs/dsl.md +13 -11
- package/docs/ssr.md +5 -3
- package/docs/tasty-static.md +15 -0
- package/package.json +1 -1
- package/dist/collector-MOYY2SOr.js.map +0 -1
- package/dist/config-A237aY9H.js.map +0 -1
- package/dist/core-BkKav78f.js.map +0 -1
- package/dist/css-writer-Cos9tQRM.js.map +0 -1
package/README.md
CHANGED
|
@@ -6,7 +6,7 @@
|
|
|
6
6
|
|
|
7
7
|
<p align="center">
|
|
8
8
|
<strong>Deterministic styling for stateful component systems.</strong><br>
|
|
9
|
-
A design-system styling engine that compiles component states into mutually exclusive selectors.
|
|
9
|
+
A design-system styling engine that compiles component states into mutually exclusive selectors, so complex components stay predictable as they evolve.
|
|
10
10
|
</p>
|
|
11
11
|
|
|
12
12
|
<p align="center">
|
|
@@ -23,6 +23,8 @@ It compiles state maps into **mutually exclusive selectors**, so for a given pro
|
|
|
23
23
|
|
|
24
24
|
That is the core guarantee: component styling resolves from declared state logic, not from source-order accidents or specificity fights.
|
|
25
25
|
|
|
26
|
+
The practical payoff shows up later: adding states, variants, and overrides stays inside the state map instead of reopening selector logic by hand.
|
|
27
|
+
|
|
26
28
|
Tasty fits best when you are building a design system or component library with intersecting states, variants, tokens, sub-elements, responsive rules, and extension semantics that need to stay predictable over time.
|
|
27
29
|
|
|
28
30
|
On top of that foundation, Tasty gives teams a governed styling model: a CSS-like DSL, tokens, recipes, typed style props, sub-elements, and multiple rendering modes.
|
|
@@ -35,6 +37,7 @@ On top of that foundation, Tasty gives teams a governed styling model: a CSS-lik
|
|
|
35
37
|
## Why Tasty
|
|
36
38
|
|
|
37
39
|
- **Deterministic composition, not cascade fights** — Stateful styles resolve from the state map you declared, not from selector competition. See [How It Actually Works](#how-it-actually-works).
|
|
40
|
+
- **Easier to extend over time** — When components gain new states, variants, or overrides, you update declared branches instead of re-deriving selector interactions by hand.
|
|
38
41
|
- **Built for design-system teams** — Best fit for reusable component systems with complex state interactions.
|
|
39
42
|
- **A governed styling model, not just syntax sugar** — Design-system authors define the styling language product teams consume.
|
|
40
43
|
- **DSL that still feels like CSS** — Familiar property names, less selector boilerplate. Start with the [Style DSL](docs/dsl.md), then use [Style Properties](docs/styles.md) as the handler reference.
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { n as StyleResult } from "./index-
|
|
1
|
+
import { n as StyleResult } from "./index-Dy74C11K.js";
|
|
2
2
|
|
|
3
3
|
//#region src/ssr/collector.d.ts
|
|
4
4
|
declare class ServerStyleCollector {
|
|
@@ -20,6 +20,16 @@ declare class ServerStyleCollector {
|
|
|
20
20
|
private keyframesCounter;
|
|
21
21
|
private counterStyleCounter;
|
|
22
22
|
private internalsCollected;
|
|
23
|
+
private namePrefix;
|
|
24
|
+
/**
|
|
25
|
+
* @param namePrefix - Optional override for the configured prefix.
|
|
26
|
+
* Defaults to the value from `configure({ namePrefix })` (or `'t'`).
|
|
27
|
+
* Pass an explicit prefix when constructing a collector outside the
|
|
28
|
+
* normal configure() lifecycle (e.g. in tests). Validated eagerly
|
|
29
|
+
* so misconfiguration fails before any CSS is collected.
|
|
30
|
+
*/
|
|
31
|
+
constructor(namePrefix?: string);
|
|
32
|
+
private generateClassName;
|
|
23
33
|
/**
|
|
24
34
|
* Collect internal @property rules and :root token defaults.
|
|
25
35
|
* Mirrors markStylesGenerated() from the client-side injector.
|
|
@@ -95,4 +105,4 @@ declare class ServerStyleCollector {
|
|
|
95
105
|
}
|
|
96
106
|
//#endregion
|
|
97
107
|
export { ServerStyleCollector as t };
|
|
98
|
-
//# sourceMappingURL=collector-
|
|
108
|
+
//# sourceMappingURL=collector-BQHl-atL.d.ts.map
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { F as formatFontFaceRule,
|
|
2
|
-
import { n as formatPropertyCSS, t as formatRules } from "./format-rules-
|
|
1
|
+
import { F as fontFaceContentHash, I as formatFontFaceRule, M as formatCounterStyleRule, S as renderStyles, a as getGlobalCounterStyle, d as getNamePrefix, dt as makeCounterStyleName, ft as makeKeyframeName, gt as hashString, i as getGlobalConfigTokens, mt as validateNamePrefix, o as getGlobalFontFace, r as getEffectiveProperties, u as getGlobalStyles, ut as makeClassName } from "./config-JokB1Lc8.js";
|
|
2
|
+
import { n as formatPropertyCSS, t as formatRules } from "./format-rules-B0vbh8Qz.js";
|
|
3
3
|
import { t as formatGlobalRules } from "./format-global-rules-Dbc_1tc3.js";
|
|
4
4
|
//#region src/ssr/collector.ts
|
|
5
5
|
/**
|
|
@@ -7,15 +7,13 @@ import { t as formatGlobalRules } from "./format-global-rules-Dbc_1tc3.js";
|
|
|
7
7
|
*
|
|
8
8
|
* Accumulates CSS rules and cache metadata during server rendering.
|
|
9
9
|
* This is the server-side counterpart to StyleInjector: it allocates
|
|
10
|
-
* hash-based class names
|
|
11
|
-
*
|
|
10
|
+
* hash-based class names using the configured `namePrefix` (defaults
|
|
11
|
+
* to `'t'`), formats CSS rules into text, and tracks rendered class
|
|
12
|
+
* names for lightweight client transfer.
|
|
12
13
|
*
|
|
13
14
|
* One instance is created per HTTP request. Concurrent requests
|
|
14
15
|
* each get their own collector (via AsyncLocalStorage or React context).
|
|
15
16
|
*/
|
|
16
|
-
function generateClassName(cacheKey) {
|
|
17
|
-
return `t${hashString(cacheKey)}`;
|
|
18
|
-
}
|
|
19
17
|
var ServerStyleCollector = class {
|
|
20
18
|
chunks = /* @__PURE__ */ new Map();
|
|
21
19
|
cacheKeyToClassName = /* @__PURE__ */ new Map();
|
|
@@ -35,6 +33,21 @@ var ServerStyleCollector = class {
|
|
|
35
33
|
keyframesCounter = 0;
|
|
36
34
|
counterStyleCounter = 0;
|
|
37
35
|
internalsCollected = false;
|
|
36
|
+
namePrefix;
|
|
37
|
+
/**
|
|
38
|
+
* @param namePrefix - Optional override for the configured prefix.
|
|
39
|
+
* Defaults to the value from `configure({ namePrefix })` (or `'t'`).
|
|
40
|
+
* Pass an explicit prefix when constructing a collector outside the
|
|
41
|
+
* normal configure() lifecycle (e.g. in tests). Validated eagerly
|
|
42
|
+
* so misconfiguration fails before any CSS is collected.
|
|
43
|
+
*/
|
|
44
|
+
constructor(namePrefix) {
|
|
45
|
+
if (namePrefix !== void 0) validateNamePrefix(namePrefix);
|
|
46
|
+
this.namePrefix = namePrefix ?? getNamePrefix();
|
|
47
|
+
}
|
|
48
|
+
generateClassName(cacheKey) {
|
|
49
|
+
return makeClassName(this.namePrefix, hashString(cacheKey));
|
|
50
|
+
}
|
|
38
51
|
/**
|
|
39
52
|
* Collect internal @property rules and :root token defaults.
|
|
40
53
|
* Mirrors markStylesGenerated() from the client-side injector.
|
|
@@ -94,7 +107,7 @@ var ServerStyleCollector = class {
|
|
|
94
107
|
className: existing,
|
|
95
108
|
isNewAllocation: false
|
|
96
109
|
};
|
|
97
|
-
const className = generateClassName(cacheKey);
|
|
110
|
+
const className = this.generateClassName(cacheKey);
|
|
98
111
|
this.cacheKeyToClassName.set(cacheKey, className);
|
|
99
112
|
return {
|
|
100
113
|
className,
|
|
@@ -126,7 +139,7 @@ var ServerStyleCollector = class {
|
|
|
126
139
|
* Allocate a keyframe name for SSR. Uses provided name or generates one.
|
|
127
140
|
*/
|
|
128
141
|
allocateKeyframeName(providedName) {
|
|
129
|
-
return providedName ??
|
|
142
|
+
return providedName ?? makeKeyframeName(this.namePrefix, String(this.keyframesCounter++));
|
|
130
143
|
}
|
|
131
144
|
/**
|
|
132
145
|
* Record a @font-face rule. Deduplicated by key (content hash).
|
|
@@ -144,7 +157,7 @@ var ServerStyleCollector = class {
|
|
|
144
157
|
* Allocate a counter-style name for SSR. Uses provided name or generates one.
|
|
145
158
|
*/
|
|
146
159
|
allocateCounterStyleName(providedName) {
|
|
147
|
-
return providedName ??
|
|
160
|
+
return providedName ?? makeCounterStyleName(this.namePrefix, String(this.counterStyleCounter++));
|
|
148
161
|
}
|
|
149
162
|
/**
|
|
150
163
|
* Record global styles (from useGlobalStyles). Deduplicated by key.
|
|
@@ -227,4 +240,4 @@ var ServerStyleCollector = class {
|
|
|
227
240
|
//#endregion
|
|
228
241
|
export { ServerStyleCollector as t };
|
|
229
242
|
|
|
230
|
-
//# sourceMappingURL=collector-
|
|
243
|
+
//# sourceMappingURL=collector-DROCOiaT.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"collector-DROCOiaT.js","names":[],"sources":["../src/ssr/collector.ts"],"sourcesContent":["/**\n * ServerStyleCollector — server-safe style collector for SSR.\n *\n * Accumulates CSS rules and cache metadata during server rendering.\n * This is the server-side counterpart to StyleInjector: it allocates\n * hash-based class names using the configured `namePrefix` (defaults\n * to `'t'`), formats CSS rules into text, and tracks rendered class\n * names for lightweight client transfer.\n *\n * One instance is created per HTTP request. Concurrent requests\n * each get their own collector (via AsyncLocalStorage or React context).\n */\n\nimport {\n getEffectiveProperties,\n getGlobalStyles,\n getGlobalCounterStyle,\n getGlobalFontFace,\n getGlobalConfigTokens,\n getNamePrefix,\n} from '../config';\nimport { formatCounterStyleRule } from '../counter-style';\nimport { fontFaceContentHash, formatFontFaceRule } from '../font-face';\nimport { renderStyles } from '../pipeline';\nimport type { StyleResult } from '../pipeline';\nimport { hashString } from '../utils/hash';\nimport {\n makeClassName,\n makeCounterStyleName,\n makeKeyframeName,\n validateNamePrefix,\n} from '../utils/name-prefix';\nimport { formatPropertyCSS } from './format-property';\nimport { formatGlobalRules } from './format-global-rules';\nimport { formatRules } from './format-rules';\n\nexport class ServerStyleCollector {\n private chunks = new Map<string, string>();\n private cacheKeyToClassName = new Map<string, string>();\n private flushedKeys = new Set<string>();\n private propertyRules = new Map<string, string>();\n private flushedPropertyKeys = new Set<string>();\n private keyframeRules = new Map<string, string>();\n private flushedKeyframeKeys = new Set<string>();\n private globalStyles = new Map<string, string>();\n private flushedGlobalKeys = new Set<string>();\n private rawCSS = new Map<string, string>();\n private flushedRawKeys = new Set<string>();\n private fontFaceRules = new Map<string, string>();\n private flushedFontFaceKeys = new Set<string>();\n private counterStyleRules = new Map<string, string>();\n private flushedCounterStyleKeys = new Set<string>();\n private keyframesCounter = 0;\n private counterStyleCounter = 0;\n private internalsCollected = false;\n private namePrefix: string;\n\n /**\n * @param namePrefix - Optional override for the configured prefix.\n * Defaults to the value from `configure({ namePrefix })` (or `'t'`).\n * Pass an explicit prefix when constructing a collector outside the\n * normal configure() lifecycle (e.g. in tests). Validated eagerly\n * so misconfiguration fails before any CSS is collected.\n */\n constructor(namePrefix?: string) {\n if (namePrefix !== undefined) {\n validateNamePrefix(namePrefix);\n }\n this.namePrefix = namePrefix ?? getNamePrefix();\n }\n\n private generateClassName(cacheKey: string): string {\n return makeClassName(this.namePrefix, hashString(cacheKey));\n }\n\n /**\n * Collect internal @property rules and :root token defaults.\n * Mirrors markStylesGenerated() from the client-side injector.\n * Called automatically on first chunk collection; idempotent.\n *\n * Internals are always emitted here — the RSC path deliberately\n * defers to SSR so that tokens appear exactly once per page in\n * <style data-tasty-ssr> (avoiding duplication of large token sets).\n */\n collectInternals(): void {\n if (this.internalsCollected) return;\n this.internalsCollected = true;\n\n for (const [token, definition] of Object.entries(\n getEffectiveProperties(),\n )) {\n const css = formatPropertyCSS(token, definition);\n if (css) {\n this.collectProperty(`__prop:${token}`, css);\n }\n }\n\n const tokenStyles = getGlobalConfigTokens();\n if (tokenStyles && Object.keys(tokenStyles).length > 0) {\n const tokenRules = renderStyles(tokenStyles, ':root') as StyleResult[];\n if (tokenRules.length > 0) {\n const css = formatGlobalRules(tokenRules);\n if (css) {\n this.collectGlobalStyles('__global:tokens', css);\n }\n }\n }\n\n const globalFF = getGlobalFontFace();\n if (globalFF) {\n for (const [family, input] of Object.entries(globalFF)) {\n const descriptors = Array.isArray(input) ? input : [input];\n for (const desc of descriptors) {\n const hash = fontFaceContentHash(family, desc);\n const css = formatFontFaceRule(family, desc);\n this.collectFontFace(hash, css);\n }\n }\n }\n\n const globalCS = getGlobalCounterStyle();\n if (globalCS) {\n for (const [name, descriptors] of Object.entries(globalCS)) {\n const css = formatCounterStyleRule(name, descriptors);\n this.collectCounterStyle(name, css);\n }\n }\n\n const globalStyles = getGlobalStyles();\n if (globalStyles) {\n for (const [selector, styles] of Object.entries(globalStyles)) {\n if (Object.keys(styles).length > 0) {\n const rules = renderStyles(styles, selector) as StyleResult[];\n if (rules.length > 0) {\n const css = formatGlobalRules(rules);\n if (css) {\n this.collectGlobalStyles(`__global:styles:${selector}`, css);\n }\n }\n }\n }\n }\n }\n\n /**\n * Allocate a className for a cache key, server-side.\n * Mirrors StyleInjector.allocateClassName but without DOM access.\n */\n allocateClassName(cacheKey: string): {\n className: string;\n isNewAllocation: boolean;\n } {\n const existing = this.cacheKeyToClassName.get(cacheKey);\n if (existing) {\n return { className: existing, isNewAllocation: false };\n }\n\n const className = this.generateClassName(cacheKey);\n this.cacheKeyToClassName.set(cacheKey, className);\n\n return { className, isNewAllocation: true };\n }\n\n /**\n * Record CSS rules for a chunk.\n * Called by useStyles during server render.\n */\n collectChunk(\n cacheKey: string,\n className: string,\n rules: StyleResult[],\n ): void {\n if (this.chunks.has(cacheKey)) return;\n const css = formatRules(rules, className);\n if (css) {\n this.chunks.set(cacheKey, css);\n }\n }\n\n /**\n * Record a @property rule. Deduplicated by name.\n */\n collectProperty(name: string, css: string): void {\n if (!this.propertyRules.has(name)) {\n this.propertyRules.set(name, css);\n }\n }\n\n /**\n * Record a @keyframes rule. Deduplicated by name.\n */\n collectKeyframes(name: string, css: string): void {\n if (!this.keyframeRules.has(name)) {\n this.keyframeRules.set(name, css);\n }\n }\n\n /**\n * Allocate a keyframe name for SSR. Uses provided name or generates one.\n */\n allocateKeyframeName(providedName?: string): string {\n return (\n providedName ??\n makeKeyframeName(this.namePrefix, String(this.keyframesCounter++))\n );\n }\n\n /**\n * Record a @font-face rule. Deduplicated by key (content hash).\n */\n collectFontFace(key: string, css: string): void {\n if (!this.fontFaceRules.has(key)) {\n this.fontFaceRules.set(key, css);\n }\n }\n\n /**\n * Record a @counter-style rule. Deduplicated by name.\n */\n collectCounterStyle(name: string, css: string): void {\n if (!this.counterStyleRules.has(name)) {\n this.counterStyleRules.set(name, css);\n }\n }\n\n /**\n * Allocate a counter-style name for SSR. Uses provided name or generates one.\n */\n allocateCounterStyleName(providedName?: string): string {\n return (\n providedName ??\n makeCounterStyleName(this.namePrefix, String(this.counterStyleCounter++))\n );\n }\n\n /**\n * Record global styles (from useGlobalStyles). Deduplicated by key.\n */\n collectGlobalStyles(key: string, css: string): void {\n if (!this.globalStyles.has(key)) {\n this.globalStyles.set(key, css);\n }\n }\n\n /**\n * Record raw CSS text (from useRawCSS). Deduplicated by key.\n */\n collectRawCSS(key: string, css: string): void {\n if (!this.rawCSS.has(key)) {\n this.rawCSS.set(key, css);\n }\n }\n\n /**\n * Extract all CSS collected so far as a single string.\n * Includes @property and @keyframes rules.\n * Used for non-streaming SSR (renderToString).\n */\n getCSS(): string {\n const parts: string[] = [];\n\n for (const css of this.propertyRules.values()) {\n parts.push(css);\n }\n\n for (const css of this.fontFaceRules.values()) {\n parts.push(css);\n }\n\n for (const css of this.counterStyleRules.values()) {\n parts.push(css);\n }\n\n for (const css of this.rawCSS.values()) {\n parts.push(css);\n }\n\n for (const css of this.globalStyles.values()) {\n parts.push(css);\n }\n\n for (const css of this.chunks.values()) {\n parts.push(css);\n }\n\n for (const css of this.keyframeRules.values()) {\n parts.push(css);\n }\n\n return parts.join('\\n');\n }\n\n /**\n * Flush only newly collected CSS since the last flush.\n * Used for streaming SSR (renderToPipeableStream + useServerInsertedHTML).\n */\n flushCSS(): string {\n const parts: string[] = [];\n\n for (const [name, css] of this.propertyRules) {\n if (!this.flushedPropertyKeys.has(name)) {\n parts.push(css);\n this.flushedPropertyKeys.add(name);\n }\n }\n\n for (const [key, css] of this.fontFaceRules) {\n if (!this.flushedFontFaceKeys.has(key)) {\n parts.push(css);\n this.flushedFontFaceKeys.add(key);\n }\n }\n\n for (const [key, css] of this.counterStyleRules) {\n if (!this.flushedCounterStyleKeys.has(key)) {\n parts.push(css);\n this.flushedCounterStyleKeys.add(key);\n }\n }\n\n for (const [key, css] of this.rawCSS) {\n if (!this.flushedRawKeys.has(key)) {\n parts.push(css);\n this.flushedRawKeys.add(key);\n }\n }\n\n for (const [key, css] of this.globalStyles) {\n if (!this.flushedGlobalKeys.has(key)) {\n parts.push(css);\n this.flushedGlobalKeys.add(key);\n }\n }\n\n for (const [key, css] of this.chunks) {\n if (!this.flushedKeys.has(key)) {\n parts.push(css);\n this.flushedKeys.add(key);\n }\n }\n\n for (const [name, css] of this.keyframeRules) {\n if (!this.flushedKeyframeKeys.has(name)) {\n parts.push(css);\n this.flushedKeyframeKeys.add(name);\n }\n }\n\n return parts.join('\\n');\n }\n\n private flushedClassNames = new Set<string>();\n\n /**\n * Return class names rendered since the last call (for streaming).\n * Used to emit lightweight class-list scripts for client hydration.\n */\n getRenderedClassNames(): string[] {\n const names: string[] = [];\n for (const className of this.cacheKeyToClassName.values()) {\n if (!this.flushedClassNames.has(className)) {\n this.flushedClassNames.add(className);\n names.push(className);\n }\n }\n return names;\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;AAoCA,IAAa,uBAAb,MAAkC;CAChC,yBAAiB,IAAI,KAAqB;CAC1C,sCAA8B,IAAI,KAAqB;CACvD,8BAAsB,IAAI,KAAa;CACvC,gCAAwB,IAAI,KAAqB;CACjD,sCAA8B,IAAI,KAAa;CAC/C,gCAAwB,IAAI,KAAqB;CACjD,sCAA8B,IAAI,KAAa;CAC/C,+BAAuB,IAAI,KAAqB;CAChD,oCAA4B,IAAI,KAAa;CAC7C,yBAAiB,IAAI,KAAqB;CAC1C,iCAAyB,IAAI,KAAa;CAC1C,gCAAwB,IAAI,KAAqB;CACjD,sCAA8B,IAAI,KAAa;CAC/C,oCAA4B,IAAI,KAAqB;CACrD,0CAAkC,IAAI,KAAa;CACnD,mBAA2B;CAC3B,sBAA8B;CAC9B,qBAA6B;CAC7B;;;;;;;;CASA,YAAY,YAAqB;AAC/B,MAAI,eAAe,KAAA,EACjB,oBAAmB,WAAW;AAEhC,OAAK,aAAa,cAAc,eAAe;;CAGjD,kBAA0B,UAA0B;AAClD,SAAO,cAAc,KAAK,YAAY,WAAW,SAAS,CAAC;;;;;;;;;;;CAY7D,mBAAyB;AACvB,MAAI,KAAK,mBAAoB;AAC7B,OAAK,qBAAqB;AAE1B,OAAK,MAAM,CAAC,OAAO,eAAe,OAAO,QACvC,wBAAwB,CACzB,EAAE;GACD,MAAM,MAAM,kBAAkB,OAAO,WAAW;AAChD,OAAI,IACF,MAAK,gBAAgB,UAAU,SAAS,IAAI;;EAIhD,MAAM,cAAc,uBAAuB;AAC3C,MAAI,eAAe,OAAO,KAAK,YAAY,CAAC,SAAS,GAAG;GACtD,MAAM,aAAa,aAAa,aAAa,QAAQ;AACrD,OAAI,WAAW,SAAS,GAAG;IACzB,MAAM,MAAM,kBAAkB,WAAW;AACzC,QAAI,IACF,MAAK,oBAAoB,mBAAmB,IAAI;;;EAKtD,MAAM,WAAW,mBAAmB;AACpC,MAAI,SACF,MAAK,MAAM,CAAC,QAAQ,UAAU,OAAO,QAAQ,SAAS,EAAE;GACtD,MAAM,cAAc,MAAM,QAAQ,MAAM,GAAG,QAAQ,CAAC,MAAM;AAC1D,QAAK,MAAM,QAAQ,aAAa;IAC9B,MAAM,OAAO,oBAAoB,QAAQ,KAAK;IAC9C,MAAM,MAAM,mBAAmB,QAAQ,KAAK;AAC5C,SAAK,gBAAgB,MAAM,IAAI;;;EAKrC,MAAM,WAAW,uBAAuB;AACxC,MAAI,SACF,MAAK,MAAM,CAAC,MAAM,gBAAgB,OAAO,QAAQ,SAAS,EAAE;GAC1D,MAAM,MAAM,uBAAuB,MAAM,YAAY;AACrD,QAAK,oBAAoB,MAAM,IAAI;;EAIvC,MAAM,eAAe,iBAAiB;AACtC,MAAI;QACG,MAAM,CAAC,UAAU,WAAW,OAAO,QAAQ,aAAa,CAC3D,KAAI,OAAO,KAAK,OAAO,CAAC,SAAS,GAAG;IAClC,MAAM,QAAQ,aAAa,QAAQ,SAAS;AAC5C,QAAI,MAAM,SAAS,GAAG;KACpB,MAAM,MAAM,kBAAkB,MAAM;AACpC,SAAI,IACF,MAAK,oBAAoB,mBAAmB,YAAY,IAAI;;;;;;;;;CAYxE,kBAAkB,UAGhB;EACA,MAAM,WAAW,KAAK,oBAAoB,IAAI,SAAS;AACvD,MAAI,SACF,QAAO;GAAE,WAAW;GAAU,iBAAiB;GAAO;EAGxD,MAAM,YAAY,KAAK,kBAAkB,SAAS;AAClD,OAAK,oBAAoB,IAAI,UAAU,UAAU;AAEjD,SAAO;GAAE;GAAW,iBAAiB;GAAM;;;;;;CAO7C,aACE,UACA,WACA,OACM;AACN,MAAI,KAAK,OAAO,IAAI,SAAS,CAAE;EAC/B,MAAM,MAAM,YAAY,OAAO,UAAU;AACzC,MAAI,IACF,MAAK,OAAO,IAAI,UAAU,IAAI;;;;;CAOlC,gBAAgB,MAAc,KAAmB;AAC/C,MAAI,CAAC,KAAK,cAAc,IAAI,KAAK,CAC/B,MAAK,cAAc,IAAI,MAAM,IAAI;;;;;CAOrC,iBAAiB,MAAc,KAAmB;AAChD,MAAI,CAAC,KAAK,cAAc,IAAI,KAAK,CAC/B,MAAK,cAAc,IAAI,MAAM,IAAI;;;;;CAOrC,qBAAqB,cAA+B;AAClD,SACE,gBACA,iBAAiB,KAAK,YAAY,OAAO,KAAK,mBAAmB,CAAC;;;;;CAOtE,gBAAgB,KAAa,KAAmB;AAC9C,MAAI,CAAC,KAAK,cAAc,IAAI,IAAI,CAC9B,MAAK,cAAc,IAAI,KAAK,IAAI;;;;;CAOpC,oBAAoB,MAAc,KAAmB;AACnD,MAAI,CAAC,KAAK,kBAAkB,IAAI,KAAK,CACnC,MAAK,kBAAkB,IAAI,MAAM,IAAI;;;;;CAOzC,yBAAyB,cAA+B;AACtD,SACE,gBACA,qBAAqB,KAAK,YAAY,OAAO,KAAK,sBAAsB,CAAC;;;;;CAO7E,oBAAoB,KAAa,KAAmB;AAClD,MAAI,CAAC,KAAK,aAAa,IAAI,IAAI,CAC7B,MAAK,aAAa,IAAI,KAAK,IAAI;;;;;CAOnC,cAAc,KAAa,KAAmB;AAC5C,MAAI,CAAC,KAAK,OAAO,IAAI,IAAI,CACvB,MAAK,OAAO,IAAI,KAAK,IAAI;;;;;;;CAS7B,SAAiB;EACf,MAAM,QAAkB,EAAE;AAE1B,OAAK,MAAM,OAAO,KAAK,cAAc,QAAQ,CAC3C,OAAM,KAAK,IAAI;AAGjB,OAAK,MAAM,OAAO,KAAK,cAAc,QAAQ,CAC3C,OAAM,KAAK,IAAI;AAGjB,OAAK,MAAM,OAAO,KAAK,kBAAkB,QAAQ,CAC/C,OAAM,KAAK,IAAI;AAGjB,OAAK,MAAM,OAAO,KAAK,OAAO,QAAQ,CACpC,OAAM,KAAK,IAAI;AAGjB,OAAK,MAAM,OAAO,KAAK,aAAa,QAAQ,CAC1C,OAAM,KAAK,IAAI;AAGjB,OAAK,MAAM,OAAO,KAAK,OAAO,QAAQ,CACpC,OAAM,KAAK,IAAI;AAGjB,OAAK,MAAM,OAAO,KAAK,cAAc,QAAQ,CAC3C,OAAM,KAAK,IAAI;AAGjB,SAAO,MAAM,KAAK,KAAK;;;;;;CAOzB,WAAmB;EACjB,MAAM,QAAkB,EAAE;AAE1B,OAAK,MAAM,CAAC,MAAM,QAAQ,KAAK,cAC7B,KAAI,CAAC,KAAK,oBAAoB,IAAI,KAAK,EAAE;AACvC,SAAM,KAAK,IAAI;AACf,QAAK,oBAAoB,IAAI,KAAK;;AAItC,OAAK,MAAM,CAAC,KAAK,QAAQ,KAAK,cAC5B,KAAI,CAAC,KAAK,oBAAoB,IAAI,IAAI,EAAE;AACtC,SAAM,KAAK,IAAI;AACf,QAAK,oBAAoB,IAAI,IAAI;;AAIrC,OAAK,MAAM,CAAC,KAAK,QAAQ,KAAK,kBAC5B,KAAI,CAAC,KAAK,wBAAwB,IAAI,IAAI,EAAE;AAC1C,SAAM,KAAK,IAAI;AACf,QAAK,wBAAwB,IAAI,IAAI;;AAIzC,OAAK,MAAM,CAAC,KAAK,QAAQ,KAAK,OAC5B,KAAI,CAAC,KAAK,eAAe,IAAI,IAAI,EAAE;AACjC,SAAM,KAAK,IAAI;AACf,QAAK,eAAe,IAAI,IAAI;;AAIhC,OAAK,MAAM,CAAC,KAAK,QAAQ,KAAK,aAC5B,KAAI,CAAC,KAAK,kBAAkB,IAAI,IAAI,EAAE;AACpC,SAAM,KAAK,IAAI;AACf,QAAK,kBAAkB,IAAI,IAAI;;AAInC,OAAK,MAAM,CAAC,KAAK,QAAQ,KAAK,OAC5B,KAAI,CAAC,KAAK,YAAY,IAAI,IAAI,EAAE;AAC9B,SAAM,KAAK,IAAI;AACf,QAAK,YAAY,IAAI,IAAI;;AAI7B,OAAK,MAAM,CAAC,MAAM,QAAQ,KAAK,cAC7B,KAAI,CAAC,KAAK,oBAAoB,IAAI,KAAK,EAAE;AACvC,SAAM,KAAK,IAAI;AACf,QAAK,oBAAoB,IAAI,KAAK;;AAItC,SAAO,MAAM,KAAK,KAAK;;CAGzB,oCAA4B,IAAI,KAAa;;;;;CAM7C,wBAAkC;EAChC,MAAM,QAAkB,EAAE;AAC1B,OAAK,MAAM,aAAa,KAAK,oBAAoB,QAAQ,CACvD,KAAI,CAAC,KAAK,kBAAkB,IAAI,UAAU,EAAE;AAC1C,QAAK,kBAAkB,IAAI,UAAU;AACrC,SAAM,KAAK,UAAU;;AAGzB,SAAO"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Ct as RawCSSResult, Dt as StyleInjectorConfig, Et as SheetInfo, M as StyleHandlerDefinition, Ot as StyleRule, St as PropertyDefinition, Tt as RuleInfo, b as Styles, bt as KeyframesResult, ct as CacheMetrics, dt as FontFaceDescriptors, ft as FontFaceInput, gt as InjectResult, h as ConfigTokens, ht as GlobalInjectResult, it as StyleDetails, lt as CounterStyleDescriptors, mt as GCOptions, n as StyleResult, ot as UnitHandler, pt as GCConfig, v as RecipeStyles, wt as RootRegistry, xt as KeyframesSteps, yt as KeyframesInfo } from "./index-
|
|
1
|
+
import { Ct as RawCSSResult, Dt as StyleInjectorConfig, Et as SheetInfo, M as StyleHandlerDefinition, Ot as StyleRule, St as PropertyDefinition, Tt as RuleInfo, b as Styles, bt as KeyframesResult, ct as CacheMetrics, dt as FontFaceDescriptors, ft as FontFaceInput, gt as InjectResult, h as ConfigTokens, ht as GlobalInjectResult, it as StyleDetails, lt as CounterStyleDescriptors, mt as GCOptions, n as StyleResult, ot as UnitHandler, pt as GCConfig, v as RecipeStyles, wt as RootRegistry, xt as KeyframesSteps, yt as KeyframesInfo } from "./index-Dy74C11K.js";
|
|
2
2
|
|
|
3
3
|
//#region src/injector/sheet-manager.d.ts
|
|
4
4
|
declare class SheetManager {
|
|
@@ -161,9 +161,18 @@ declare class StyleInjector {
|
|
|
161
161
|
private config;
|
|
162
162
|
private globalRuleCounter;
|
|
163
163
|
private pendingGCHandle;
|
|
164
|
+
private namePrefix;
|
|
165
|
+
private classRegex;
|
|
166
|
+
private rscClassRegex;
|
|
164
167
|
/** @internal — exposed for debug utilities only */
|
|
165
168
|
get _sheetManager(): SheetManager;
|
|
166
169
|
constructor(config?: StyleInjectorConfig);
|
|
170
|
+
/**
|
|
171
|
+
* Generate a deterministic class name from a cache key using content hash.
|
|
172
|
+
* The same cache key always produces the same class name across environments
|
|
173
|
+
* with the same `namePrefix`.
|
|
174
|
+
*/
|
|
175
|
+
private generateClassName;
|
|
167
176
|
/**
|
|
168
177
|
* Check if `className` was hydrated from server-rendered styles and,
|
|
169
178
|
* if so, wire the cacheKey mapping. Returns true on hit.
|
|
@@ -268,6 +277,11 @@ declare class StyleInjector {
|
|
|
268
277
|
property(name: string, options?: PropertyDefinition & {
|
|
269
278
|
root?: Document | ShadowRoot;
|
|
270
279
|
}): void;
|
|
280
|
+
/**
|
|
281
|
+
* Build and insert a single `@property` rule into the given registry.
|
|
282
|
+
* No-op if the property was already injected.
|
|
283
|
+
*/
|
|
284
|
+
private insertPropertyRule;
|
|
271
285
|
/**
|
|
272
286
|
* Check whether a given @property name was already injected by this injector.
|
|
273
287
|
*
|
|
@@ -314,7 +328,6 @@ declare class StyleInjector {
|
|
|
314
328
|
* Dispose keyframes
|
|
315
329
|
*/
|
|
316
330
|
private disposeKeyframes;
|
|
317
|
-
private static readonly TASTY_CLASS_RE;
|
|
318
331
|
/**
|
|
319
332
|
* Record a render-time usage hit for one or more classNames.
|
|
320
333
|
* Handles space-separated multi-chunk classNames.
|
|
@@ -551,6 +564,28 @@ interface TastyConfig {
|
|
|
551
564
|
* ```
|
|
552
565
|
*/
|
|
553
566
|
gc?: GCConfig;
|
|
567
|
+
/**
|
|
568
|
+
* Prefix prepended to every generated identifier (class names,
|
|
569
|
+
* keyframe names, counter-style names). The hash is appended verbatim,
|
|
570
|
+
* so include any separator inside the prefix itself (e.g. `'myapp-'`).
|
|
571
|
+
*
|
|
572
|
+
* Discriminator letters are inserted between the prefix and the hash
|
|
573
|
+
* for non-class names so the three kinds stay visually distinct:
|
|
574
|
+
* - class: `${namePrefix}${hash}` — e.g. `t1a2b3`
|
|
575
|
+
* - keyframe: `${namePrefix}k${hash}` — e.g. `tk1a2b3`
|
|
576
|
+
* - counter-style: `${namePrefix}c${hash}` — e.g. `tc1a2b3`
|
|
577
|
+
*
|
|
578
|
+
* The runtime, SSR, and RSC paths must agree on this value or
|
|
579
|
+
* hydration will mismatch. The zero-runtime build path defaults to
|
|
580
|
+
* `'ts'` (overridable via the same option) so its classes can't
|
|
581
|
+
* collide with runtime classes when both are loaded on the same page.
|
|
582
|
+
*
|
|
583
|
+
* Must match `^[a-zA-Z][a-zA-Z0-9_-]{0,31}$`. Locked once styles
|
|
584
|
+
* have been generated.
|
|
585
|
+
*
|
|
586
|
+
* @default 't'
|
|
587
|
+
*/
|
|
588
|
+
namePrefix?: string;
|
|
554
589
|
/**
|
|
555
590
|
* Plugins that extend tasty with custom functions, units, or states.
|
|
556
591
|
* Plugins are processed in order, with later plugins overriding earlier ones.
|
|
@@ -874,11 +909,20 @@ declare function configure(config?: Partial<TastyConfig>): void;
|
|
|
874
909
|
* If not configured, returns default configuration.
|
|
875
910
|
*/
|
|
876
911
|
declare function getConfig(): TastyConfig;
|
|
912
|
+
/**
|
|
913
|
+
* Get the configured prefix used for every generated identifier
|
|
914
|
+
* (class names, keyframe names, counter-style names).
|
|
915
|
+
*
|
|
916
|
+
* Falls back to the default prefix (`'t'`) when `configure()` has not
|
|
917
|
+
* been called yet — this matches the auto-configuration behavior used
|
|
918
|
+
* by the rest of the system.
|
|
919
|
+
*/
|
|
920
|
+
declare function getNamePrefix(): string;
|
|
877
921
|
/**
|
|
878
922
|
* Reset configuration (for testing only).
|
|
879
923
|
* Clears the global injector and allows reconfiguration.
|
|
880
924
|
*/
|
|
881
925
|
declare function resetConfig(): void;
|
|
882
926
|
//#endregion
|
|
883
|
-
export {
|
|
884
|
-
//# sourceMappingURL=config-
|
|
927
|
+
export { SheetManager as S, TypographyPreset as _, getGlobalFontFace as a, ColorSpace as b, getNamePrefix as c, hasStylesGenerated as d, isConfigLocked as f, TastyPluginFactory as g, TastyPlugin as h, getGlobalCounterStyle as i, hasGlobalKeyframes as l, resetConfig as m, configure as n, getGlobalKeyframes as o, isTestEnvironment as p, getConfig as r, getGlobalRecipes as s, TastyConfig as t, hasGlobalRecipes as u, TypographyTokenValue as v, StyleInjector as x, generateTypographyTokens as y };
|
|
928
|
+
//# sourceMappingURL=config-CzzTHmtS.d.ts.map
|