@typecaast/skins 0.1.0 → 0.2.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/dist/chunk-3WKOSJVB.js +320 -0
- package/dist/chunk-3WKOSJVB.js.map +1 -0
- package/dist/chunk-6K2ANTPJ.cjs +722 -0
- package/dist/chunk-6K2ANTPJ.cjs.map +1 -0
- package/dist/chunk-7IC3DRCQ.js +718 -0
- package/dist/chunk-7IC3DRCQ.js.map +1 -0
- package/dist/chunk-AMP2ZMTF.cjs +275 -0
- package/dist/chunk-AMP2ZMTF.cjs.map +1 -0
- package/dist/chunk-BMB4ZKAU.cjs +32 -0
- package/dist/chunk-BMB4ZKAU.cjs.map +1 -0
- package/dist/chunk-CAHWYIXY.js +272 -0
- package/dist/chunk-CAHWYIXY.js.map +1 -0
- package/dist/chunk-CCT33UVA.cjs +591 -0
- package/dist/chunk-CCT33UVA.cjs.map +1 -0
- package/dist/chunk-E5K2XXQL.cjs +469 -0
- package/dist/chunk-E5K2XXQL.cjs.map +1 -0
- package/dist/chunk-FEXZ3X5C.cjs +255 -0
- package/dist/chunk-FEXZ3X5C.cjs.map +1 -0
- package/dist/chunk-JDPMZ572.js +466 -0
- package/dist/chunk-JDPMZ572.js.map +1 -0
- package/dist/chunk-JZVM4T2A.js +29 -0
- package/dist/chunk-JZVM4T2A.js.map +1 -0
- package/dist/chunk-KTQVRSDX.cjs +323 -0
- package/dist/chunk-KTQVRSDX.cjs.map +1 -0
- package/dist/chunk-M54H2ZJJ.js +252 -0
- package/dist/chunk-M54H2ZJJ.js.map +1 -0
- package/dist/chunk-NCSI7C7I.js +561 -0
- package/dist/chunk-NCSI7C7I.js.map +1 -0
- package/dist/chunk-OC7WDISK.js +343 -0
- package/dist/chunk-OC7WDISK.js.map +1 -0
- package/dist/chunk-UC43JQYK.cjs +346 -0
- package/dist/chunk-UC43JQYK.cjs.map +1 -0
- package/dist/chunk-UFC4ODW5.js +587 -0
- package/dist/chunk-UFC4ODW5.js.map +1 -0
- package/dist/chunk-UKWBCC7E.cjs +567 -0
- package/dist/chunk-UKWBCC7E.cjs.map +1 -0
- package/dist/claude-code/index.cjs +19 -0
- package/dist/claude-code/index.cjs.map +1 -0
- package/dist/claude-code/index.d.cts +6 -0
- package/dist/claude-code/index.d.ts +6 -0
- package/dist/claude-code/index.js +4 -0
- package/dist/claude-code/index.js.map +1 -0
- package/dist/cursor/index.cjs +19 -0
- package/dist/cursor/index.cjs.map +1 -0
- package/dist/cursor/index.d.cts +6 -0
- package/dist/cursor/index.d.ts +6 -0
- package/dist/cursor/index.js +4 -0
- package/dist/cursor/index.js.map +1 -0
- package/dist/discord/index.cjs +19 -0
- package/dist/discord/index.cjs.map +1 -0
- package/dist/discord/index.d.cts +6 -0
- package/dist/discord/index.d.ts +6 -0
- package/dist/discord/index.js +4 -0
- package/dist/discord/index.js.map +1 -0
- package/dist/imessage/index.cjs +20 -0
- package/dist/imessage/index.cjs.map +1 -0
- package/dist/imessage/index.d.cts +6 -0
- package/dist/imessage/index.d.ts +6 -0
- package/dist/imessage/index.js +5 -0
- package/dist/imessage/index.js.map +1 -0
- package/dist/index.cjs +52 -2664
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +49 -27
- package/dist/index.d.ts +49 -27
- package/dist/index.js +20 -2656
- package/dist/index.js.map +1 -1
- package/dist/messages-macos/index.cjs +20 -0
- package/dist/messages-macos/index.cjs.map +1 -0
- package/dist/messages-macos/index.d.cts +10 -0
- package/dist/messages-macos/index.d.ts +10 -0
- package/dist/messages-macos/index.js +5 -0
- package/dist/messages-macos/index.js.map +1 -0
- package/dist/slack/index.cjs +19 -0
- package/dist/slack/index.cjs.map +1 -0
- package/dist/slack/index.d.cts +6 -0
- package/dist/slack/index.d.ts +6 -0
- package/dist/slack/index.js +4 -0
- package/dist/slack/index.js.map +1 -0
- package/dist/telegram/index.cjs +19 -0
- package/dist/telegram/index.cjs.map +1 -0
- package/dist/telegram/index.d.cts +6 -0
- package/dist/telegram/index.d.ts +6 -0
- package/dist/telegram/index.js +4 -0
- package/dist/telegram/index.js.map +1 -0
- package/dist/whatsapp/index.cjs +19 -0
- package/dist/whatsapp/index.cjs.map +1 -0
- package/dist/whatsapp/index.d.cts +6 -0
- package/dist/whatsapp/index.d.ts +6 -0
- package/dist/whatsapp/index.js +4 -0
- package/dist/whatsapp/index.js.map +1 -0
- package/package.json +49 -5
|
@@ -0,0 +1,272 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { imessageComponents, imessageTokens, imessageFonts, imessageCapabilities, IMESSAGE_FONT_STACK } from './chunk-NCSI7C7I.js';
|
|
3
|
+
import { z } from 'zod';
|
|
4
|
+
import { defineSkin } from '@typecaast/skin-kit';
|
|
5
|
+
import { jsxs, jsx } from 'react/jsx-runtime';
|
|
6
|
+
|
|
7
|
+
var CHROME = {
|
|
8
|
+
light: {
|
|
9
|
+
window: "#ffffff",
|
|
10
|
+
sidebar: "#f5f5f7",
|
|
11
|
+
sidebarBorder: "#e0e0e2",
|
|
12
|
+
titleBar: "#ececee",
|
|
13
|
+
text: "#1d1d1f",
|
|
14
|
+
subtle: "#86868b",
|
|
15
|
+
activeRow: "#0b93f6",
|
|
16
|
+
activeText: "#ffffff",
|
|
17
|
+
searchBg: "#e4e4e6"
|
|
18
|
+
},
|
|
19
|
+
dark: {
|
|
20
|
+
window: "#1e1e1e",
|
|
21
|
+
sidebar: "#28282a",
|
|
22
|
+
sidebarBorder: "#3a3a3c",
|
|
23
|
+
titleBar: "#323234",
|
|
24
|
+
text: "#f5f5f7",
|
|
25
|
+
subtle: "#98989d",
|
|
26
|
+
activeRow: "#0b6cff",
|
|
27
|
+
activeText: "#ffffff",
|
|
28
|
+
searchBg: "#3a3a3c"
|
|
29
|
+
}
|
|
30
|
+
};
|
|
31
|
+
var TRAFFIC = ["#ff5f56", "#ffbd2e", "#27c93f"];
|
|
32
|
+
function initials(name) {
|
|
33
|
+
return name.split(/\s+/).map((w) => w.charAt(0)).slice(0, 2).join("").toUpperCase();
|
|
34
|
+
}
|
|
35
|
+
var SAMPLE_CONVOS = [
|
|
36
|
+
{ name: "Sam Carter", preview: "you're the best, omw \u{1F3C3}", time: "9:41 AM" },
|
|
37
|
+
{ name: "Mum", preview: "call me when you can \u2764\uFE0F", time: "Yesterday" },
|
|
38
|
+
{ name: "Design", preview: "Tap to load preview", time: "Tuesday" },
|
|
39
|
+
{ name: "Alex Rivera", preview: "ship it \u{1F680}", time: "Monday" }
|
|
40
|
+
];
|
|
41
|
+
var SidebarRow = ({ theme, name, preview, time, active }) => {
|
|
42
|
+
const ch = CHROME[theme];
|
|
43
|
+
return /* @__PURE__ */ jsxs(
|
|
44
|
+
"div",
|
|
45
|
+
{
|
|
46
|
+
style: {
|
|
47
|
+
display: "flex",
|
|
48
|
+
gap: 10,
|
|
49
|
+
padding: "8px 10px",
|
|
50
|
+
borderRadius: 8,
|
|
51
|
+
background: active ? ch.activeRow : "transparent",
|
|
52
|
+
color: active ? ch.activeText : ch.text
|
|
53
|
+
},
|
|
54
|
+
children: [
|
|
55
|
+
/* @__PURE__ */ jsx(
|
|
56
|
+
"div",
|
|
57
|
+
{
|
|
58
|
+
style: {
|
|
59
|
+
width: 40,
|
|
60
|
+
height: 40,
|
|
61
|
+
borderRadius: "50%",
|
|
62
|
+
background: active ? "rgba(255,255,255,0.25)" : "#a9a9af",
|
|
63
|
+
color: "#fff",
|
|
64
|
+
display: "flex",
|
|
65
|
+
alignItems: "center",
|
|
66
|
+
justifyContent: "center",
|
|
67
|
+
fontSize: 15,
|
|
68
|
+
flex: "0 0 40px"
|
|
69
|
+
},
|
|
70
|
+
children: initials(name)
|
|
71
|
+
}
|
|
72
|
+
),
|
|
73
|
+
/* @__PURE__ */ jsxs("div", { style: { minWidth: 0, flex: 1 }, children: [
|
|
74
|
+
/* @__PURE__ */ jsxs("div", { style: { display: "flex", justifyContent: "space-between" }, children: [
|
|
75
|
+
/* @__PURE__ */ jsx("span", { style: { fontSize: 14, fontWeight: 600 }, children: name }),
|
|
76
|
+
/* @__PURE__ */ jsx(
|
|
77
|
+
"span",
|
|
78
|
+
{
|
|
79
|
+
style: {
|
|
80
|
+
fontSize: 11,
|
|
81
|
+
color: active ? "rgba(255,255,255,0.8)" : ch.subtle
|
|
82
|
+
},
|
|
83
|
+
children: time
|
|
84
|
+
}
|
|
85
|
+
)
|
|
86
|
+
] }),
|
|
87
|
+
/* @__PURE__ */ jsx(
|
|
88
|
+
"div",
|
|
89
|
+
{
|
|
90
|
+
style: {
|
|
91
|
+
fontSize: 13,
|
|
92
|
+
color: active ? "rgba(255,255,255,0.85)" : ch.subtle,
|
|
93
|
+
whiteSpace: "nowrap",
|
|
94
|
+
overflow: "hidden",
|
|
95
|
+
textOverflow: "ellipsis"
|
|
96
|
+
},
|
|
97
|
+
children: preview
|
|
98
|
+
}
|
|
99
|
+
)
|
|
100
|
+
] })
|
|
101
|
+
]
|
|
102
|
+
}
|
|
103
|
+
);
|
|
104
|
+
};
|
|
105
|
+
var Frame = ({
|
|
106
|
+
theme,
|
|
107
|
+
options,
|
|
108
|
+
children
|
|
109
|
+
}) => {
|
|
110
|
+
const ch = CHROME[theme];
|
|
111
|
+
const contact = typeof options?.contact === "string" ? options.contact : "Messages";
|
|
112
|
+
const convos = [
|
|
113
|
+
{ name: contact, preview: "active now", time: "now" },
|
|
114
|
+
...SAMPLE_CONVOS.filter((c) => c.name !== contact)
|
|
115
|
+
];
|
|
116
|
+
return /* @__PURE__ */ jsxs(
|
|
117
|
+
"div",
|
|
118
|
+
{
|
|
119
|
+
style: {
|
|
120
|
+
fontFamily: IMESSAGE_FONT_STACK,
|
|
121
|
+
background: ch.window,
|
|
122
|
+
color: ch.text,
|
|
123
|
+
display: "flex",
|
|
124
|
+
flexDirection: "column",
|
|
125
|
+
height: "100%",
|
|
126
|
+
width: "100%",
|
|
127
|
+
WebkitFontSmoothing: "antialiased"
|
|
128
|
+
},
|
|
129
|
+
children: [
|
|
130
|
+
/* @__PURE__ */ jsx(
|
|
131
|
+
"div",
|
|
132
|
+
{
|
|
133
|
+
style: {
|
|
134
|
+
flex: "0 0 auto",
|
|
135
|
+
height: 38,
|
|
136
|
+
background: ch.titleBar,
|
|
137
|
+
display: "flex",
|
|
138
|
+
alignItems: "center",
|
|
139
|
+
gap: 8,
|
|
140
|
+
padding: "0 13px",
|
|
141
|
+
borderBottom: `1px solid ${ch.sidebarBorder}`
|
|
142
|
+
},
|
|
143
|
+
children: TRAFFIC.map((color) => /* @__PURE__ */ jsx(
|
|
144
|
+
"span",
|
|
145
|
+
{
|
|
146
|
+
style: {
|
|
147
|
+
width: 12,
|
|
148
|
+
height: 12,
|
|
149
|
+
borderRadius: "50%",
|
|
150
|
+
background: color
|
|
151
|
+
}
|
|
152
|
+
},
|
|
153
|
+
color
|
|
154
|
+
))
|
|
155
|
+
}
|
|
156
|
+
),
|
|
157
|
+
/* @__PURE__ */ jsxs("div", { style: { flex: "1 1 auto", minHeight: 0, display: "flex" }, children: [
|
|
158
|
+
/* @__PURE__ */ jsxs(
|
|
159
|
+
"div",
|
|
160
|
+
{
|
|
161
|
+
style: {
|
|
162
|
+
flex: "0 0 250px",
|
|
163
|
+
background: ch.sidebar,
|
|
164
|
+
borderRight: `1px solid ${ch.sidebarBorder}`,
|
|
165
|
+
display: "flex",
|
|
166
|
+
flexDirection: "column",
|
|
167
|
+
padding: "8px 8px 0"
|
|
168
|
+
},
|
|
169
|
+
children: [
|
|
170
|
+
/* @__PURE__ */ jsx(
|
|
171
|
+
"div",
|
|
172
|
+
{
|
|
173
|
+
style: {
|
|
174
|
+
background: ch.searchBg,
|
|
175
|
+
borderRadius: 7,
|
|
176
|
+
padding: "5px 9px",
|
|
177
|
+
color: ch.subtle,
|
|
178
|
+
fontSize: 13,
|
|
179
|
+
marginBottom: 6
|
|
180
|
+
},
|
|
181
|
+
children: "\u{1F50D} Search"
|
|
182
|
+
}
|
|
183
|
+
),
|
|
184
|
+
convos.slice(0, 5).map((cv, i) => /* @__PURE__ */ jsx(
|
|
185
|
+
SidebarRow,
|
|
186
|
+
{
|
|
187
|
+
theme,
|
|
188
|
+
name: cv.name,
|
|
189
|
+
preview: cv.preview,
|
|
190
|
+
time: cv.time,
|
|
191
|
+
active: i === 0
|
|
192
|
+
},
|
|
193
|
+
cv.name
|
|
194
|
+
))
|
|
195
|
+
]
|
|
196
|
+
}
|
|
197
|
+
),
|
|
198
|
+
/* @__PURE__ */ jsxs(
|
|
199
|
+
"div",
|
|
200
|
+
{
|
|
201
|
+
style: {
|
|
202
|
+
flex: "1 1 auto",
|
|
203
|
+
minWidth: 0,
|
|
204
|
+
display: "flex",
|
|
205
|
+
flexDirection: "column",
|
|
206
|
+
background: ch.window
|
|
207
|
+
},
|
|
208
|
+
children: [
|
|
209
|
+
/* @__PURE__ */ jsx(
|
|
210
|
+
"div",
|
|
211
|
+
{
|
|
212
|
+
style: {
|
|
213
|
+
flex: "0 0 auto",
|
|
214
|
+
textAlign: "center",
|
|
215
|
+
padding: "8px 0",
|
|
216
|
+
borderBottom: `1px solid ${ch.sidebarBorder}`,
|
|
217
|
+
fontSize: 13,
|
|
218
|
+
fontWeight: 600
|
|
219
|
+
},
|
|
220
|
+
children: contact
|
|
221
|
+
}
|
|
222
|
+
),
|
|
223
|
+
/* @__PURE__ */ jsx(
|
|
224
|
+
"div",
|
|
225
|
+
{
|
|
226
|
+
style: {
|
|
227
|
+
flex: "1 1 auto",
|
|
228
|
+
minHeight: 0,
|
|
229
|
+
display: "flex",
|
|
230
|
+
flexDirection: "column",
|
|
231
|
+
justifyContent: "flex-end",
|
|
232
|
+
overflow: "hidden",
|
|
233
|
+
paddingBottom: 4
|
|
234
|
+
},
|
|
235
|
+
children
|
|
236
|
+
}
|
|
237
|
+
)
|
|
238
|
+
]
|
|
239
|
+
}
|
|
240
|
+
)
|
|
241
|
+
] })
|
|
242
|
+
]
|
|
243
|
+
}
|
|
244
|
+
);
|
|
245
|
+
};
|
|
246
|
+
var macosComponents = {
|
|
247
|
+
...imessageComponents,
|
|
248
|
+
Frame
|
|
249
|
+
};
|
|
250
|
+
|
|
251
|
+
// src/messages-macos/index.ts
|
|
252
|
+
var macosOptionsSchema = z.object({
|
|
253
|
+
contact: z.string().optional()
|
|
254
|
+
});
|
|
255
|
+
var messagesMacos = defineSkin({
|
|
256
|
+
id: "messages-macos",
|
|
257
|
+
meta: {
|
|
258
|
+
name: "Messages (macOS)",
|
|
259
|
+
defaultCanvas: { width: 900, height: 600 },
|
|
260
|
+
supportsThemes: ["light", "dark"],
|
|
261
|
+
capabilities: imessageCapabilities,
|
|
262
|
+
optionsSchema: macosOptionsSchema,
|
|
263
|
+
fonts: imessageFonts
|
|
264
|
+
},
|
|
265
|
+
components: macosComponents,
|
|
266
|
+
tokens: imessageTokens
|
|
267
|
+
});
|
|
268
|
+
var messages_macos_default = messagesMacos;
|
|
269
|
+
|
|
270
|
+
export { messagesMacos, messages_macos_default };
|
|
271
|
+
//# sourceMappingURL=chunk-CAHWYIXY.js.map
|
|
272
|
+
//# sourceMappingURL=chunk-CAHWYIXY.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/messages-macos/components.tsx","../src/messages-macos/index.ts"],"names":[],"mappings":"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","file":"chunk-CAHWYIXY.js","sourcesContent":["import type { FC, ReactNode } from \"react\";\nimport type { FrameProps, ResolvedTheme } from \"@typecaast/core\";\nimport { imessageComponents } from \"../imessage/components.js\";\nimport { IMESSAGE_COLORS, IMESSAGE_FONT_STACK } from \"../imessage/tokens.js\";\n\n// macOS-specific window/sidebar chrome (bubbles + composer reuse iMessage).\nconst CHROME = {\n light: {\n window: \"#ffffff\",\n sidebar: \"#f5f5f7\",\n sidebarBorder: \"#e0e0e2\",\n titleBar: \"#ececee\",\n text: \"#1d1d1f\",\n subtle: \"#86868b\",\n activeRow: \"#0b93f6\",\n activeText: \"#ffffff\",\n searchBg: \"#e4e4e6\",\n },\n dark: {\n window: \"#1e1e1e\",\n sidebar: \"#28282a\",\n sidebarBorder: \"#3a3a3c\",\n titleBar: \"#323234\",\n text: \"#f5f5f7\",\n subtle: \"#98989d\",\n activeRow: \"#0b6cff\",\n activeText: \"#ffffff\",\n searchBg: \"#3a3a3c\",\n },\n} as const;\n\nconst TRAFFIC = [\"#ff5f56\", \"#ffbd2e\", \"#27c93f\"];\n\nfunction initials(name: string): string {\n return name\n .split(/\\s+/)\n .map((w) => w.charAt(0))\n .slice(0, 2)\n .join(\"\")\n .toUpperCase();\n}\n\nconst SAMPLE_CONVOS = [\n { name: \"Sam Carter\", preview: \"you're the best, omw 🏃\", time: \"9:41 AM\" },\n { name: \"Mum\", preview: \"call me when you can ❤️\", time: \"Yesterday\" },\n { name: \"Design\", preview: \"Tap to load preview\", time: \"Tuesday\" },\n { name: \"Alex Rivera\", preview: \"ship it 🚀\", time: \"Monday\" },\n];\n\nconst SidebarRow: FC<{\n theme: ResolvedTheme;\n name: string;\n preview: string;\n time: string;\n active: boolean;\n}> = ({ theme, name, preview, time, active }) => {\n const ch = CHROME[theme];\n return (\n <div\n style={{\n display: \"flex\",\n gap: 10,\n padding: \"8px 10px\",\n borderRadius: 8,\n background: active ? ch.activeRow : \"transparent\",\n color: active ? ch.activeText : ch.text,\n }}\n >\n <div\n style={{\n width: 40,\n height: 40,\n borderRadius: \"50%\",\n background: active ? \"rgba(255,255,255,0.25)\" : \"#a9a9af\",\n color: \"#fff\",\n display: \"flex\",\n alignItems: \"center\",\n justifyContent: \"center\",\n fontSize: 15,\n flex: \"0 0 40px\",\n }}\n >\n {initials(name)}\n </div>\n <div style={{ minWidth: 0, flex: 1 }}>\n <div style={{ display: \"flex\", justifyContent: \"space-between\" }}>\n <span style={{ fontSize: 14, fontWeight: 600 }}>{name}</span>\n <span\n style={{\n fontSize: 11,\n color: active ? \"rgba(255,255,255,0.8)\" : ch.subtle,\n }}\n >\n {time}\n </span>\n </div>\n <div\n style={{\n fontSize: 13,\n color: active ? \"rgba(255,255,255,0.85)\" : ch.subtle,\n whiteSpace: \"nowrap\",\n overflow: \"hidden\",\n textOverflow: \"ellipsis\",\n }}\n >\n {preview}\n </div>\n </div>\n </div>\n );\n};\n\nconst Frame: FC<FrameProps & { children?: ReactNode }> = ({\n theme,\n options,\n children,\n}) => {\n const ch = CHROME[theme];\n const contact =\n typeof options?.contact === \"string\" ? options.contact : \"Messages\";\n const convos = [\n { name: contact, preview: \"active now\", time: \"now\" },\n ...SAMPLE_CONVOS.filter((c) => c.name !== contact),\n ];\n return (\n <div\n style={{\n fontFamily: IMESSAGE_FONT_STACK,\n background: ch.window,\n color: ch.text,\n display: \"flex\",\n flexDirection: \"column\",\n height: \"100%\",\n width: \"100%\",\n WebkitFontSmoothing: \"antialiased\",\n }}\n >\n <div\n style={{\n flex: \"0 0 auto\",\n height: 38,\n background: ch.titleBar,\n display: \"flex\",\n alignItems: \"center\",\n gap: 8,\n padding: \"0 13px\",\n borderBottom: `1px solid ${ch.sidebarBorder}`,\n }}\n >\n {TRAFFIC.map((color) => (\n <span\n key={color}\n style={{\n width: 12,\n height: 12,\n borderRadius: \"50%\",\n background: color,\n }}\n />\n ))}\n </div>\n <div style={{ flex: \"1 1 auto\", minHeight: 0, display: \"flex\" }}>\n <div\n style={{\n flex: \"0 0 250px\",\n background: ch.sidebar,\n borderRight: `1px solid ${ch.sidebarBorder}`,\n display: \"flex\",\n flexDirection: \"column\",\n padding: \"8px 8px 0\",\n }}\n >\n <div\n style={{\n background: ch.searchBg,\n borderRadius: 7,\n padding: \"5px 9px\",\n color: ch.subtle,\n fontSize: 13,\n marginBottom: 6,\n }}\n >\n 🔍 Search\n </div>\n {convos.slice(0, 5).map((cv, i) => (\n <SidebarRow\n key={cv.name}\n theme={theme}\n name={cv.name}\n preview={cv.preview}\n time={cv.time}\n active={i === 0}\n />\n ))}\n </div>\n <div\n style={{\n flex: \"1 1 auto\",\n minWidth: 0,\n display: \"flex\",\n flexDirection: \"column\",\n background: ch.window,\n }}\n >\n <div\n style={{\n flex: \"0 0 auto\",\n textAlign: \"center\",\n padding: \"8px 0\",\n borderBottom: `1px solid ${ch.sidebarBorder}`,\n fontSize: 13,\n fontWeight: 600,\n }}\n >\n {contact}\n </div>\n <div\n style={{\n flex: \"1 1 auto\",\n minHeight: 0,\n display: \"flex\",\n flexDirection: \"column\",\n justifyContent: \"flex-end\",\n overflow: \"hidden\",\n paddingBottom: 4,\n }}\n >\n {children}\n </div>\n </div>\n </div>\n </div>\n );\n};\n\n// Reuse iMessage bubbles, reactions, typing, composer, avatar — only the Frame\n// differs (window + sidebar + wider layout). Shared tokens (IMESSAGE_COLORS).\nexport const macosComponents = {\n ...imessageComponents,\n Frame,\n};\n\nexport { IMESSAGE_COLORS };\n","import { z } from \"zod\";\nimport { defineSkin } from \"@typecaast/skin-kit\";\nimport { macosComponents } from \"./components.js\";\nimport { imessageCapabilities } from \"../imessage/capabilities.js\";\nimport { imessageFonts } from \"../imessage/fonts.js\";\nimport { imessageTokens } from \"../imessage/tokens.js\";\n\nconst macosOptionsSchema = z.object({\n contact: z.string().optional(),\n});\n\n/**\n * macOS Messages — the desktop counterpart to the iOS skin. Window chrome +\n * a conversation sidebar + a wider layout, sharing iMessage's bubbles, tokens,\n * fonts, and capabilities. Distinct skin, shared internals.\n */\nexport const messagesMacos = defineSkin({\n id: \"messages-macos\",\n meta: {\n name: \"Messages (macOS)\",\n defaultCanvas: { width: 900, height: 600 },\n supportsThemes: [\"light\", \"dark\"],\n capabilities: imessageCapabilities,\n optionsSchema: macosOptionsSchema,\n fonts: imessageFonts,\n },\n components: macosComponents,\n tokens: imessageTokens,\n});\n\n/** Default export so `@typecaast/skins/messages-macos` can be lazy-imported uniformly. */\nexport default messagesMacos;\n"]}
|