@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.
Files changed (91) hide show
  1. package/dist/chunk-3WKOSJVB.js +320 -0
  2. package/dist/chunk-3WKOSJVB.js.map +1 -0
  3. package/dist/chunk-6K2ANTPJ.cjs +722 -0
  4. package/dist/chunk-6K2ANTPJ.cjs.map +1 -0
  5. package/dist/chunk-7IC3DRCQ.js +718 -0
  6. package/dist/chunk-7IC3DRCQ.js.map +1 -0
  7. package/dist/chunk-AMP2ZMTF.cjs +275 -0
  8. package/dist/chunk-AMP2ZMTF.cjs.map +1 -0
  9. package/dist/chunk-BMB4ZKAU.cjs +32 -0
  10. package/dist/chunk-BMB4ZKAU.cjs.map +1 -0
  11. package/dist/chunk-CAHWYIXY.js +272 -0
  12. package/dist/chunk-CAHWYIXY.js.map +1 -0
  13. package/dist/chunk-CCT33UVA.cjs +591 -0
  14. package/dist/chunk-CCT33UVA.cjs.map +1 -0
  15. package/dist/chunk-E5K2XXQL.cjs +469 -0
  16. package/dist/chunk-E5K2XXQL.cjs.map +1 -0
  17. package/dist/chunk-FEXZ3X5C.cjs +255 -0
  18. package/dist/chunk-FEXZ3X5C.cjs.map +1 -0
  19. package/dist/chunk-JDPMZ572.js +466 -0
  20. package/dist/chunk-JDPMZ572.js.map +1 -0
  21. package/dist/chunk-JZVM4T2A.js +29 -0
  22. package/dist/chunk-JZVM4T2A.js.map +1 -0
  23. package/dist/chunk-KTQVRSDX.cjs +323 -0
  24. package/dist/chunk-KTQVRSDX.cjs.map +1 -0
  25. package/dist/chunk-M54H2ZJJ.js +252 -0
  26. package/dist/chunk-M54H2ZJJ.js.map +1 -0
  27. package/dist/chunk-NCSI7C7I.js +561 -0
  28. package/dist/chunk-NCSI7C7I.js.map +1 -0
  29. package/dist/chunk-OC7WDISK.js +343 -0
  30. package/dist/chunk-OC7WDISK.js.map +1 -0
  31. package/dist/chunk-UC43JQYK.cjs +346 -0
  32. package/dist/chunk-UC43JQYK.cjs.map +1 -0
  33. package/dist/chunk-UFC4ODW5.js +587 -0
  34. package/dist/chunk-UFC4ODW5.js.map +1 -0
  35. package/dist/chunk-UKWBCC7E.cjs +567 -0
  36. package/dist/chunk-UKWBCC7E.cjs.map +1 -0
  37. package/dist/claude-code/index.cjs +19 -0
  38. package/dist/claude-code/index.cjs.map +1 -0
  39. package/dist/claude-code/index.d.cts +6 -0
  40. package/dist/claude-code/index.d.ts +6 -0
  41. package/dist/claude-code/index.js +4 -0
  42. package/dist/claude-code/index.js.map +1 -0
  43. package/dist/cursor/index.cjs +19 -0
  44. package/dist/cursor/index.cjs.map +1 -0
  45. package/dist/cursor/index.d.cts +6 -0
  46. package/dist/cursor/index.d.ts +6 -0
  47. package/dist/cursor/index.js +4 -0
  48. package/dist/cursor/index.js.map +1 -0
  49. package/dist/discord/index.cjs +19 -0
  50. package/dist/discord/index.cjs.map +1 -0
  51. package/dist/discord/index.d.cts +6 -0
  52. package/dist/discord/index.d.ts +6 -0
  53. package/dist/discord/index.js +4 -0
  54. package/dist/discord/index.js.map +1 -0
  55. package/dist/imessage/index.cjs +20 -0
  56. package/dist/imessage/index.cjs.map +1 -0
  57. package/dist/imessage/index.d.cts +6 -0
  58. package/dist/imessage/index.d.ts +6 -0
  59. package/dist/imessage/index.js +5 -0
  60. package/dist/imessage/index.js.map +1 -0
  61. package/dist/index.cjs +52 -2664
  62. package/dist/index.cjs.map +1 -1
  63. package/dist/index.d.cts +49 -27
  64. package/dist/index.d.ts +49 -27
  65. package/dist/index.js +20 -2656
  66. package/dist/index.js.map +1 -1
  67. package/dist/messages-macos/index.cjs +20 -0
  68. package/dist/messages-macos/index.cjs.map +1 -0
  69. package/dist/messages-macos/index.d.cts +10 -0
  70. package/dist/messages-macos/index.d.ts +10 -0
  71. package/dist/messages-macos/index.js +5 -0
  72. package/dist/messages-macos/index.js.map +1 -0
  73. package/dist/slack/index.cjs +19 -0
  74. package/dist/slack/index.cjs.map +1 -0
  75. package/dist/slack/index.d.cts +6 -0
  76. package/dist/slack/index.d.ts +6 -0
  77. package/dist/slack/index.js +4 -0
  78. package/dist/slack/index.js.map +1 -0
  79. package/dist/telegram/index.cjs +19 -0
  80. package/dist/telegram/index.cjs.map +1 -0
  81. package/dist/telegram/index.d.cts +6 -0
  82. package/dist/telegram/index.d.ts +6 -0
  83. package/dist/telegram/index.js +4 -0
  84. package/dist/telegram/index.js.map +1 -0
  85. package/dist/whatsapp/index.cjs +19 -0
  86. package/dist/whatsapp/index.cjs.map +1 -0
  87. package/dist/whatsapp/index.d.cts +6 -0
  88. package/dist/whatsapp/index.d.ts +6 -0
  89. package/dist/whatsapp/index.js +4 -0
  90. package/dist/whatsapp/index.js.map +1 -0
  91. 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"]}