@bgord/design 0.29.2 → 0.29.4
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/v2/index.d.ts +6 -0
- package/dist/v2/main.css +861 -0
- package/dist/v2/main.min.css +1 -0
- package/dist/v2/main.min.css.br +0 -0
- package/dist/v2/main.min.css.gz +0 -0
- package/dist/{normalize.css → v2/normalize.css} +20 -15
- package/dist/v2/normalize.min.css +1 -0
- package/dist/v2/normalize.min.css.br +0 -0
- package/dist/v2/normalize.min.css.gz +0 -0
- package/package.json +15 -8
- package/src/animations/grow-fade-in.css +1 -1
- package/src/animations/shrink-fade-out.css +1 -1
- package/src/normalize.css +20 -15
- package/src/v2/index.ts +3 -0
- package/src/v2/tokens/backdrops-token-generator.ts +14 -0
- package/src/v2/tokens/border-width-token-generator.ts +17 -0
- package/src/v2/tokens/brand-token-generator.ts +20 -0
- package/src/v2/tokens/breakpoint-token-generator.ts +11 -0
- package/src/v2/tokens/danger-token-generator.ts +15 -0
- package/src/v2/tokens/font-family-token-generator.ts +13 -0
- package/src/v2/tokens/font-size-token-generator.ts +19 -0
- package/src/v2/tokens/font-weight-token-generator.ts +16 -0
- package/src/v2/tokens/grayscale-token-generator.ts +21 -0
- package/src/v2/tokens/index.ts +18 -0
- package/src/v2/tokens/letter-spacing-token-generator.ts +16 -0
- package/src/v2/tokens/line-height-token-generator.ts +16 -0
- package/src/v2/tokens/opacity-token-generator.ts +13 -0
- package/src/v2/tokens/positive-token-generator.ts +15 -0
- package/src/v2/tokens/radius-token-generator.ts +19 -0
- package/src/v2/tokens/shadow-token-generator.ts +18 -0
- package/src/v2/tokens/spacing-token-generator.ts +24 -0
- package/src/v2/tokens/template.ts +44 -0
- package/src/v2/tokens/warning-token-generator.ts +15 -0
- package/src/v2/tokens/z-index-token-generator.ts +15 -0
- package/src/v2/utilities/axis-placement-utility-generator.ts +28 -0
- package/src/v2/utilities/backdrop-utility-generator.ts +23 -0
- package/src/v2/utilities/background-utility-generator.ts +39 -0
- package/src/v2/utilities/border-color-utility-generator.ts +40 -0
- package/src/v2/utilities/border-width-utility-generator.ts +23 -0
- package/src/v2/utilities/cursor-utility-generator.ts +19 -0
- package/src/v2/utilities/display-utility-generator.ts +22 -0
- package/src/v2/utilities/flex-direction-utility-generator.ts +24 -0
- package/src/v2/utilities/flex-grow-utility-generator.ts +19 -0
- package/src/v2/utilities/flex-shrink-utility-generator.ts +19 -0
- package/src/v2/utilities/flex-wrap-utility-generator.ts +19 -0
- package/src/v2/utilities/font-color-utility-generator.ts +39 -0
- package/src/v2/utilities/font-family-utility-generator.ts +23 -0
- package/src/v2/utilities/font-size-utility-generator.ts +31 -0
- package/src/v2/utilities/font-weight-utility-generator.ts +23 -0
- package/src/v2/utilities/gap-utility-generator.ts +23 -0
- package/src/v2/utilities/height-utility-generator.ts +19 -0
- package/src/v2/utilities/index.ts +36 -0
- package/src/v2/utilities/letter-spacing-utility-generator.ts +23 -0
- package/src/v2/utilities/line-height-utility-generator.ts +23 -0
- package/src/v2/utilities/margin-utility-generator.ts +31 -0
- package/src/v2/utilities/max-height-utility-generator.ts +21 -0
- package/src/v2/utilities/max-width-utility-generator.ts +21 -0
- package/src/v2/utilities/object-fit-utility-generator.ts +25 -0
- package/src/v2/utilities/object-position-utility-generator.ts +27 -0
- package/src/v2/utilities/opacity-utility-generator.ts +23 -0
- package/src/v2/utilities/overflow-utility-generator.ts +19 -0
- package/src/v2/utilities/padding-utility-generator.ts +31 -0
- package/src/v2/utilities/pointer-event-utility-generator.ts +19 -0
- package/src/v2/utilities/position-utility-generator.ts +26 -0
- package/src/v2/utilities/positioners-utility-generator.ts +27 -0
- package/src/v2/utilities/radius-utility-generator.ts +23 -0
- package/src/v2/utilities/rotate-utility-generator.ts +19 -0
- package/src/v2/utilities/shadow-utility-generator.ts +23 -0
- package/src/v2/utilities/template.ts +24 -0
- package/src/v2/utilities/transform-utility-generator.ts +58 -0
- package/src/v2/utilities/width-utility-generator.ts +19 -0
- package/src/v2/utilities/z-index-utility-generator.ts +23 -0
- package/src/v2/v2-generate-css.ts +195 -0
- package/dist/main.css +0 -3472
- package/dist/main.min.css +0 -1
- package/dist/main.min.css.br +0 -0
- package/dist/main.min.css.gz +0 -0
- package/dist/normalize.min.css +0 -1
- package/dist/normalize.min.css.br +0 -0
- package/dist/normalize.min.css.gz +0 -0
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { UtilityGenerator } from "./template";
|
|
2
|
+
|
|
3
|
+
export class ObjectFitUtilityGenerator extends UtilityGenerator {
|
|
4
|
+
config = {
|
|
5
|
+
contain: "contain",
|
|
6
|
+
cover: "cover",
|
|
7
|
+
fill: "fill",
|
|
8
|
+
"scale-down": "scale-down",
|
|
9
|
+
none: "none",
|
|
10
|
+
};
|
|
11
|
+
|
|
12
|
+
constructor() {
|
|
13
|
+
super("Object fit utilities");
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
css() {
|
|
17
|
+
const lines: string[] = [];
|
|
18
|
+
|
|
19
|
+
for (const [key, value] of Object.entries(this.config)) {
|
|
20
|
+
lines.push(`[data-object-fit='${key}'] { object-fit: ${value}; }`);
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
return lines.join("\n");
|
|
24
|
+
}
|
|
25
|
+
}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { UtilityGenerator } from "./template";
|
|
2
|
+
|
|
3
|
+
export class ObjectPositionUtilityGenerator extends UtilityGenerator {
|
|
4
|
+
config = {
|
|
5
|
+
top: "top",
|
|
6
|
+
bottom: "bottom",
|
|
7
|
+
left: "left",
|
|
8
|
+
right: "right",
|
|
9
|
+
center: "center",
|
|
10
|
+
"top-left": "top left",
|
|
11
|
+
"top-right": "top right",
|
|
12
|
+
};
|
|
13
|
+
|
|
14
|
+
constructor() {
|
|
15
|
+
super("Object position utilities");
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
css() {
|
|
19
|
+
const lines: string[] = [];
|
|
20
|
+
|
|
21
|
+
for (const [key, value] of Object.entries(this.config)) {
|
|
22
|
+
lines.push(`[data-object-position='${key}'] { object-position: ${value}; }`);
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
return lines.join("\n");
|
|
26
|
+
}
|
|
27
|
+
}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { OpacityTokenGenerator } from "../tokens/opacity-token-generator";
|
|
2
|
+
import { UtilityGenerator } from "./template";
|
|
3
|
+
|
|
4
|
+
export class OpacityUtilityGenerator extends UtilityGenerator {
|
|
5
|
+
config = {};
|
|
6
|
+
|
|
7
|
+
constructor(OpacityTokenGenerator: OpacityTokenGenerator) {
|
|
8
|
+
super("Opacity utilities");
|
|
9
|
+
this.config = OpacityTokenGenerator.getConfig();
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
css() {
|
|
13
|
+
const lines: string[] = [];
|
|
14
|
+
|
|
15
|
+
for (const variable of Object.keys(this.config)) {
|
|
16
|
+
const key = variable.replace("opacity-", "");
|
|
17
|
+
|
|
18
|
+
lines.push(`[data-opacity='${key}'] { opacity: var(--${variable}); }`);
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
return lines.join("\n");
|
|
22
|
+
}
|
|
23
|
+
}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { UtilityGenerator } from "./template";
|
|
2
|
+
|
|
3
|
+
export class OverflowUtilityGenerator extends UtilityGenerator {
|
|
4
|
+
config = { auto: "auto", scroll: "scroll", hidden: "hidden" };
|
|
5
|
+
|
|
6
|
+
constructor() {
|
|
7
|
+
super("Overflow utilities");
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
css() {
|
|
11
|
+
const lines: string[] = [];
|
|
12
|
+
|
|
13
|
+
for (const [key, value] of Object.entries(this.config)) {
|
|
14
|
+
lines.push(`[data-overflow='${key}'] { overflow: ${value}; }`);
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
return lines.join("\n");
|
|
18
|
+
}
|
|
19
|
+
}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { SpacingTokenGenerator } from "../tokens/spacing-token-generator";
|
|
2
|
+
import { UtilityGenerator } from "./template";
|
|
3
|
+
|
|
4
|
+
export class PaddingUtilityGenerator extends UtilityGenerator {
|
|
5
|
+
config = {};
|
|
6
|
+
|
|
7
|
+
constructor(SpacingTokenGenerator: SpacingTokenGenerator) {
|
|
8
|
+
super("Padding utilities");
|
|
9
|
+
this.config = SpacingTokenGenerator.getConfig();
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
css() {
|
|
13
|
+
const lines: string[] = [];
|
|
14
|
+
|
|
15
|
+
for (const variable of Object.keys(this.config)) {
|
|
16
|
+
const key = variable.replace("spacing-", "");
|
|
17
|
+
|
|
18
|
+
lines.push(`[data-p='${key}'] { padding: var(--${variable}); }`);
|
|
19
|
+
|
|
20
|
+
lines.push(`[data-pt='${key}'] { padding-top: var(--${variable}); }`);
|
|
21
|
+
lines.push(`[data-pr='${key}'] { padding-right: var(--${variable}); }`);
|
|
22
|
+
lines.push(`[data-pb='${key}'] { padding-bottom: var(--${variable}); }`);
|
|
23
|
+
lines.push(`[data-pl='${key}'] { padding-left: var(--${variable}); }`);
|
|
24
|
+
|
|
25
|
+
lines.push(`[data-px='${key}'] { padding: 0 var(--${variable}); }`);
|
|
26
|
+
lines.push(`[data-py='${key}'] { padding: var(--${variable}) 0; }`);
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
return lines.join("\n");
|
|
30
|
+
}
|
|
31
|
+
}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { UtilityGenerator } from "./template";
|
|
2
|
+
|
|
3
|
+
export class PointerEventUtilityGenerator extends UtilityGenerator {
|
|
4
|
+
config = { none: "none", auto: "auto" };
|
|
5
|
+
|
|
6
|
+
constructor() {
|
|
7
|
+
super("Pointer event utilities");
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
css() {
|
|
11
|
+
const lines: string[] = [];
|
|
12
|
+
|
|
13
|
+
for (const [key, value] of Object.entries(this.config)) {
|
|
14
|
+
lines.push(`[data-pointer-events='${key}'] { pointer-events: ${value}; }`);
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
return lines.join("\n");
|
|
18
|
+
}
|
|
19
|
+
}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { UtilityGenerator } from "./template";
|
|
2
|
+
|
|
3
|
+
export class PositionUtilityGenerator extends UtilityGenerator {
|
|
4
|
+
config = {
|
|
5
|
+
static: "static",
|
|
6
|
+
relative: "relative",
|
|
7
|
+
absolute: "absolute",
|
|
8
|
+
fixed: "fixed",
|
|
9
|
+
sticky: "sticky",
|
|
10
|
+
unset: "unset",
|
|
11
|
+
};
|
|
12
|
+
|
|
13
|
+
constructor() {
|
|
14
|
+
super("Position utilities");
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
css() {
|
|
18
|
+
const lines: string[] = [];
|
|
19
|
+
|
|
20
|
+
for (const [key, value] of Object.entries(this.config)) {
|
|
21
|
+
lines.push(`[data-position='${key}'] { position: ${value}; }`);
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
return lines.join("\n");
|
|
25
|
+
}
|
|
26
|
+
}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { SpacingTokenGenerator } from "../tokens/spacing-token-generator";
|
|
2
|
+
import { UtilityGenerator } from "./template";
|
|
3
|
+
|
|
4
|
+
export class PositionersUtilityGenerator extends UtilityGenerator {
|
|
5
|
+
config = {};
|
|
6
|
+
|
|
7
|
+
constructor(SpacingTokenGenerator: SpacingTokenGenerator) {
|
|
8
|
+
super("Positioners utilities");
|
|
9
|
+
this.config = SpacingTokenGenerator.getConfig();
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
css() {
|
|
13
|
+
const lines: string[] = [];
|
|
14
|
+
|
|
15
|
+
for (const variable of Object.keys(this.config)) {
|
|
16
|
+
const key = variable.replace("spacing-", "");
|
|
17
|
+
|
|
18
|
+
lines.push(`[data-top='${key}'] { top: var(--${variable}); }`);
|
|
19
|
+
lines.push(`[data-right='${key}'] { right: var(--${variable}); }`);
|
|
20
|
+
lines.push(`[data-bottom='${key}'] { bottom: var(--${variable}); }`);
|
|
21
|
+
lines.push(`[data-left='${key}'] { left: var(--${variable}); }`);
|
|
22
|
+
lines.push(`[data-inset='${key}'] { inset: var(--${variable}); }`);
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
return lines.join("\n");
|
|
26
|
+
}
|
|
27
|
+
}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { RadiusTokenGenerator } from "../tokens/radius-token-generator";
|
|
2
|
+
import { UtilityGenerator } from "./template";
|
|
3
|
+
|
|
4
|
+
export class RadiusUtilityGenerator extends UtilityGenerator {
|
|
5
|
+
config = {};
|
|
6
|
+
|
|
7
|
+
constructor(RadiusTokenGenerator: RadiusTokenGenerator) {
|
|
8
|
+
super("Radius utilities");
|
|
9
|
+
this.config = RadiusTokenGenerator.getConfig();
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
css() {
|
|
13
|
+
const lines: string[] = [];
|
|
14
|
+
|
|
15
|
+
for (const variable of Object.keys(this.config)) {
|
|
16
|
+
const key = variable.replace("radius-", "");
|
|
17
|
+
|
|
18
|
+
lines.push(`[data-br='${key}'] { border-radius: var(--${variable}); }`);
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
return lines.join("\n");
|
|
22
|
+
}
|
|
23
|
+
}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { UtilityGenerator } from "./template";
|
|
2
|
+
|
|
3
|
+
export class RotateUtilityGenerator extends UtilityGenerator {
|
|
4
|
+
config = { "0": "0", "90": "90", "180": "180", "270": "270" };
|
|
5
|
+
|
|
6
|
+
constructor() {
|
|
7
|
+
super("Rotate utilities");
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
css() {
|
|
11
|
+
const lines: string[] = [];
|
|
12
|
+
|
|
13
|
+
for (const [key, value] of Object.entries(this.config)) {
|
|
14
|
+
lines.push(`[data-rotate='${key}'] { transform: rotate(${value}deg); }`);
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
return lines.join("\n");
|
|
18
|
+
}
|
|
19
|
+
}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { ShadowTokenGenerator } from "../tokens/shadow-token-generator";
|
|
2
|
+
import { UtilityGenerator } from "./template";
|
|
3
|
+
|
|
4
|
+
export class ShadowUtilityGenerator extends UtilityGenerator {
|
|
5
|
+
config = {};
|
|
6
|
+
|
|
7
|
+
constructor(ShadowTokenGenerator: ShadowTokenGenerator) {
|
|
8
|
+
super("Shadow utilities");
|
|
9
|
+
this.config = ShadowTokenGenerator.getConfig();
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
css() {
|
|
13
|
+
const lines: string[] = [];
|
|
14
|
+
|
|
15
|
+
for (const variable of Object.keys(this.config)) {
|
|
16
|
+
const key = variable.replace("shadow-", "");
|
|
17
|
+
|
|
18
|
+
lines.push(`[data-shadow='${key}'] { box-shadow: var(--${variable}); }`);
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
return lines.join("\n");
|
|
22
|
+
}
|
|
23
|
+
}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { TokenConfigType } from "../tokens/template";
|
|
2
|
+
|
|
3
|
+
export abstract class UtilityGenerator {
|
|
4
|
+
abstract config: TokenConfigType;
|
|
5
|
+
name: string;
|
|
6
|
+
|
|
7
|
+
constructor(name: string) {
|
|
8
|
+
this.name = name;
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
header(): string {
|
|
12
|
+
return `\n/* ${this.name} */\n`;
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
abstract css(): string;
|
|
16
|
+
|
|
17
|
+
footer(): string {
|
|
18
|
+
return "\n/* ===================== */\n";
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
toTypeScript(): string {
|
|
22
|
+
return "";
|
|
23
|
+
}
|
|
24
|
+
}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
import { UtilityGenerator } from "./template";
|
|
2
|
+
|
|
3
|
+
export class TransformUtilityGenerator extends UtilityGenerator {
|
|
4
|
+
config = {
|
|
5
|
+
uppercase: "uppercase",
|
|
6
|
+
lowercase: "lowercase",
|
|
7
|
+
capitalize: "capitalize",
|
|
8
|
+
"upper-first": "upper-first",
|
|
9
|
+
truncate: "truncate",
|
|
10
|
+
center: "center",
|
|
11
|
+
nowrap: "nowrap",
|
|
12
|
+
none: "none",
|
|
13
|
+
"line-clamp": "line-clamp",
|
|
14
|
+
};
|
|
15
|
+
|
|
16
|
+
constructor() {
|
|
17
|
+
super("Transform utilities");
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
css() {
|
|
21
|
+
const lines: string[] = [];
|
|
22
|
+
|
|
23
|
+
for (const [key, value] of Object.entries(this.config)) {
|
|
24
|
+
if (key === "truncate") {
|
|
25
|
+
lines.push(
|
|
26
|
+
`[data-transform~='${key}'] {\n overflow: hidden;\n white-space: nowrap;\n text-overflow: ellipsis;\n}\n`,
|
|
27
|
+
);
|
|
28
|
+
continue;
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
if (key === "line-clamp") {
|
|
32
|
+
lines.push(
|
|
33
|
+
`[data-transform~='${key}'] {\n display: -webkit-box;\n -webkit-box-orient: vertical;\n -webkit-line-clamp: var(--lines, 2); overflow: hidden;\n}\n`,
|
|
34
|
+
);
|
|
35
|
+
continue;
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
if (key === "center") {
|
|
39
|
+
lines.push(`[data-transform~='${key}'] {\n text-align: center;\n}\n`);
|
|
40
|
+
continue;
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
if (key === "upper-first") {
|
|
44
|
+
lines.push(`[data-transform~='upper-first']:first-letter {\n text-transform: uppercase;\n}\n`);
|
|
45
|
+
continue;
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
if (key === "nowrap") {
|
|
49
|
+
lines.push(`[data-transform~='nowrap'] {\n white-space: nowrap;\n}\n`);
|
|
50
|
+
continue;
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
lines.push(`[data-transform~='${key}'] {\n text-transform: ${value};\n}\n`);
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
return lines.join("\n");
|
|
57
|
+
}
|
|
58
|
+
}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { UtilityGenerator } from "./template";
|
|
2
|
+
|
|
3
|
+
export class WidthUtilityGenerator extends UtilityGenerator {
|
|
4
|
+
config = { "100%": "100%", auto: "auto", unset: "unset" };
|
|
5
|
+
|
|
6
|
+
constructor() {
|
|
7
|
+
super("Width utilities");
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
css() {
|
|
11
|
+
const lines: string[] = [];
|
|
12
|
+
|
|
13
|
+
for (const [key, value] of Object.entries(this.config)) {
|
|
14
|
+
lines.push(`[data-width='${key}'] { width: ${value}; }`);
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
return lines.join("\n");
|
|
18
|
+
}
|
|
19
|
+
}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { ZIndexTokenGenerator } from "../tokens/z-index-token-generator";
|
|
2
|
+
import { UtilityGenerator } from "./template";
|
|
3
|
+
|
|
4
|
+
export class ZIndexUtilityGenerator extends UtilityGenerator {
|
|
5
|
+
config = {};
|
|
6
|
+
|
|
7
|
+
constructor(ZIndexTokenGenerator: ZIndexTokenGenerator) {
|
|
8
|
+
super("Z-index utilities");
|
|
9
|
+
this.config = ZIndexTokenGenerator.getConfig();
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
css() {
|
|
13
|
+
const lines: string[] = [];
|
|
14
|
+
|
|
15
|
+
for (const variable of Object.keys(this.config)) {
|
|
16
|
+
const key = variable.replace("z-index-", "");
|
|
17
|
+
|
|
18
|
+
lines.push(`[data-z='${key}'] { z-index: var(--${variable}); }`);
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
return lines.join("\n");
|
|
22
|
+
}
|
|
23
|
+
}
|
|
@@ -0,0 +1,195 @@
|
|
|
1
|
+
import * as TokenGenerators from "./tokens";
|
|
2
|
+
import * as UtilityGenerators from "./utilities";
|
|
3
|
+
|
|
4
|
+
class GeneratorProcessor {
|
|
5
|
+
static async process() {
|
|
6
|
+
const BackdropsTokenGenerator = new TokenGenerators.BackdropsTokenGenerator();
|
|
7
|
+
const BorderWidthTokenGenerator = new TokenGenerators.BorderWidthTokenGenerator();
|
|
8
|
+
const BrandTokenGenerator = new TokenGenerators.BrandTokenGenerator();
|
|
9
|
+
const BreakpointTokenGenerator = new TokenGenerators.BreakpointTokenGenerator();
|
|
10
|
+
const DangerTokenGenerator = new TokenGenerators.DangerTokenGenerator();
|
|
11
|
+
const FontFamilyTokenGenerator = new TokenGenerators.FontFamilyTokenGenerator();
|
|
12
|
+
const FontSizeTokenGenerator = new TokenGenerators.FontSizeTokenGenerator();
|
|
13
|
+
const FontWeightTokenGenerator = new TokenGenerators.FontWeightTokenGenerator();
|
|
14
|
+
const GrayscaleTokenGenerator = new TokenGenerators.GrayscaleTokenGenerator();
|
|
15
|
+
const LetterSpacingTokenGenerator = new TokenGenerators.LetterSpacingTokenGenerator();
|
|
16
|
+
const LineHeightTokenGenerator = new TokenGenerators.LineHeightTokenGenerator();
|
|
17
|
+
const OpacityTokenGenerator = new TokenGenerators.OpacityTokenGenerator();
|
|
18
|
+
const PositiveTokenGenerator = new TokenGenerators.PositiveTokenGenerator();
|
|
19
|
+
const RadiusTokenGenerator = new TokenGenerators.RadiusTokenGenerator();
|
|
20
|
+
const ShadowTokenGenerator = new TokenGenerators.ShadowTokenGenerator();
|
|
21
|
+
const SpacingTokenGenerator = new TokenGenerators.SpacingTokenGenerator();
|
|
22
|
+
const WarningTokenGenerator = new TokenGenerators.WarningTokenGenerator();
|
|
23
|
+
const ZIndexTokenGenerator = new TokenGenerators.ZIndexTokenGenerator();
|
|
24
|
+
|
|
25
|
+
const tokens = [
|
|
26
|
+
BackdropsTokenGenerator,
|
|
27
|
+
BorderWidthTokenGenerator,
|
|
28
|
+
BrandTokenGenerator,
|
|
29
|
+
BreakpointTokenGenerator,
|
|
30
|
+
DangerTokenGenerator,
|
|
31
|
+
FontFamilyTokenGenerator,
|
|
32
|
+
FontSizeTokenGenerator,
|
|
33
|
+
FontWeightTokenGenerator,
|
|
34
|
+
GrayscaleTokenGenerator,
|
|
35
|
+
LetterSpacingTokenGenerator,
|
|
36
|
+
LineHeightTokenGenerator,
|
|
37
|
+
OpacityTokenGenerator,
|
|
38
|
+
PositiveTokenGenerator,
|
|
39
|
+
RadiusTokenGenerator,
|
|
40
|
+
ShadowTokenGenerator,
|
|
41
|
+
SpacingTokenGenerator,
|
|
42
|
+
WarningTokenGenerator,
|
|
43
|
+
ZIndexTokenGenerator,
|
|
44
|
+
];
|
|
45
|
+
|
|
46
|
+
let output = ":root {";
|
|
47
|
+
|
|
48
|
+
for (const token of tokens) {
|
|
49
|
+
output += token.getTokens();
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
output += "}";
|
|
53
|
+
|
|
54
|
+
const BackdropUtilityGenerator = new UtilityGenerators.BackdropUtilityGenerator(BackdropsTokenGenerator);
|
|
55
|
+
const BorderWidthUtilityGenerator = new UtilityGenerators.BorderWidthUtilityGenerator(
|
|
56
|
+
BorderWidthTokenGenerator,
|
|
57
|
+
);
|
|
58
|
+
const FontFamilyUtilityGenerator = new UtilityGenerators.FontFamilyUtilityGenerator(
|
|
59
|
+
FontFamilyTokenGenerator,
|
|
60
|
+
);
|
|
61
|
+
const FontSizeUtilityGenerator = new UtilityGenerators.FontSizeUtilityGenerator(FontSizeTokenGenerator);
|
|
62
|
+
const FontWeightUtilityGenerator = new UtilityGenerators.FontWeightUtilityGenerator(
|
|
63
|
+
FontWeightTokenGenerator,
|
|
64
|
+
);
|
|
65
|
+
const LetterSpacingUtilityGenerator = new UtilityGenerators.LetterSpacingUtilityGenerator(
|
|
66
|
+
LetterSpacingTokenGenerator,
|
|
67
|
+
);
|
|
68
|
+
const LineHeightUtilityGenerator = new UtilityGenerators.LineHeightUtilityGenerator(
|
|
69
|
+
LineHeightTokenGenerator,
|
|
70
|
+
);
|
|
71
|
+
const OpacityUtilityGenerator = new UtilityGenerators.OpacityUtilityGenerator(OpacityTokenGenerator);
|
|
72
|
+
const RadiusUtilityGenerator = new UtilityGenerators.RadiusUtilityGenerator(RadiusTokenGenerator);
|
|
73
|
+
const ShadowUtilityGenerator = new UtilityGenerators.ShadowUtilityGenerator(ShadowTokenGenerator);
|
|
74
|
+
const ZIndexUtilityGenerator = new UtilityGenerators.ZIndexUtilityGenerator(ZIndexTokenGenerator);
|
|
75
|
+
const FontColorUtilityGenerator = new UtilityGenerators.FontColorUtilityGenerator(
|
|
76
|
+
GrayscaleTokenGenerator,
|
|
77
|
+
BrandTokenGenerator,
|
|
78
|
+
PositiveTokenGenerator,
|
|
79
|
+
DangerTokenGenerator,
|
|
80
|
+
WarningTokenGenerator,
|
|
81
|
+
);
|
|
82
|
+
const BackgroundUtilityGenerator = new UtilityGenerators.BackgroundUtilityGenerator(
|
|
83
|
+
GrayscaleTokenGenerator,
|
|
84
|
+
BrandTokenGenerator,
|
|
85
|
+
PositiveTokenGenerator,
|
|
86
|
+
DangerTokenGenerator,
|
|
87
|
+
WarningTokenGenerator,
|
|
88
|
+
);
|
|
89
|
+
const BorderColorUtilityGenerator = new UtilityGenerators.BorderColorUtilityGenerator(
|
|
90
|
+
GrayscaleTokenGenerator,
|
|
91
|
+
BrandTokenGenerator,
|
|
92
|
+
PositiveTokenGenerator,
|
|
93
|
+
DangerTokenGenerator,
|
|
94
|
+
WarningTokenGenerator,
|
|
95
|
+
);
|
|
96
|
+
const PaddingUtilityGenerator = new UtilityGenerators.PaddingUtilityGenerator(SpacingTokenGenerator);
|
|
97
|
+
const MarginUtilityGenerator = new UtilityGenerators.MarginUtilityGenerator(SpacingTokenGenerator);
|
|
98
|
+
const GapUtilityGenerator = new UtilityGenerators.GapUtilityGenerator(SpacingTokenGenerator);
|
|
99
|
+
const PositionersUtilityGenerator = new UtilityGenerators.PositionersUtilityGenerator(
|
|
100
|
+
SpacingTokenGenerator,
|
|
101
|
+
);
|
|
102
|
+
const MaxWidthUtilityGenerator = new UtilityGenerators.MaxWidthUtilityGenerator(BreakpointTokenGenerator);
|
|
103
|
+
const MaxHeightUtilityGenerator = new UtilityGenerators.MaxHeightUtilityGenerator(
|
|
104
|
+
BreakpointTokenGenerator,
|
|
105
|
+
);
|
|
106
|
+
const DisplayUtilityGenerator = new UtilityGenerators.DisplayUtilityGenerator();
|
|
107
|
+
const CursorUtilityGenerator = new UtilityGenerators.CursorUtilityGenerator();
|
|
108
|
+
const ObjectFitUtilityGenerator = new UtilityGenerators.ObjectFitUtilityGenerator();
|
|
109
|
+
const PositionUtilityGenerator = new UtilityGenerators.PositionUtilityGenerator();
|
|
110
|
+
const RotateUtilityGenerator = new UtilityGenerators.RotateUtilityGenerator();
|
|
111
|
+
const ObjectPositionUtilityGenerator = new UtilityGenerators.ObjectPositionUtilityGenerator();
|
|
112
|
+
const PointerEventUtilityGenerator = new UtilityGenerators.PointerEventUtilityGenerator();
|
|
113
|
+
const OverflowUtilityGenerator = new UtilityGenerators.OverflowUtilityGenerator();
|
|
114
|
+
const FlexDirectionUtilityGenerator = new UtilityGenerators.FlexDirectionUtilityGenerator();
|
|
115
|
+
const AxisPlacementUtilityGenerator = new UtilityGenerators.AxisPlacementUtilityGenerator();
|
|
116
|
+
const FlexGrowUtilityGenerator = new UtilityGenerators.FlexGrowUtilityGenerator();
|
|
117
|
+
const FlexShrinkUtilityGenerator = new UtilityGenerators.FlexShrinkUtilityGenerator();
|
|
118
|
+
const FlexWrapUtilityGenerator = new UtilityGenerators.FlexWrapUtilityGenerator();
|
|
119
|
+
const TransformUtilityGenerator = new UtilityGenerators.TransformUtilityGenerator();
|
|
120
|
+
const WidthUtilityGenerator = new UtilityGenerators.WidthUtilityGenerator();
|
|
121
|
+
const HeightUtilityGenerator = new UtilityGenerators.HeightUtilityGenerator();
|
|
122
|
+
|
|
123
|
+
const generators = [
|
|
124
|
+
BackdropUtilityGenerator,
|
|
125
|
+
BorderWidthUtilityGenerator,
|
|
126
|
+
FontFamilyUtilityGenerator,
|
|
127
|
+
FontSizeUtilityGenerator,
|
|
128
|
+
FontWeightUtilityGenerator,
|
|
129
|
+
LetterSpacingUtilityGenerator,
|
|
130
|
+
LineHeightUtilityGenerator,
|
|
131
|
+
OpacityUtilityGenerator,
|
|
132
|
+
RadiusUtilityGenerator,
|
|
133
|
+
ShadowUtilityGenerator,
|
|
134
|
+
ZIndexUtilityGenerator,
|
|
135
|
+
FontColorUtilityGenerator,
|
|
136
|
+
BackgroundUtilityGenerator,
|
|
137
|
+
BorderColorUtilityGenerator,
|
|
138
|
+
PaddingUtilityGenerator,
|
|
139
|
+
MarginUtilityGenerator,
|
|
140
|
+
GapUtilityGenerator,
|
|
141
|
+
PositionersUtilityGenerator,
|
|
142
|
+
MaxWidthUtilityGenerator,
|
|
143
|
+
MaxHeightUtilityGenerator,
|
|
144
|
+
DisplayUtilityGenerator,
|
|
145
|
+
CursorUtilityGenerator,
|
|
146
|
+
ObjectFitUtilityGenerator,
|
|
147
|
+
PositionUtilityGenerator,
|
|
148
|
+
RotateUtilityGenerator,
|
|
149
|
+
ObjectPositionUtilityGenerator,
|
|
150
|
+
PointerEventUtilityGenerator,
|
|
151
|
+
OverflowUtilityGenerator,
|
|
152
|
+
FlexDirectionUtilityGenerator,
|
|
153
|
+
AxisPlacementUtilityGenerator,
|
|
154
|
+
FlexGrowUtilityGenerator,
|
|
155
|
+
FlexShrinkUtilityGenerator,
|
|
156
|
+
FlexWrapUtilityGenerator,
|
|
157
|
+
TransformUtilityGenerator,
|
|
158
|
+
WidthUtilityGenerator,
|
|
159
|
+
HeightUtilityGenerator,
|
|
160
|
+
];
|
|
161
|
+
|
|
162
|
+
for (const generator of generators) {
|
|
163
|
+
output += generator.header();
|
|
164
|
+
output += generator.css();
|
|
165
|
+
output += generator.footer();
|
|
166
|
+
}
|
|
167
|
+
|
|
168
|
+
await Bun.file("dist/v2/main.css").write(output);
|
|
169
|
+
|
|
170
|
+
let types = "";
|
|
171
|
+
|
|
172
|
+
// for (const token of tokens) {
|
|
173
|
+
// types += token.toTypeScript();
|
|
174
|
+
// }
|
|
175
|
+
|
|
176
|
+
types += `
|
|
177
|
+
export {};
|
|
178
|
+
|
|
179
|
+
import "react";
|
|
180
|
+
declare module "react" { interface HTMLAttributes<T> {
|
|
181
|
+
`;
|
|
182
|
+
|
|
183
|
+
for (const generator of generators) {
|
|
184
|
+
types += generator.toTypeScript();
|
|
185
|
+
}
|
|
186
|
+
|
|
187
|
+
types += "}}";
|
|
188
|
+
|
|
189
|
+
await Bun.file("dist/v2/index.d.ts").write(types);
|
|
190
|
+
}
|
|
191
|
+
}
|
|
192
|
+
|
|
193
|
+
export async function main() {
|
|
194
|
+
await GeneratorProcessor.process();
|
|
195
|
+
}
|