solfaces 1.0.0
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/LICENSE +21 -0
- package/README.md +518 -0
- package/dist/agent/index.cjs +51 -0
- package/dist/agent/index.cjs.map +1 -0
- package/dist/agent/index.d.cts +65 -0
- package/dist/agent/index.d.ts +65 -0
- package/dist/agent/index.js +6 -0
- package/dist/agent/index.js.map +1 -0
- package/dist/agent/mcp-server.cjs +836 -0
- package/dist/chunk-2DIKGLXZ.cjs +126 -0
- package/dist/chunk-2DIKGLXZ.cjs.map +1 -0
- package/dist/chunk-A6N3RPEA.cjs +111 -0
- package/dist/chunk-A6N3RPEA.cjs.map +1 -0
- package/dist/chunk-CVFO7YHY.cjs +97 -0
- package/dist/chunk-CVFO7YHY.cjs.map +1 -0
- package/dist/chunk-H3SK3MNX.cjs +409 -0
- package/dist/chunk-H3SK3MNX.cjs.map +1 -0
- package/dist/chunk-KSGFMW33.js +401 -0
- package/dist/chunk-KSGFMW33.js.map +1 -0
- package/dist/chunk-LQWJRHGC.js +86 -0
- package/dist/chunk-LQWJRHGC.js.map +1 -0
- package/dist/chunk-RX6D5FGH.js +211 -0
- package/dist/chunk-RX6D5FGH.js.map +1 -0
- package/dist/chunk-SNJABBAT.js +107 -0
- package/dist/chunk-SNJABBAT.js.map +1 -0
- package/dist/chunk-VMNATBH3.cjs +222 -0
- package/dist/chunk-VMNATBH3.cjs.map +1 -0
- package/dist/chunk-WURY4QGH.js +117 -0
- package/dist/chunk-WURY4QGH.js.map +1 -0
- package/dist/core/index.cjs +82 -0
- package/dist/core/index.cjs.map +1 -0
- package/dist/core/index.d.cts +104 -0
- package/dist/core/index.d.ts +104 -0
- package/dist/core/index.js +5 -0
- package/dist/core/index.js.map +1 -0
- package/dist/index.cjs +100 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.cts +4 -0
- package/dist/index.d.ts +4 -0
- package/dist/index.js +7 -0
- package/dist/index.js.map +1 -0
- package/dist/react/index.cjs +543 -0
- package/dist/react/index.cjs.map +1 -0
- package/dist/react/index.d.cts +28 -0
- package/dist/react/index.d.ts +28 -0
- package/dist/react/index.js +541 -0
- package/dist/react/index.js.map +1 -0
- package/dist/solfaces.cdn.global.js +3 -0
- package/dist/solfaces.cdn.global.js.map +1 -0
- package/dist/themes/index.cjs +48 -0
- package/dist/themes/index.cjs.map +1 -0
- package/dist/themes/index.d.cts +14 -0
- package/dist/themes/index.d.ts +14 -0
- package/dist/themes/index.js +3 -0
- package/dist/themes/index.js.map +1 -0
- package/dist/traits-DAFZnXeS.d.cts +61 -0
- package/dist/traits-DAFZnXeS.d.ts +61 -0
- package/dist/vanilla/index.cjs +43 -0
- package/dist/vanilla/index.cjs.map +1 -0
- package/dist/vanilla/index.d.cts +7 -0
- package/dist/vanilla/index.d.ts +7 -0
- package/dist/vanilla/index.js +39 -0
- package/dist/vanilla/index.js.map +1 -0
- package/package.json +100 -0
- package/python/solfaces.py +475 -0
- package/skill.md +463 -0
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import * as react_jsx_runtime from 'react/jsx-runtime';
|
|
2
|
+
import { SVGAttributes } from 'react';
|
|
3
|
+
import { a as SolFaceTheme, b as SolFaceTraits } from '../traits-DAFZnXeS.js';
|
|
4
|
+
|
|
5
|
+
interface SolFaceProps extends Omit<SVGAttributes<SVGSVGElement>, "viewBox" | "xmlns"> {
|
|
6
|
+
walletAddress: string;
|
|
7
|
+
size?: number;
|
|
8
|
+
enableBlink?: boolean | {
|
|
9
|
+
duration?: number;
|
|
10
|
+
delay?: number;
|
|
11
|
+
};
|
|
12
|
+
theme?: SolFaceTheme;
|
|
13
|
+
traitOverrides?: Partial<SolFaceTraits>;
|
|
14
|
+
colorOverrides?: {
|
|
15
|
+
skin?: string;
|
|
16
|
+
eyes?: string;
|
|
17
|
+
hair?: string;
|
|
18
|
+
bg?: string;
|
|
19
|
+
mouth?: string;
|
|
20
|
+
eyebrow?: string;
|
|
21
|
+
accessory?: string;
|
|
22
|
+
nose?: string;
|
|
23
|
+
eyeWhite?: string;
|
|
24
|
+
};
|
|
25
|
+
}
|
|
26
|
+
declare function SolFace({ walletAddress, size, enableBlink, theme, traitOverrides, colorOverrides, className, style, ...rest }: SolFaceProps): react_jsx_runtime.JSX.Element;
|
|
27
|
+
|
|
28
|
+
export { SolFace, type SolFaceProps };
|
|
@@ -0,0 +1,541 @@
|
|
|
1
|
+
import { generateTraits, SKIN_COLORS, EYE_COLORS, HAIR_COLORS, BG_COLORS } from '../chunk-WURY4QGH.js';
|
|
2
|
+
import { useMemo } from 'react';
|
|
3
|
+
import { jsxs, jsx, Fragment } from 'react/jsx-runtime';
|
|
4
|
+
|
|
5
|
+
function renderFace(traits, skin) {
|
|
6
|
+
switch (traits.faceShape) {
|
|
7
|
+
case 0:
|
|
8
|
+
return /* @__PURE__ */ jsx("circle", { cx: "32", cy: "34", r: "20", fill: skin });
|
|
9
|
+
case 1:
|
|
10
|
+
return /* @__PURE__ */ jsx("rect", { x: "12", y: "14", width: "40", height: "40", rx: "8", ry: "8", fill: skin });
|
|
11
|
+
case 2:
|
|
12
|
+
return /* @__PURE__ */ jsx("ellipse", { cx: "32", cy: "34", rx: "18", ry: "22", fill: skin });
|
|
13
|
+
case 3:
|
|
14
|
+
return /* @__PURE__ */ jsx(
|
|
15
|
+
"path",
|
|
16
|
+
{
|
|
17
|
+
d: "M32 12 L50 24 L50 44 L32 56 L14 44 L14 24 Z",
|
|
18
|
+
fill: skin,
|
|
19
|
+
strokeLinejoin: "round"
|
|
20
|
+
}
|
|
21
|
+
);
|
|
22
|
+
default:
|
|
23
|
+
return /* @__PURE__ */ jsx("circle", { cx: "32", cy: "34", r: "20", fill: skin });
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
function renderEyes(traits, eyeCol, eyeWhite = "white") {
|
|
27
|
+
const lx = 24, rx = 40, y = 30;
|
|
28
|
+
switch (traits.eyeStyle) {
|
|
29
|
+
case 0:
|
|
30
|
+
return /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
31
|
+
/* @__PURE__ */ jsx("circle", { cx: lx, cy: y, r: "3.5", fill: eyeWhite }),
|
|
32
|
+
/* @__PURE__ */ jsx("circle", { cx: lx + 1, cy: y, r: "2", fill: eyeCol }),
|
|
33
|
+
/* @__PURE__ */ jsx("circle", { cx: rx, cy: y, r: "3.5", fill: eyeWhite }),
|
|
34
|
+
/* @__PURE__ */ jsx("circle", { cx: rx + 1, cy: y, r: "2", fill: eyeCol })
|
|
35
|
+
] });
|
|
36
|
+
case 1:
|
|
37
|
+
return /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
38
|
+
/* @__PURE__ */ jsx("circle", { cx: lx, cy: y, r: "2", fill: eyeCol }),
|
|
39
|
+
/* @__PURE__ */ jsx("circle", { cx: rx, cy: y, r: "2", fill: eyeCol })
|
|
40
|
+
] });
|
|
41
|
+
case 2:
|
|
42
|
+
return /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
43
|
+
/* @__PURE__ */ jsx("ellipse", { cx: lx, cy: y, rx: "4", ry: "2.5", fill: eyeWhite }),
|
|
44
|
+
/* @__PURE__ */ jsx("circle", { cx: lx + 0.5, cy: y, r: "1.5", fill: eyeCol }),
|
|
45
|
+
/* @__PURE__ */ jsx("ellipse", { cx: rx, cy: y, rx: "4", ry: "2.5", fill: eyeWhite }),
|
|
46
|
+
/* @__PURE__ */ jsx("circle", { cx: rx + 0.5, cy: y, r: "1.5", fill: eyeCol })
|
|
47
|
+
] });
|
|
48
|
+
case 3:
|
|
49
|
+
return /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
50
|
+
/* @__PURE__ */ jsx("circle", { cx: lx, cy: y, r: "4.5", fill: eyeWhite }),
|
|
51
|
+
/* @__PURE__ */ jsx("circle", { cx: lx, cy: y + 0.5, r: "2.5", fill: eyeCol }),
|
|
52
|
+
/* @__PURE__ */ jsx("circle", { cx: rx, cy: y, r: "4.5", fill: eyeWhite }),
|
|
53
|
+
/* @__PURE__ */ jsx("circle", { cx: rx, cy: y + 0.5, r: "2.5", fill: eyeCol })
|
|
54
|
+
] });
|
|
55
|
+
case 4:
|
|
56
|
+
return /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
57
|
+
/* @__PURE__ */ jsx("ellipse", { cx: lx, cy: y + 1, rx: "3.5", ry: "2", fill: eyeWhite }),
|
|
58
|
+
/* @__PURE__ */ jsx("circle", { cx: lx, cy: y + 1, r: "1.5", fill: eyeCol }),
|
|
59
|
+
/* @__PURE__ */ jsx(
|
|
60
|
+
"line",
|
|
61
|
+
{
|
|
62
|
+
x1: lx - 4,
|
|
63
|
+
y1: y - 0.5,
|
|
64
|
+
x2: lx + 4,
|
|
65
|
+
y2: y - 0.5,
|
|
66
|
+
stroke: eyeCol,
|
|
67
|
+
strokeWidth: "1",
|
|
68
|
+
strokeLinecap: "round"
|
|
69
|
+
}
|
|
70
|
+
),
|
|
71
|
+
/* @__PURE__ */ jsx("ellipse", { cx: rx, cy: y + 1, rx: "3.5", ry: "2", fill: eyeWhite }),
|
|
72
|
+
/* @__PURE__ */ jsx("circle", { cx: rx, cy: y + 1, r: "1.5", fill: eyeCol }),
|
|
73
|
+
/* @__PURE__ */ jsx(
|
|
74
|
+
"line",
|
|
75
|
+
{
|
|
76
|
+
x1: rx - 4,
|
|
77
|
+
y1: y - 0.5,
|
|
78
|
+
x2: rx + 4,
|
|
79
|
+
y2: y - 0.5,
|
|
80
|
+
stroke: eyeCol,
|
|
81
|
+
strokeWidth: "1",
|
|
82
|
+
strokeLinecap: "round"
|
|
83
|
+
}
|
|
84
|
+
)
|
|
85
|
+
] });
|
|
86
|
+
case 5:
|
|
87
|
+
return /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
88
|
+
/* @__PURE__ */ jsx(
|
|
89
|
+
"path",
|
|
90
|
+
{
|
|
91
|
+
d: `M${lx - 3} ${y} Q${lx} ${y + 3} ${lx + 3} ${y}`,
|
|
92
|
+
fill: "none",
|
|
93
|
+
stroke: eyeCol,
|
|
94
|
+
strokeWidth: "1.5",
|
|
95
|
+
strokeLinecap: "round"
|
|
96
|
+
}
|
|
97
|
+
),
|
|
98
|
+
/* @__PURE__ */ jsx("circle", { cx: rx, cy: y, r: "3.5", fill: eyeWhite }),
|
|
99
|
+
/* @__PURE__ */ jsx("circle", { cx: rx + 1, cy: y, r: "2", fill: eyeCol })
|
|
100
|
+
] });
|
|
101
|
+
case 6:
|
|
102
|
+
return /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
103
|
+
/* @__PURE__ */ jsx("circle", { cx: lx, cy: y, r: "3", fill: eyeWhite }),
|
|
104
|
+
/* @__PURE__ */ jsx("circle", { cx: lx + 0.5, cy: y, r: "1.5", fill: eyeCol }),
|
|
105
|
+
/* @__PURE__ */ jsx(
|
|
106
|
+
"line",
|
|
107
|
+
{
|
|
108
|
+
x1: lx + 2,
|
|
109
|
+
y1: y - 3,
|
|
110
|
+
x2: lx + 3.5,
|
|
111
|
+
y2: y - 4.5,
|
|
112
|
+
stroke: eyeCol,
|
|
113
|
+
strokeWidth: "0.8",
|
|
114
|
+
strokeLinecap: "round"
|
|
115
|
+
}
|
|
116
|
+
),
|
|
117
|
+
/* @__PURE__ */ jsx(
|
|
118
|
+
"line",
|
|
119
|
+
{
|
|
120
|
+
x1: lx + 3,
|
|
121
|
+
y1: y - 2,
|
|
122
|
+
x2: lx + 4.5,
|
|
123
|
+
y2: y - 3,
|
|
124
|
+
stroke: eyeCol,
|
|
125
|
+
strokeWidth: "0.8",
|
|
126
|
+
strokeLinecap: "round"
|
|
127
|
+
}
|
|
128
|
+
),
|
|
129
|
+
/* @__PURE__ */ jsx("circle", { cx: rx, cy: y, r: "3", fill: eyeWhite }),
|
|
130
|
+
/* @__PURE__ */ jsx("circle", { cx: rx + 0.5, cy: y, r: "1.5", fill: eyeCol }),
|
|
131
|
+
/* @__PURE__ */ jsx(
|
|
132
|
+
"line",
|
|
133
|
+
{
|
|
134
|
+
x1: rx + 2,
|
|
135
|
+
y1: y - 3,
|
|
136
|
+
x2: rx + 3.5,
|
|
137
|
+
y2: y - 4.5,
|
|
138
|
+
stroke: eyeCol,
|
|
139
|
+
strokeWidth: "0.8",
|
|
140
|
+
strokeLinecap: "round"
|
|
141
|
+
}
|
|
142
|
+
),
|
|
143
|
+
/* @__PURE__ */ jsx(
|
|
144
|
+
"line",
|
|
145
|
+
{
|
|
146
|
+
x1: rx + 3,
|
|
147
|
+
y1: y - 2,
|
|
148
|
+
x2: rx + 4.5,
|
|
149
|
+
y2: y - 3,
|
|
150
|
+
stroke: eyeCol,
|
|
151
|
+
strokeWidth: "0.8",
|
|
152
|
+
strokeLinecap: "round"
|
|
153
|
+
}
|
|
154
|
+
)
|
|
155
|
+
] });
|
|
156
|
+
case 7:
|
|
157
|
+
return /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
158
|
+
/* @__PURE__ */ jsx("ellipse", { cx: lx, cy: y, rx: "4", ry: "1.2", fill: eyeWhite }),
|
|
159
|
+
/* @__PURE__ */ jsx("ellipse", { cx: lx + 0.5, cy: y, rx: "2", ry: "1", fill: eyeCol }),
|
|
160
|
+
/* @__PURE__ */ jsx("ellipse", { cx: rx, cy: y, rx: "4", ry: "1.2", fill: eyeWhite }),
|
|
161
|
+
/* @__PURE__ */ jsx("ellipse", { cx: rx + 0.5, cy: y, rx: "2", ry: "1", fill: eyeCol })
|
|
162
|
+
] });
|
|
163
|
+
default:
|
|
164
|
+
return /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
165
|
+
/* @__PURE__ */ jsx("circle", { cx: lx, cy: y, r: "3", fill: eyeWhite }),
|
|
166
|
+
/* @__PURE__ */ jsx("circle", { cx: lx + 1, cy: y, r: "2", fill: eyeCol }),
|
|
167
|
+
/* @__PURE__ */ jsx("circle", { cx: rx, cy: y, r: "3", fill: eyeWhite }),
|
|
168
|
+
/* @__PURE__ */ jsx("circle", { cx: rx + 1, cy: y, r: "2", fill: eyeCol })
|
|
169
|
+
] });
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
function renderEyebrows(traits, col) {
|
|
173
|
+
const lx = 24, rx = 40, y = 25;
|
|
174
|
+
switch (traits.eyebrows) {
|
|
175
|
+
case 0:
|
|
176
|
+
return null;
|
|
177
|
+
case 1:
|
|
178
|
+
return /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
179
|
+
/* @__PURE__ */ jsx(
|
|
180
|
+
"line",
|
|
181
|
+
{
|
|
182
|
+
x1: lx - 3,
|
|
183
|
+
y1: y,
|
|
184
|
+
x2: lx + 3,
|
|
185
|
+
y2: y,
|
|
186
|
+
stroke: col,
|
|
187
|
+
strokeWidth: "0.8",
|
|
188
|
+
strokeLinecap: "round"
|
|
189
|
+
}
|
|
190
|
+
),
|
|
191
|
+
/* @__PURE__ */ jsx(
|
|
192
|
+
"line",
|
|
193
|
+
{
|
|
194
|
+
x1: rx - 3,
|
|
195
|
+
y1: y,
|
|
196
|
+
x2: rx + 3,
|
|
197
|
+
y2: y,
|
|
198
|
+
stroke: col,
|
|
199
|
+
strokeWidth: "0.8",
|
|
200
|
+
strokeLinecap: "round"
|
|
201
|
+
}
|
|
202
|
+
)
|
|
203
|
+
] });
|
|
204
|
+
case 2:
|
|
205
|
+
return /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
206
|
+
/* @__PURE__ */ jsx(
|
|
207
|
+
"line",
|
|
208
|
+
{
|
|
209
|
+
x1: lx - 3.5,
|
|
210
|
+
y1: y,
|
|
211
|
+
x2: lx + 3.5,
|
|
212
|
+
y2: y,
|
|
213
|
+
stroke: col,
|
|
214
|
+
strokeWidth: "2",
|
|
215
|
+
strokeLinecap: "round"
|
|
216
|
+
}
|
|
217
|
+
),
|
|
218
|
+
/* @__PURE__ */ jsx(
|
|
219
|
+
"line",
|
|
220
|
+
{
|
|
221
|
+
x1: rx - 3.5,
|
|
222
|
+
y1: y,
|
|
223
|
+
x2: rx + 3.5,
|
|
224
|
+
y2: y,
|
|
225
|
+
stroke: col,
|
|
226
|
+
strokeWidth: "2",
|
|
227
|
+
strokeLinecap: "round"
|
|
228
|
+
}
|
|
229
|
+
)
|
|
230
|
+
] });
|
|
231
|
+
case 3:
|
|
232
|
+
return /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
233
|
+
/* @__PURE__ */ jsx(
|
|
234
|
+
"path",
|
|
235
|
+
{
|
|
236
|
+
d: `M${lx - 3.5} ${y + 1} Q${lx} ${y - 2} ${lx + 3.5} ${y + 1}`,
|
|
237
|
+
fill: "none",
|
|
238
|
+
stroke: col,
|
|
239
|
+
strokeWidth: "1",
|
|
240
|
+
strokeLinecap: "round"
|
|
241
|
+
}
|
|
242
|
+
),
|
|
243
|
+
/* @__PURE__ */ jsx(
|
|
244
|
+
"path",
|
|
245
|
+
{
|
|
246
|
+
d: `M${rx - 3.5} ${y + 1} Q${rx} ${y - 2} ${rx + 3.5} ${y + 1}`,
|
|
247
|
+
fill: "none",
|
|
248
|
+
stroke: col,
|
|
249
|
+
strokeWidth: "1",
|
|
250
|
+
strokeLinecap: "round"
|
|
251
|
+
}
|
|
252
|
+
)
|
|
253
|
+
] });
|
|
254
|
+
case 4:
|
|
255
|
+
return /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
256
|
+
/* @__PURE__ */ jsx(
|
|
257
|
+
"line",
|
|
258
|
+
{
|
|
259
|
+
x1: lx - 3,
|
|
260
|
+
y1: y - 1,
|
|
261
|
+
x2: lx + 3,
|
|
262
|
+
y2: y + 1,
|
|
263
|
+
stroke: col,
|
|
264
|
+
strokeWidth: "1.2",
|
|
265
|
+
strokeLinecap: "round"
|
|
266
|
+
}
|
|
267
|
+
),
|
|
268
|
+
/* @__PURE__ */ jsx(
|
|
269
|
+
"line",
|
|
270
|
+
{
|
|
271
|
+
x1: rx - 3,
|
|
272
|
+
y1: y + 1,
|
|
273
|
+
x2: rx + 3,
|
|
274
|
+
y2: y - 1,
|
|
275
|
+
stroke: col,
|
|
276
|
+
strokeWidth: "1.2",
|
|
277
|
+
strokeLinecap: "round"
|
|
278
|
+
}
|
|
279
|
+
)
|
|
280
|
+
] });
|
|
281
|
+
default:
|
|
282
|
+
return null;
|
|
283
|
+
}
|
|
284
|
+
}
|
|
285
|
+
function renderNose(traits, skin, noseCol) {
|
|
286
|
+
const cx = 32, y = 36;
|
|
287
|
+
const shadow = noseCol ?? skin + "aa";
|
|
288
|
+
switch (traits.nose) {
|
|
289
|
+
case 0:
|
|
290
|
+
return null;
|
|
291
|
+
case 1:
|
|
292
|
+
return /* @__PURE__ */ jsx("circle", { cx, cy: y, r: "1.5", fill: shadow });
|
|
293
|
+
case 2:
|
|
294
|
+
return /* @__PURE__ */ jsx(
|
|
295
|
+
"path",
|
|
296
|
+
{
|
|
297
|
+
d: `M${cx} ${y - 1.5} L${cx + 2.5} ${y + 2} L${cx - 2.5} ${y + 2} Z`,
|
|
298
|
+
fill: shadow
|
|
299
|
+
}
|
|
300
|
+
);
|
|
301
|
+
case 3:
|
|
302
|
+
return /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
303
|
+
/* @__PURE__ */ jsx("circle", { cx: cx - 1.5, cy: y, r: "1", fill: shadow }),
|
|
304
|
+
/* @__PURE__ */ jsx("circle", { cx: cx + 1.5, cy: y, r: "1", fill: shadow })
|
|
305
|
+
] });
|
|
306
|
+
default:
|
|
307
|
+
return null;
|
|
308
|
+
}
|
|
309
|
+
}
|
|
310
|
+
function renderMouth(traits, col, teethCol = "white") {
|
|
311
|
+
const cx = 32, y = 42;
|
|
312
|
+
switch (traits.mouth) {
|
|
313
|
+
case 0:
|
|
314
|
+
return /* @__PURE__ */ jsx(
|
|
315
|
+
"path",
|
|
316
|
+
{
|
|
317
|
+
d: `M${cx - 4} ${y} Q${cx} ${y + 4} ${cx + 4} ${y}`,
|
|
318
|
+
fill: "none",
|
|
319
|
+
stroke: col,
|
|
320
|
+
strokeWidth: "1.2",
|
|
321
|
+
strokeLinecap: "round"
|
|
322
|
+
}
|
|
323
|
+
);
|
|
324
|
+
case 1:
|
|
325
|
+
return /* @__PURE__ */ jsx(
|
|
326
|
+
"line",
|
|
327
|
+
{
|
|
328
|
+
x1: cx - 3,
|
|
329
|
+
y1: y + 1,
|
|
330
|
+
x2: cx + 3,
|
|
331
|
+
y2: y + 1,
|
|
332
|
+
stroke: col,
|
|
333
|
+
strokeWidth: "1.2",
|
|
334
|
+
strokeLinecap: "round"
|
|
335
|
+
}
|
|
336
|
+
);
|
|
337
|
+
case 2:
|
|
338
|
+
return /* @__PURE__ */ jsx(
|
|
339
|
+
"path",
|
|
340
|
+
{
|
|
341
|
+
d: `M${cx - 6} ${y} Q${cx} ${y + 5} ${cx + 6} ${y}`,
|
|
342
|
+
fill: "none",
|
|
343
|
+
stroke: col,
|
|
344
|
+
strokeWidth: "1.5",
|
|
345
|
+
strokeLinecap: "round"
|
|
346
|
+
}
|
|
347
|
+
);
|
|
348
|
+
case 3:
|
|
349
|
+
return /* @__PURE__ */ jsx("ellipse", { cx, cy: y + 1, rx: "3", ry: "2.5", fill: col, opacity: "0.8" });
|
|
350
|
+
case 4:
|
|
351
|
+
return /* @__PURE__ */ jsx(
|
|
352
|
+
"path",
|
|
353
|
+
{
|
|
354
|
+
d: `M${cx - 4} ${y + 1} Q${cx - 1} ${y + 1} ${cx + 4} ${y - 1}`,
|
|
355
|
+
fill: "none",
|
|
356
|
+
stroke: col,
|
|
357
|
+
strokeWidth: "1.2",
|
|
358
|
+
strokeLinecap: "round"
|
|
359
|
+
}
|
|
360
|
+
);
|
|
361
|
+
case 5:
|
|
362
|
+
return /* @__PURE__ */ jsx(
|
|
363
|
+
"path",
|
|
364
|
+
{
|
|
365
|
+
d: `M${cx - 6} ${y} Q${cx} ${y + 6} ${cx + 6} ${y}`,
|
|
366
|
+
fill: teethCol,
|
|
367
|
+
stroke: col,
|
|
368
|
+
strokeWidth: "1"
|
|
369
|
+
}
|
|
370
|
+
);
|
|
371
|
+
default:
|
|
372
|
+
return /* @__PURE__ */ jsx(
|
|
373
|
+
"path",
|
|
374
|
+
{
|
|
375
|
+
d: `M${cx - 4} ${y} Q${cx} ${y + 4} ${cx + 4} ${y}`,
|
|
376
|
+
fill: "none",
|
|
377
|
+
stroke: col,
|
|
378
|
+
strokeWidth: "1.2",
|
|
379
|
+
strokeLinecap: "round"
|
|
380
|
+
}
|
|
381
|
+
);
|
|
382
|
+
}
|
|
383
|
+
}
|
|
384
|
+
function renderHair(traits, hairCol) {
|
|
385
|
+
switch (traits.hairStyle) {
|
|
386
|
+
case 0:
|
|
387
|
+
return null;
|
|
388
|
+
case 1:
|
|
389
|
+
return /* @__PURE__ */ jsx("rect", { x: "14", y: "12", width: "36", height: "12", rx: "6", ry: "6", fill: hairCol });
|
|
390
|
+
case 2:
|
|
391
|
+
return /* @__PURE__ */ jsxs("g", { fill: hairCol, children: [
|
|
392
|
+
/* @__PURE__ */ jsx("rect", { x: "14", y: "16", width: "36", height: "8", rx: "2" }),
|
|
393
|
+
/* @__PURE__ */ jsx("polygon", { points: "18,16 22,6 26,16" }),
|
|
394
|
+
/* @__PURE__ */ jsx("polygon", { points: "26,16 30,4 34,16" }),
|
|
395
|
+
/* @__PURE__ */ jsx("polygon", { points: "34,16 38,6 42,16" }),
|
|
396
|
+
/* @__PURE__ */ jsx("polygon", { points: "42,16 46,10 48,16" })
|
|
397
|
+
] });
|
|
398
|
+
case 3:
|
|
399
|
+
return /* @__PURE__ */ jsxs("g", { fill: hairCol, children: [
|
|
400
|
+
/* @__PURE__ */ jsx("rect", { x: "14", y: "14", width: "36", height: "10", rx: "4" }),
|
|
401
|
+
/* @__PURE__ */ jsx("path", { d: "M14 18 Q8 14 10 8 Q14 10 20 14 Z" })
|
|
402
|
+
] });
|
|
403
|
+
case 4:
|
|
404
|
+
return /* @__PURE__ */ jsx("rect", { x: "26", y: "4", width: "12", height: "20", rx: "4", ry: "2", fill: hairCol });
|
|
405
|
+
case 5:
|
|
406
|
+
return /* @__PURE__ */ jsxs("g", { fill: hairCol, children: [
|
|
407
|
+
/* @__PURE__ */ jsx("rect", { x: "14", y: "12", width: "36", height: "10", rx: "4" }),
|
|
408
|
+
/* @__PURE__ */ jsx("rect", { x: "10", y: "18", width: "8", height: "24", rx: "3" }),
|
|
409
|
+
/* @__PURE__ */ jsx("rect", { x: "46", y: "18", width: "8", height: "24", rx: "3" })
|
|
410
|
+
] });
|
|
411
|
+
case 6:
|
|
412
|
+
return /* @__PURE__ */ jsx(
|
|
413
|
+
"path",
|
|
414
|
+
{
|
|
415
|
+
d: "M12 22 Q12 10 32 10 Q52 10 52 22 L52 38 Q52 42 48 42 L48 26 Q48 16 32 16 Q16 16 16 26 L16 42 Q12 42 12 38 Z",
|
|
416
|
+
fill: hairCol
|
|
417
|
+
}
|
|
418
|
+
);
|
|
419
|
+
case 7:
|
|
420
|
+
return /* @__PURE__ */ jsx("rect", { x: "15", y: "13", width: "34", height: "9", rx: "8", ry: "4", fill: hairCol, opacity: "0.7" });
|
|
421
|
+
default:
|
|
422
|
+
return null;
|
|
423
|
+
}
|
|
424
|
+
}
|
|
425
|
+
function renderAccessory(traits, col) {
|
|
426
|
+
switch (traits.accessory) {
|
|
427
|
+
case 0:
|
|
428
|
+
case 1:
|
|
429
|
+
return null;
|
|
430
|
+
case 2:
|
|
431
|
+
return /* @__PURE__ */ jsxs("g", { fill: "none", stroke: col, strokeWidth: "1", children: [
|
|
432
|
+
/* @__PURE__ */ jsx("circle", { cx: "24", cy: "30", r: "5" }),
|
|
433
|
+
/* @__PURE__ */ jsx("circle", { cx: "40", cy: "30", r: "5" }),
|
|
434
|
+
/* @__PURE__ */ jsx("line", { x1: "29", y1: "30", x2: "35", y2: "30" }),
|
|
435
|
+
/* @__PURE__ */ jsx("line", { x1: "19", y1: "30", x2: "14", y2: "28" }),
|
|
436
|
+
/* @__PURE__ */ jsx("line", { x1: "45", y1: "30", x2: "50", y2: "28" })
|
|
437
|
+
] });
|
|
438
|
+
case 3:
|
|
439
|
+
return /* @__PURE__ */ jsxs("g", { fill: "none", stroke: col, strokeWidth: "1", children: [
|
|
440
|
+
/* @__PURE__ */ jsx("rect", { x: "19", y: "26", width: "10", height: "8", rx: "1" }),
|
|
441
|
+
/* @__PURE__ */ jsx("rect", { x: "35", y: "26", width: "10", height: "8", rx: "1" }),
|
|
442
|
+
/* @__PURE__ */ jsx("line", { x1: "29", y1: "30", x2: "35", y2: "30" }),
|
|
443
|
+
/* @__PURE__ */ jsx("line", { x1: "19", y1: "30", x2: "14", y2: "28" }),
|
|
444
|
+
/* @__PURE__ */ jsx("line", { x1: "45", y1: "30", x2: "50", y2: "28" })
|
|
445
|
+
] });
|
|
446
|
+
case 4:
|
|
447
|
+
return /* @__PURE__ */ jsx("circle", { cx: "11", cy: "36", r: "2", fill: col, stroke: col, strokeWidth: "0.5" });
|
|
448
|
+
case 5:
|
|
449
|
+
return /* @__PURE__ */ jsxs("g", { children: [
|
|
450
|
+
/* @__PURE__ */ jsx("rect", { x: "12", y: "20", width: "40", height: "4", rx: "1", fill: col }),
|
|
451
|
+
/* @__PURE__ */ jsx("path", { d: "M12 22 L8 26 L12 24 Z", fill: col })
|
|
452
|
+
] });
|
|
453
|
+
default:
|
|
454
|
+
return null;
|
|
455
|
+
}
|
|
456
|
+
}
|
|
457
|
+
function SolFace({
|
|
458
|
+
walletAddress,
|
|
459
|
+
size = 64,
|
|
460
|
+
enableBlink = false,
|
|
461
|
+
theme,
|
|
462
|
+
traitOverrides,
|
|
463
|
+
colorOverrides,
|
|
464
|
+
className,
|
|
465
|
+
style,
|
|
466
|
+
...rest
|
|
467
|
+
}) {
|
|
468
|
+
const traits = useMemo(
|
|
469
|
+
() => generateTraits(walletAddress, traitOverrides),
|
|
470
|
+
[walletAddress, traitOverrides]
|
|
471
|
+
);
|
|
472
|
+
const skinColors = theme?.skinColors ?? SKIN_COLORS;
|
|
473
|
+
const eyeColors = theme?.eyeColors ?? EYE_COLORS;
|
|
474
|
+
const hairColors = theme?.hairColors ?? HAIR_COLORS;
|
|
475
|
+
const bgColors = theme?.bgColors ?? BG_COLORS;
|
|
476
|
+
const skin = colorOverrides?.skin ?? skinColors[traits.skinColor % skinColors.length];
|
|
477
|
+
const eyeCol = colorOverrides?.eyes ?? eyeColors[traits.eyeColor % eyeColors.length];
|
|
478
|
+
const hairCol = colorOverrides?.hair ?? hairColors[traits.hairColor % hairColors.length];
|
|
479
|
+
const bgCol = colorOverrides?.bg ?? bgColors[traits.bgColor % bgColors.length];
|
|
480
|
+
const bgOpacity = theme?.bgOpacity ?? 0.15;
|
|
481
|
+
const bgRadius = theme?.bgRadius ?? 4;
|
|
482
|
+
const mouthCol = colorOverrides?.mouth ?? theme?.mouthColor ?? "#c05050";
|
|
483
|
+
const browCol = colorOverrides?.eyebrow ?? theme?.eyebrowColor ?? "#2a2020";
|
|
484
|
+
const accCol = colorOverrides?.accessory ?? theme?.accessoryColor ?? "#444";
|
|
485
|
+
const eyeWhite = colorOverrides?.eyeWhite ?? theme?.eyeWhiteColor ?? "white";
|
|
486
|
+
const noseCol = colorOverrides?.nose ?? theme?.noseColor;
|
|
487
|
+
const uid = useMemo(() => `sf-${walletAddress.slice(0, 8)}`, [walletAddress]);
|
|
488
|
+
const blinkEnabled = !!enableBlink;
|
|
489
|
+
const blinkDuration = typeof enableBlink === "object" ? enableBlink.duration ?? 4 : 4;
|
|
490
|
+
const blinkDelay = typeof enableBlink === "object" ? enableBlink.delay ?? 0 : 0;
|
|
491
|
+
const delayStr = blinkDelay ? ` ${blinkDelay}s` : "";
|
|
492
|
+
return /* @__PURE__ */ jsxs(
|
|
493
|
+
"svg",
|
|
494
|
+
{
|
|
495
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
496
|
+
viewBox: "0 0 64 64",
|
|
497
|
+
width: size,
|
|
498
|
+
height: size,
|
|
499
|
+
className,
|
|
500
|
+
style: { display: "block", ...style },
|
|
501
|
+
...rest,
|
|
502
|
+
children: [
|
|
503
|
+
blinkEnabled && /* @__PURE__ */ jsx("style", { children: `
|
|
504
|
+
@keyframes ${uid}-blink {
|
|
505
|
+
0%, 90%, 100% { transform: scaleY(1); }
|
|
506
|
+
95% { transform: scaleY(0.1); }
|
|
507
|
+
}
|
|
508
|
+
.${uid}-eyes {
|
|
509
|
+
animation: ${uid}-blink ${blinkDuration}s ease-in-out${delayStr} infinite;
|
|
510
|
+
transform-origin: 32px 30px;
|
|
511
|
+
}
|
|
512
|
+
` }),
|
|
513
|
+
/* @__PURE__ */ jsx("rect", { x: "0", y: "0", width: "64", height: "64", fill: bgCol, opacity: bgOpacity, rx: bgRadius }),
|
|
514
|
+
renderHair(traits, hairCol),
|
|
515
|
+
renderFace(traits, skin),
|
|
516
|
+
/* @__PURE__ */ jsx("g", { className: blinkEnabled ? `${uid}-eyes` : void 0, children: renderEyes(traits, eyeCol, eyeWhite) }),
|
|
517
|
+
renderEyebrows(traits, browCol),
|
|
518
|
+
renderNose(traits, skin, noseCol),
|
|
519
|
+
renderMouth(traits, mouthCol, eyeWhite),
|
|
520
|
+
renderAccessory(traits, accCol),
|
|
521
|
+
theme?.border && /* @__PURE__ */ jsx(
|
|
522
|
+
"rect",
|
|
523
|
+
{
|
|
524
|
+
x: "0",
|
|
525
|
+
y: "0",
|
|
526
|
+
width: "64",
|
|
527
|
+
height: "64",
|
|
528
|
+
fill: "none",
|
|
529
|
+
stroke: theme.border.color,
|
|
530
|
+
strokeWidth: theme.border.width,
|
|
531
|
+
rx: bgRadius
|
|
532
|
+
}
|
|
533
|
+
)
|
|
534
|
+
]
|
|
535
|
+
}
|
|
536
|
+
);
|
|
537
|
+
}
|
|
538
|
+
|
|
539
|
+
export { SolFace };
|
|
540
|
+
//# sourceMappingURL=index.js.map
|
|
541
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/react/SolFace.tsx"],"names":[],"mappings":"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","file":"index.js","sourcesContent":["\"use client\";\n\nimport { useMemo, type SVGAttributes } from \"react\";\nimport {\n generateTraits,\n SKIN_COLORS,\n EYE_COLORS,\n HAIR_COLORS,\n BG_COLORS,\n type SolFaceTraits,\n type SolFaceTheme,\n} from \"../core/traits\";\n\nexport interface SolFaceProps extends Omit<SVGAttributes<SVGSVGElement>, \"viewBox\" | \"xmlns\"> {\n walletAddress: string;\n size?: number;\n enableBlink?: boolean | {\n duration?: number;\n delay?: number;\n };\n theme?: SolFaceTheme;\n traitOverrides?: Partial<SolFaceTraits>;\n colorOverrides?: {\n skin?: string;\n eyes?: string;\n hair?: string;\n bg?: string;\n mouth?: string;\n eyebrow?: string;\n accessory?: string;\n nose?: string;\n eyeWhite?: string;\n };\n}\n\n// ─── Face Shape ─────────────────────────────────\n\nfunction renderFace(traits: SolFaceTraits, skin: string) {\n switch (traits.faceShape) {\n case 0:\n return <circle cx=\"32\" cy=\"34\" r=\"20\" fill={skin} />;\n case 1:\n return <rect x=\"12\" y=\"14\" width=\"40\" height=\"40\" rx=\"8\" ry=\"8\" fill={skin} />;\n case 2:\n return <ellipse cx=\"32\" cy=\"34\" rx=\"18\" ry=\"22\" fill={skin} />;\n case 3:\n return (\n <path\n d=\"M32 12 L50 24 L50 44 L32 56 L14 44 L14 24 Z\"\n fill={skin}\n strokeLinejoin=\"round\"\n />\n );\n default:\n return <circle cx=\"32\" cy=\"34\" r=\"20\" fill={skin} />;\n }\n}\n\n// ─── Eyes ────────────────────────────────────────\n\nfunction renderEyes(traits: SolFaceTraits, eyeCol: string, eyeWhite: string = \"white\") {\n const lx = 24, rx = 40, y = 30;\n\n switch (traits.eyeStyle) {\n case 0: // Round\n return (\n <>\n <circle cx={lx} cy={y} r=\"3.5\" fill={eyeWhite} />\n <circle cx={lx + 1} cy={y} r=\"2\" fill={eyeCol} />\n <circle cx={rx} cy={y} r=\"3.5\" fill={eyeWhite} />\n <circle cx={rx + 1} cy={y} r=\"2\" fill={eyeCol} />\n </>\n );\n case 1: // Dots\n return (\n <>\n <circle cx={lx} cy={y} r=\"2\" fill={eyeCol} />\n <circle cx={rx} cy={y} r=\"2\" fill={eyeCol} />\n </>\n );\n case 2: // Almond\n return (\n <>\n <ellipse cx={lx} cy={y} rx=\"4\" ry=\"2.5\" fill={eyeWhite} />\n <circle cx={lx + 0.5} cy={y} r=\"1.5\" fill={eyeCol} />\n <ellipse cx={rx} cy={y} rx=\"4\" ry=\"2.5\" fill={eyeWhite} />\n <circle cx={rx + 0.5} cy={y} r=\"1.5\" fill={eyeCol} />\n </>\n );\n case 3: // Wide\n return (\n <>\n <circle cx={lx} cy={y} r=\"4.5\" fill={eyeWhite} />\n <circle cx={lx} cy={y + 0.5} r=\"2.5\" fill={eyeCol} />\n <circle cx={rx} cy={y} r=\"4.5\" fill={eyeWhite} />\n <circle cx={rx} cy={y + 0.5} r=\"2.5\" fill={eyeCol} />\n </>\n );\n case 4: // Sleepy\n return (\n <>\n <ellipse cx={lx} cy={y + 1} rx=\"3.5\" ry=\"2\" fill={eyeWhite} />\n <circle cx={lx} cy={y + 1} r=\"1.5\" fill={eyeCol} />\n <line x1={lx - 4} y1={y - 0.5} x2={lx + 4} y2={y - 0.5}\n stroke={eyeCol} strokeWidth=\"1\" strokeLinecap=\"round\" />\n <ellipse cx={rx} cy={y + 1} rx=\"3.5\" ry=\"2\" fill={eyeWhite} />\n <circle cx={rx} cy={y + 1} r=\"1.5\" fill={eyeCol} />\n <line x1={rx - 4} y1={y - 0.5} x2={rx + 4} y2={y - 0.5}\n stroke={eyeCol} strokeWidth=\"1\" strokeLinecap=\"round\" />\n </>\n );\n case 5: // Winking\n return (\n <>\n <path d={`M${lx - 3} ${y} Q${lx} ${y + 3} ${lx + 3} ${y}`}\n fill=\"none\" stroke={eyeCol} strokeWidth=\"1.5\" strokeLinecap=\"round\" />\n <circle cx={rx} cy={y} r=\"3.5\" fill={eyeWhite} />\n <circle cx={rx + 1} cy={y} r=\"2\" fill={eyeCol} />\n </>\n );\n case 6: // Lashes\n return (\n <>\n <circle cx={lx} cy={y} r=\"3\" fill={eyeWhite} />\n <circle cx={lx + 0.5} cy={y} r=\"1.5\" fill={eyeCol} />\n <line x1={lx + 2} y1={y - 3} x2={lx + 3.5} y2={y - 4.5}\n stroke={eyeCol} strokeWidth=\"0.8\" strokeLinecap=\"round\" />\n <line x1={lx + 3} y1={y - 2} x2={lx + 4.5} y2={y - 3}\n stroke={eyeCol} strokeWidth=\"0.8\" strokeLinecap=\"round\" />\n <circle cx={rx} cy={y} r=\"3\" fill={eyeWhite} />\n <circle cx={rx + 0.5} cy={y} r=\"1.5\" fill={eyeCol} />\n <line x1={rx + 2} y1={y - 3} x2={rx + 3.5} y2={y - 4.5}\n stroke={eyeCol} strokeWidth=\"0.8\" strokeLinecap=\"round\" />\n <line x1={rx + 3} y1={y - 2} x2={rx + 4.5} y2={y - 3}\n stroke={eyeCol} strokeWidth=\"0.8\" strokeLinecap=\"round\" />\n </>\n );\n case 7: // Narrow\n return (\n <>\n <ellipse cx={lx} cy={y} rx=\"4\" ry=\"1.2\" fill={eyeWhite} />\n <ellipse cx={lx + 0.5} cy={y} rx=\"2\" ry=\"1\" fill={eyeCol} />\n <ellipse cx={rx} cy={y} rx=\"4\" ry=\"1.2\" fill={eyeWhite} />\n <ellipse cx={rx + 0.5} cy={y} rx=\"2\" ry=\"1\" fill={eyeCol} />\n </>\n );\n default:\n return (\n <>\n <circle cx={lx} cy={y} r=\"3\" fill={eyeWhite} />\n <circle cx={lx + 1} cy={y} r=\"2\" fill={eyeCol} />\n <circle cx={rx} cy={y} r=\"3\" fill={eyeWhite} />\n <circle cx={rx + 1} cy={y} r=\"2\" fill={eyeCol} />\n </>\n );\n }\n}\n\n// ─── Eyebrows ───────────────────────────────────\n\nfunction renderEyebrows(traits: SolFaceTraits, col: string) {\n const lx = 24, rx = 40, y = 25;\n\n switch (traits.eyebrows) {\n case 0:\n return null;\n case 1: // Thin\n return (\n <>\n <line x1={lx - 3} y1={y} x2={lx + 3} y2={y}\n stroke={col} strokeWidth=\"0.8\" strokeLinecap=\"round\" />\n <line x1={rx - 3} y1={y} x2={rx + 3} y2={y}\n stroke={col} strokeWidth=\"0.8\" strokeLinecap=\"round\" />\n </>\n );\n case 2: // Thick\n return (\n <>\n <line x1={lx - 3.5} y1={y} x2={lx + 3.5} y2={y}\n stroke={col} strokeWidth=\"2\" strokeLinecap=\"round\" />\n <line x1={rx - 3.5} y1={y} x2={rx + 3.5} y2={y}\n stroke={col} strokeWidth=\"2\" strokeLinecap=\"round\" />\n </>\n );\n case 3: // Arched\n return (\n <>\n <path d={`M${lx - 3.5} ${y + 1} Q${lx} ${y - 2} ${lx + 3.5} ${y + 1}`}\n fill=\"none\" stroke={col} strokeWidth=\"1\" strokeLinecap=\"round\" />\n <path d={`M${rx - 3.5} ${y + 1} Q${rx} ${y - 2} ${rx + 3.5} ${y + 1}`}\n fill=\"none\" stroke={col} strokeWidth=\"1\" strokeLinecap=\"round\" />\n </>\n );\n case 4: // Angled\n return (\n <>\n <line x1={lx - 3} y1={y - 1} x2={lx + 3} y2={y + 1}\n stroke={col} strokeWidth=\"1.2\" strokeLinecap=\"round\" />\n <line x1={rx - 3} y1={y + 1} x2={rx + 3} y2={y - 1}\n stroke={col} strokeWidth=\"1.2\" strokeLinecap=\"round\" />\n </>\n );\n default:\n return null;\n }\n}\n\n// ─── Nose ───────────────────────────────────────\n\nfunction renderNose(traits: SolFaceTraits, skin: string, noseCol?: string) {\n const cx = 32, y = 36;\n const shadow = noseCol ?? (skin + \"aa\");\n\n switch (traits.nose) {\n case 0:\n return null;\n case 1: // Dot\n return <circle cx={cx} cy={y} r=\"1.5\" fill={shadow} />;\n case 2: // Triangle\n return (\n <path\n d={`M${cx} ${y - 1.5} L${cx + 2.5} ${y + 2} L${cx - 2.5} ${y + 2} Z`}\n fill={shadow}\n />\n );\n case 3: // Button (nostrils)\n return (\n <>\n <circle cx={cx - 1.5} cy={y} r=\"1\" fill={shadow} />\n <circle cx={cx + 1.5} cy={y} r=\"1\" fill={shadow} />\n </>\n );\n default:\n return null;\n }\n}\n\n// ─── Mouth ──────────────────────────────────────\n\nfunction renderMouth(traits: SolFaceTraits, col: string, teethCol: string = \"white\") {\n const cx = 32, y = 42;\n\n switch (traits.mouth) {\n case 0: // Smile\n return (\n <path d={`M${cx - 4} ${y} Q${cx} ${y + 4} ${cx + 4} ${y}`}\n fill=\"none\" stroke={col} strokeWidth=\"1.2\" strokeLinecap=\"round\" />\n );\n case 1: // Neutral\n return (\n <line x1={cx - 3} y1={y + 1} x2={cx + 3} y2={y + 1}\n stroke={col} strokeWidth=\"1.2\" strokeLinecap=\"round\" />\n );\n case 2: // Grin\n return (\n <path d={`M${cx - 6} ${y} Q${cx} ${y + 5} ${cx + 6} ${y}`}\n fill=\"none\" stroke={col} strokeWidth=\"1.5\" strokeLinecap=\"round\" />\n );\n case 3: // Open\n return (\n <ellipse cx={cx} cy={y + 1} rx=\"3\" ry=\"2.5\" fill={col} opacity=\"0.8\" />\n );\n case 4: // Smirk\n return (\n <path d={`M${cx - 4} ${y + 1} Q${cx - 1} ${y + 1} ${cx + 4} ${y - 1}`}\n fill=\"none\" stroke={col} strokeWidth=\"1.2\" strokeLinecap=\"round\" />\n );\n case 5: // Wide smile\n return (\n <path d={`M${cx - 6} ${y} Q${cx} ${y + 6} ${cx + 6} ${y}`}\n fill={teethCol} stroke={col} strokeWidth=\"1\" />\n );\n default:\n return (\n <path d={`M${cx - 4} ${y} Q${cx} ${y + 4} ${cx + 4} ${y}`}\n fill=\"none\" stroke={col} strokeWidth=\"1.2\" strokeLinecap=\"round\" />\n );\n }\n}\n\n// ─── Hair ───────────────────────────────────────\n\nfunction renderHair(traits: SolFaceTraits, hairCol: string) {\n switch (traits.hairStyle) {\n case 0: // Bald\n return null;\n case 1: // Short\n return <rect x=\"14\" y=\"12\" width=\"36\" height=\"12\" rx=\"6\" ry=\"6\" fill={hairCol} />;\n case 2: // Spiky\n return (\n <g fill={hairCol}>\n <rect x=\"14\" y=\"16\" width=\"36\" height=\"8\" rx=\"2\" />\n <polygon points=\"18,16 22,6 26,16\" />\n <polygon points=\"26,16 30,4 34,16\" />\n <polygon points=\"34,16 38,6 42,16\" />\n <polygon points=\"42,16 46,10 48,16\" />\n </g>\n );\n case 3: // Swept\n return (\n <g fill={hairCol}>\n <rect x=\"14\" y=\"14\" width=\"36\" height=\"10\" rx=\"4\" />\n <path d=\"M14 18 Q8 14 10 8 Q14 10 20 14 Z\" />\n </g>\n );\n case 4: // Mohawk\n return <rect x=\"26\" y=\"4\" width=\"12\" height=\"20\" rx=\"4\" ry=\"2\" fill={hairCol} />;\n case 5: // Long\n return (\n <g fill={hairCol}>\n <rect x=\"14\" y=\"12\" width=\"36\" height=\"10\" rx=\"4\" />\n <rect x=\"10\" y=\"18\" width=\"8\" height=\"24\" rx=\"3\" />\n <rect x=\"46\" y=\"18\" width=\"8\" height=\"24\" rx=\"3\" />\n </g>\n );\n case 6: // Bob\n return (\n <path\n d=\"M12 22 Q12 10 32 10 Q52 10 52 22 L52 38 Q52 42 48 42 L48 26 Q48 16 32 16 Q16 16 16 26 L16 42 Q12 42 12 38 Z\"\n fill={hairCol}\n />\n );\n case 7: // Buzz\n return <rect x=\"15\" y=\"13\" width=\"34\" height=\"9\" rx=\"8\" ry=\"4\" fill={hairCol} opacity=\"0.7\" />;\n default:\n return null;\n }\n}\n\n// ─── Accessories ────────────────────────────────\n\nfunction renderAccessory(traits: SolFaceTraits, col: string) {\n switch (traits.accessory) {\n case 0:\n case 1:\n return null;\n case 2: // Round glasses\n return (\n <g fill=\"none\" stroke={col} strokeWidth=\"1\">\n <circle cx=\"24\" cy=\"30\" r=\"5\" />\n <circle cx=\"40\" cy=\"30\" r=\"5\" />\n <line x1=\"29\" y1=\"30\" x2=\"35\" y2=\"30\" />\n <line x1=\"19\" y1=\"30\" x2=\"14\" y2=\"28\" />\n <line x1=\"45\" y1=\"30\" x2=\"50\" y2=\"28\" />\n </g>\n );\n case 3: // Square glasses\n return (\n <g fill=\"none\" stroke={col} strokeWidth=\"1\">\n <rect x=\"19\" y=\"26\" width=\"10\" height=\"8\" rx=\"1\" />\n <rect x=\"35\" y=\"26\" width=\"10\" height=\"8\" rx=\"1\" />\n <line x1=\"29\" y1=\"30\" x2=\"35\" y2=\"30\" />\n <line x1=\"19\" y1=\"30\" x2=\"14\" y2=\"28\" />\n <line x1=\"45\" y1=\"30\" x2=\"50\" y2=\"28\" />\n </g>\n );\n case 4: // Earring\n return (\n <circle cx=\"11\" cy=\"36\" r=\"2\" fill={col} stroke={col} strokeWidth=\"0.5\" />\n );\n case 5: // Bandana\n return (\n <g>\n <rect x=\"12\" y=\"20\" width=\"40\" height=\"4\" rx=\"1\" fill={col} />\n <path d=\"M12 22 L8 26 L12 24 Z\" fill={col} />\n </g>\n );\n default:\n return null;\n }\n}\n\n// ─── Main Component ─────────────────────────────\n\nexport function SolFace({\n walletAddress,\n size = 64,\n enableBlink = false,\n theme,\n traitOverrides,\n colorOverrides,\n className,\n style,\n ...rest\n}: SolFaceProps) {\n const traits = useMemo(\n () => generateTraits(walletAddress, traitOverrides),\n [walletAddress, traitOverrides]\n );\n\n const skinColors = theme?.skinColors ?? SKIN_COLORS;\n const eyeColors = theme?.eyeColors ?? EYE_COLORS;\n const hairColors = theme?.hairColors ?? HAIR_COLORS;\n const bgColors = theme?.bgColors ?? BG_COLORS;\n\n const skin = colorOverrides?.skin ?? skinColors[traits.skinColor % skinColors.length];\n const eyeCol = colorOverrides?.eyes ?? eyeColors[traits.eyeColor % eyeColors.length];\n const hairCol = colorOverrides?.hair ?? hairColors[traits.hairColor % hairColors.length];\n const bgCol = colorOverrides?.bg ?? bgColors[traits.bgColor % bgColors.length];\n\n const bgOpacity = theme?.bgOpacity ?? 0.15;\n const bgRadius = theme?.bgRadius ?? 4;\n const mouthCol = colorOverrides?.mouth ?? theme?.mouthColor ?? \"#c05050\";\n const browCol = colorOverrides?.eyebrow ?? theme?.eyebrowColor ?? \"#2a2020\";\n const accCol = colorOverrides?.accessory ?? theme?.accessoryColor ?? \"#444\";\n const eyeWhite = colorOverrides?.eyeWhite ?? theme?.eyeWhiteColor ?? \"white\";\n const noseCol = colorOverrides?.nose ?? theme?.noseColor;\n\n const uid = useMemo(() => `sf-${walletAddress.slice(0, 8)}`, [walletAddress]);\n\n const blinkEnabled = !!enableBlink;\n const blinkDuration = typeof enableBlink === \"object\" ? (enableBlink.duration ?? 4) : 4;\n const blinkDelay = typeof enableBlink === \"object\" ? (enableBlink.delay ?? 0) : 0;\n const delayStr = blinkDelay ? ` ${blinkDelay}s` : \"\";\n\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 64 64\"\n width={size}\n height={size}\n className={className}\n style={{ display: \"block\", ...style }}\n {...rest}\n >\n {blinkEnabled && (\n <style>{`\n @keyframes ${uid}-blink {\n 0%, 90%, 100% { transform: scaleY(1); }\n 95% { transform: scaleY(0.1); }\n }\n .${uid}-eyes {\n animation: ${uid}-blink ${blinkDuration}s ease-in-out${delayStr} infinite;\n transform-origin: 32px 30px;\n }\n `}</style>\n )}\n\n <rect x=\"0\" y=\"0\" width=\"64\" height=\"64\" fill={bgCol} opacity={bgOpacity} rx={bgRadius} />\n\n {renderHair(traits, hairCol)}\n {renderFace(traits, skin)}\n <g className={blinkEnabled ? `${uid}-eyes` : undefined}>\n {renderEyes(traits, eyeCol, eyeWhite)}\n </g>\n {renderEyebrows(traits, browCol)}\n {renderNose(traits, skin, noseCol)}\n {renderMouth(traits, mouthCol, eyeWhite)}\n {renderAccessory(traits, accCol)}\n\n {theme?.border && (\n <rect\n x=\"0\" y=\"0\" width=\"64\" height=\"64\"\n fill=\"none\"\n stroke={theme.border.color}\n strokeWidth={theme.border.width}\n rx={bgRadius}\n />\n )}\n </svg>\n );\n}\n"]}
|