@aws505/sheetsite 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.
Files changed (57) hide show
  1. package/README.md +105 -0
  2. package/dist/components/index.js +1696 -0
  3. package/dist/components/index.js.map +1 -0
  4. package/dist/components/index.mjs +1630 -0
  5. package/dist/components/index.mjs.map +1 -0
  6. package/dist/config/index.js +1840 -0
  7. package/dist/config/index.js.map +1 -0
  8. package/dist/config/index.mjs +1793 -0
  9. package/dist/config/index.mjs.map +1 -0
  10. package/dist/data/index.js +1296 -0
  11. package/dist/data/index.js.map +1 -0
  12. package/dist/data/index.mjs +1220 -0
  13. package/dist/data/index.mjs.map +1 -0
  14. package/dist/index.js +5433 -0
  15. package/dist/index.js.map +1 -0
  16. package/dist/index.mjs +5285 -0
  17. package/dist/index.mjs.map +1 -0
  18. package/dist/seo/index.js +187 -0
  19. package/dist/seo/index.js.map +1 -0
  20. package/dist/seo/index.mjs +155 -0
  21. package/dist/seo/index.mjs.map +1 -0
  22. package/dist/theme/index.js +552 -0
  23. package/dist/theme/index.js.map +1 -0
  24. package/dist/theme/index.mjs +526 -0
  25. package/dist/theme/index.mjs.map +1 -0
  26. package/package.json +96 -0
  27. package/src/components/index.ts +41 -0
  28. package/src/components/layout/Footer.tsx +234 -0
  29. package/src/components/layout/Header.tsx +134 -0
  30. package/src/components/sections/FAQ.tsx +178 -0
  31. package/src/components/sections/Gallery.tsx +107 -0
  32. package/src/components/sections/Hero.tsx +202 -0
  33. package/src/components/sections/Hours.tsx +225 -0
  34. package/src/components/sections/Services.tsx +216 -0
  35. package/src/components/sections/Testimonials.tsx +184 -0
  36. package/src/components/ui/Button.tsx +158 -0
  37. package/src/components/ui/Card.tsx +162 -0
  38. package/src/components/ui/Icons.tsx +508 -0
  39. package/src/config/index.ts +207 -0
  40. package/src/config/presets/generic.ts +153 -0
  41. package/src/config/presets/home-kitchen.ts +154 -0
  42. package/src/config/presets/index.ts +708 -0
  43. package/src/config/presets/professional.ts +165 -0
  44. package/src/config/presets/repair.ts +160 -0
  45. package/src/config/presets/restaurant.ts +162 -0
  46. package/src/config/presets/salon.ts +178 -0
  47. package/src/config/presets/tailor.ts +159 -0
  48. package/src/config/types.ts +314 -0
  49. package/src/data/csv-parser.ts +154 -0
  50. package/src/data/defaults.ts +202 -0
  51. package/src/data/google-drive.ts +148 -0
  52. package/src/data/index.ts +535 -0
  53. package/src/data/sheets.ts +709 -0
  54. package/src/data/types.ts +379 -0
  55. package/src/seo/index.ts +272 -0
  56. package/src/theme/colors.ts +351 -0
  57. package/src/theme/index.ts +249 -0
@@ -0,0 +1,526 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
3
+ var __getOwnPropNames = Object.getOwnPropertyNames;
4
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
5
+ var __esm = (fn, res) => function __init() {
6
+ return fn && (res = (0, fn[__getOwnPropNames(fn)[0]])(fn = 0)), res;
7
+ };
8
+ var __export = (target, all) => {
9
+ for (var name in all)
10
+ __defProp(target, name, { get: all[name], enumerable: true });
11
+ };
12
+ var __copyProps = (to, from, except, desc) => {
13
+ if (from && typeof from === "object" || typeof from === "function") {
14
+ for (let key of __getOwnPropNames(from))
15
+ if (!__hasOwnProp.call(to, key) && key !== except)
16
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
17
+ }
18
+ return to;
19
+ };
20
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
21
+
22
+ // src/theme/colors.ts
23
+ var colors_exports = {};
24
+ __export(colors_exports, {
25
+ boldRed: () => boldRed,
26
+ coolBlue: () => coolBlue,
27
+ earthGreen: () => earthGreen,
28
+ elegantGold: () => elegantGold,
29
+ forestGreen: () => forestGreen,
30
+ freshTeal: () => freshTeal,
31
+ getColorPalette: () => getColorPalette,
32
+ slateGray: () => slateGray,
33
+ softPink: () => softPink,
34
+ themePalettes: () => themePalettes,
35
+ warmAmber: () => warmAmber,
36
+ warmBrown: () => warmBrown
37
+ });
38
+ function getColorPalette(preset) {
39
+ return themePalettes[preset] || themePalettes["cool-blue"];
40
+ }
41
+ var warmBrown, coolBlue, earthGreen, warmAmber, elegantGold, freshTeal, boldRed, softPink, slateGray, forestGreen, themePalettes;
42
+ var init_colors = __esm({
43
+ "src/theme/colors.ts"() {
44
+ "use strict";
45
+ warmBrown = {
46
+ primary: {
47
+ 50: "#faf8f6",
48
+ 100: "#f2ede8",
49
+ 200: "#e4d9ce",
50
+ 300: "#d3c0ad",
51
+ 400: "#bfa38a",
52
+ 500: "#a68a6d",
53
+ 600: "#8b7058",
54
+ 700: "#735c49",
55
+ 800: "#604d3f",
56
+ 900: "#514237",
57
+ 950: "#2b221c"
58
+ },
59
+ accent: {
60
+ 50: "#fef3f2",
61
+ 100: "#fee4e2",
62
+ 200: "#fecdca",
63
+ 300: "#fcaca5",
64
+ 400: "#f87d71",
65
+ 500: "#ef5544",
66
+ 600: "#dc3626",
67
+ 700: "#b92a1c",
68
+ 800: "#99261b",
69
+ 900: "#7f261d",
70
+ 950: "#450f0a"
71
+ }
72
+ };
73
+ coolBlue = {
74
+ primary: {
75
+ 50: "#f0f7ff",
76
+ 100: "#e0effe",
77
+ 200: "#b9dffd",
78
+ 300: "#7cc5fc",
79
+ 400: "#36a8f8",
80
+ 500: "#0c8de9",
81
+ 600: "#006fc7",
82
+ 700: "#0159a1",
83
+ 800: "#064c85",
84
+ 900: "#0b406e",
85
+ 950: "#072849"
86
+ },
87
+ accent: {
88
+ 50: "#f0fdf4",
89
+ 100: "#dcfce7",
90
+ 200: "#bbf7d0",
91
+ 300: "#86efac",
92
+ 400: "#4ade80",
93
+ 500: "#22c55e",
94
+ 600: "#16a34a",
95
+ 700: "#15803d",
96
+ 800: "#166534",
97
+ 900: "#14532d",
98
+ 950: "#052e16"
99
+ }
100
+ };
101
+ earthGreen = {
102
+ primary: {
103
+ 50: "#f4f9f4",
104
+ 100: "#e5f2e7",
105
+ 200: "#cce5d0",
106
+ 300: "#a3d0ac",
107
+ 400: "#72b381",
108
+ 500: "#4f9760",
109
+ 600: "#3d7a4c",
110
+ 700: "#33613f",
111
+ 800: "#2c4e35",
112
+ 900: "#26412e",
113
+ 950: "#112317"
114
+ },
115
+ accent: {
116
+ 50: "#fefce8",
117
+ 100: "#fef9c3",
118
+ 200: "#fef08a",
119
+ 300: "#fde047",
120
+ 400: "#facc15",
121
+ 500: "#eab308",
122
+ 600: "#ca8a04",
123
+ 700: "#a16207",
124
+ 800: "#854d0e",
125
+ 900: "#713f12",
126
+ 950: "#422006"
127
+ }
128
+ };
129
+ warmAmber = {
130
+ primary: {
131
+ 50: "#fffbeb",
132
+ 100: "#fef3c7",
133
+ 200: "#fde68a",
134
+ 300: "#fcd34d",
135
+ 400: "#fbbf24",
136
+ 500: "#f59e0b",
137
+ 600: "#d97706",
138
+ 700: "#b45309",
139
+ 800: "#92400e",
140
+ 900: "#78350f",
141
+ 950: "#451a03"
142
+ },
143
+ accent: {
144
+ 50: "#fef2f2",
145
+ 100: "#fee2e2",
146
+ 200: "#fecaca",
147
+ 300: "#fca5a5",
148
+ 400: "#f87171",
149
+ 500: "#ef4444",
150
+ 600: "#dc2626",
151
+ 700: "#b91c1c",
152
+ 800: "#991b1b",
153
+ 900: "#7f1d1d",
154
+ 950: "#450a0a"
155
+ }
156
+ };
157
+ elegantGold = {
158
+ primary: {
159
+ 50: "#fdfcf7",
160
+ 100: "#f9f5e7",
161
+ 200: "#f2e9cb",
162
+ 300: "#e8d7a5",
163
+ 400: "#dcc07a",
164
+ 500: "#cfaa58",
165
+ 600: "#c09548",
166
+ 700: "#a0783d",
167
+ 800: "#826037",
168
+ 900: "#6b4f31",
169
+ 950: "#3b2a19"
170
+ },
171
+ accent: {
172
+ 50: "#f8fafc",
173
+ 100: "#f1f5f9",
174
+ 200: "#e2e8f0",
175
+ 300: "#cbd5e1",
176
+ 400: "#94a3b8",
177
+ 500: "#64748b",
178
+ 600: "#475569",
179
+ 700: "#334155",
180
+ 800: "#1e293b",
181
+ 900: "#0f172a",
182
+ 950: "#020617"
183
+ }
184
+ };
185
+ freshTeal = {
186
+ primary: {
187
+ 50: "#f0fdfa",
188
+ 100: "#ccfbf1",
189
+ 200: "#99f6e4",
190
+ 300: "#5eead4",
191
+ 400: "#2dd4bf",
192
+ 500: "#14b8a6",
193
+ 600: "#0d9488",
194
+ 700: "#0f766e",
195
+ 800: "#115e59",
196
+ 900: "#134e4a",
197
+ 950: "#042f2e"
198
+ },
199
+ accent: {
200
+ 50: "#fdf4ff",
201
+ 100: "#fae8ff",
202
+ 200: "#f5d0fe",
203
+ 300: "#f0abfc",
204
+ 400: "#e879f9",
205
+ 500: "#d946ef",
206
+ 600: "#c026d3",
207
+ 700: "#a21caf",
208
+ 800: "#86198f",
209
+ 900: "#701a75",
210
+ 950: "#4a044e"
211
+ }
212
+ };
213
+ boldRed = {
214
+ primary: {
215
+ 50: "#fef2f2",
216
+ 100: "#fee2e2",
217
+ 200: "#fecaca",
218
+ 300: "#fca5a5",
219
+ 400: "#f87171",
220
+ 500: "#ef4444",
221
+ 600: "#dc2626",
222
+ 700: "#b91c1c",
223
+ 800: "#991b1b",
224
+ 900: "#7f1d1d",
225
+ 950: "#450a0a"
226
+ },
227
+ accent: {
228
+ 50: "#f8fafc",
229
+ 100: "#f1f5f9",
230
+ 200: "#e2e8f0",
231
+ 300: "#cbd5e1",
232
+ 400: "#94a3b8",
233
+ 500: "#64748b",
234
+ 600: "#475569",
235
+ 700: "#334155",
236
+ 800: "#1e293b",
237
+ 900: "#0f172a",
238
+ 950: "#020617"
239
+ }
240
+ };
241
+ softPink = {
242
+ primary: {
243
+ 50: "#fdf2f8",
244
+ 100: "#fce7f3",
245
+ 200: "#fbcfe8",
246
+ 300: "#f9a8d4",
247
+ 400: "#f472b6",
248
+ 500: "#ec4899",
249
+ 600: "#db2777",
250
+ 700: "#be185d",
251
+ 800: "#9d174d",
252
+ 900: "#831843",
253
+ 950: "#500724"
254
+ },
255
+ accent: {
256
+ 50: "#faf5ff",
257
+ 100: "#f3e8ff",
258
+ 200: "#e9d5ff",
259
+ 300: "#d8b4fe",
260
+ 400: "#c084fc",
261
+ 500: "#a855f7",
262
+ 600: "#9333ea",
263
+ 700: "#7e22ce",
264
+ 800: "#6b21a8",
265
+ 900: "#581c87",
266
+ 950: "#3b0764"
267
+ }
268
+ };
269
+ slateGray = {
270
+ primary: {
271
+ 50: "#f8fafc",
272
+ 100: "#f1f5f9",
273
+ 200: "#e2e8f0",
274
+ 300: "#cbd5e1",
275
+ 400: "#94a3b8",
276
+ 500: "#64748b",
277
+ 600: "#475569",
278
+ 700: "#334155",
279
+ 800: "#1e293b",
280
+ 900: "#0f172a",
281
+ 950: "#020617"
282
+ },
283
+ accent: {
284
+ 50: "#ecfeff",
285
+ 100: "#cffafe",
286
+ 200: "#a5f3fc",
287
+ 300: "#67e8f9",
288
+ 400: "#22d3ee",
289
+ 500: "#06b6d4",
290
+ 600: "#0891b2",
291
+ 700: "#0e7490",
292
+ 800: "#155e75",
293
+ 900: "#164e63",
294
+ 950: "#083344"
295
+ }
296
+ };
297
+ forestGreen = {
298
+ primary: {
299
+ 50: "#f0fdf4",
300
+ 100: "#dcfce7",
301
+ 200: "#bbf7d0",
302
+ 300: "#86efac",
303
+ 400: "#4ade80",
304
+ 500: "#22c55e",
305
+ 600: "#16a34a",
306
+ 700: "#15803d",
307
+ 800: "#166534",
308
+ 900: "#14532d",
309
+ 950: "#052e16"
310
+ },
311
+ accent: {
312
+ 50: "#fffbeb",
313
+ 100: "#fef3c7",
314
+ 200: "#fde68a",
315
+ 300: "#fcd34d",
316
+ 400: "#fbbf24",
317
+ 500: "#f59e0b",
318
+ 600: "#d97706",
319
+ 700: "#b45309",
320
+ 800: "#92400e",
321
+ 900: "#78350f",
322
+ 950: "#451a03"
323
+ }
324
+ };
325
+ themePalettes = {
326
+ "warm-brown": warmBrown,
327
+ "cool-blue": coolBlue,
328
+ "earth-green": earthGreen,
329
+ "warm-amber": warmAmber,
330
+ "elegant-gold": elegantGold,
331
+ "fresh-teal": freshTeal,
332
+ "bold-red": boldRed,
333
+ "soft-pink": softPink,
334
+ "slate-gray": slateGray,
335
+ "forest-green": forestGreen
336
+ };
337
+ }
338
+ });
339
+
340
+ // src/theme/index.ts
341
+ init_colors();
342
+ init_colors();
343
+ var fontPairings = {
344
+ classic: {
345
+ heading: "Playfair Display",
346
+ body: "Inter"
347
+ },
348
+ modern: {
349
+ heading: "Inter",
350
+ body: "Inter"
351
+ },
352
+ elegant: {
353
+ heading: "Cormorant Garamond",
354
+ body: "Lato"
355
+ },
356
+ friendly: {
357
+ heading: "Nunito",
358
+ body: "Open Sans"
359
+ },
360
+ professional: {
361
+ heading: "Merriweather",
362
+ body: "Source Sans Pro"
363
+ },
364
+ bold: {
365
+ heading: "Montserrat",
366
+ body: "Roboto"
367
+ }
368
+ };
369
+ function generateTailwindTheme(config) {
370
+ const { getColorPalette: getColorPalette2 } = (init_colors(), __toCommonJS(colors_exports));
371
+ const palette = config.preset ? getColorPalette2(config.preset) : null;
372
+ const colors = {
373
+ primary: {
374
+ ...palette?.primary || {},
375
+ ...config.colors?.primary || {}
376
+ },
377
+ accent: {
378
+ ...palette?.accent || {},
379
+ ...config.colors?.accent || {}
380
+ }
381
+ };
382
+ return {
383
+ colors,
384
+ fontFamily: config.fonts ? {
385
+ heading: [config.fonts.heading, "serif"],
386
+ body: [config.fonts.body, "sans-serif"],
387
+ ...config.fonts.accent ? { accent: [config.fonts.accent, "sans-serif"] } : {}
388
+ } : void 0,
389
+ borderRadius: config.borderRadius ? {
390
+ DEFAULT: getBorderRadiusValue(config.borderRadius)
391
+ } : void 0,
392
+ boxShadow: config.shadows ? {
393
+ DEFAULT: getShadowValue(config.shadows)
394
+ } : void 0
395
+ };
396
+ }
397
+ function generateTailwindConfig(config) {
398
+ const themeExtend = generateTailwindTheme(config);
399
+ return {
400
+ theme: {
401
+ extend: themeExtend
402
+ }
403
+ };
404
+ }
405
+ function generateCSSVariables(config) {
406
+ const { getColorPalette: getColorPalette2 } = (init_colors(), __toCommonJS(colors_exports));
407
+ const palette = config.preset ? getColorPalette2(config.preset) : null;
408
+ const variables = {};
409
+ if (palette) {
410
+ for (const [shade, color] of Object.entries(palette.primary)) {
411
+ variables[`--color-primary-${shade}`] = color;
412
+ }
413
+ for (const [shade, color] of Object.entries(palette.accent)) {
414
+ variables[`--color-accent-${shade}`] = color;
415
+ }
416
+ }
417
+ if (config.colors?.primary) {
418
+ for (const [shade, color] of Object.entries(config.colors.primary)) {
419
+ variables[`--color-primary-${shade}`] = color;
420
+ }
421
+ }
422
+ if (config.colors?.accent) {
423
+ for (const [shade, color] of Object.entries(config.colors.accent)) {
424
+ variables[`--color-accent-${shade}`] = color;
425
+ }
426
+ }
427
+ if (config.fonts) {
428
+ if (config.fonts.heading) {
429
+ variables["--font-heading"] = config.fonts.heading;
430
+ }
431
+ if (config.fonts.body) {
432
+ variables["--font-body"] = config.fonts.body;
433
+ }
434
+ if (config.fonts.accent) {
435
+ variables["--font-accent"] = config.fonts.accent;
436
+ }
437
+ }
438
+ return variables;
439
+ }
440
+ function generateCSSVariablesString(config) {
441
+ const variables = generateCSSVariables(config);
442
+ const lines = Object.entries(variables).map(([key, value]) => ` ${key}: ${value};`);
443
+ return `:root {
444
+ ${lines.join("\n")}
445
+ }`;
446
+ }
447
+ function getBorderRadiusValue(size) {
448
+ const values = {
449
+ none: "0",
450
+ sm: "0.125rem",
451
+ md: "0.375rem",
452
+ lg: "0.5rem",
453
+ xl: "0.75rem",
454
+ full: "9999px"
455
+ };
456
+ return values[size || "md"];
457
+ }
458
+ function getShadowValue(size) {
459
+ const values = {
460
+ none: "none",
461
+ sm: "0 1px 2px 0 rgb(0 0 0 / 0.05)",
462
+ md: "0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1)",
463
+ lg: "0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1)"
464
+ };
465
+ return values[size || "md"];
466
+ }
467
+ function getPrimaryColor(config, shade = 600) {
468
+ const { getColorPalette: getColorPalette2 } = (init_colors(), __toCommonJS(colors_exports));
469
+ if (config.colors?.primary?.[shade]) {
470
+ return config.colors.primary[shade];
471
+ }
472
+ if (config.preset) {
473
+ const palette = getColorPalette2(config.preset);
474
+ return palette.primary[shade];
475
+ }
476
+ return "#0c8de9";
477
+ }
478
+ function getAccentColor(config, shade = 600) {
479
+ const { getColorPalette: getColorPalette2 } = (init_colors(), __toCommonJS(colors_exports));
480
+ if (config.colors?.accent?.[shade]) {
481
+ return config.colors.accent[shade];
482
+ }
483
+ if (config.preset) {
484
+ const palette = getColorPalette2(config.preset);
485
+ return palette.accent[shade];
486
+ }
487
+ return "#16a34a";
488
+ }
489
+ function recommendFontPairing(businessType) {
490
+ const recommendations = {
491
+ tailor: "classic",
492
+ restaurant: "elegant",
493
+ "home-kitchen": "friendly",
494
+ salon: "modern",
495
+ accountant: "professional",
496
+ lawyer: "professional",
497
+ "auto-repair": "bold",
498
+ "shoe-repair": "classic",
499
+ generic: "modern"
500
+ };
501
+ const pairingName = recommendations[businessType] || "modern";
502
+ return fontPairings[pairingName];
503
+ }
504
+ export {
505
+ boldRed,
506
+ coolBlue,
507
+ earthGreen,
508
+ elegantGold,
509
+ fontPairings,
510
+ forestGreen,
511
+ freshTeal,
512
+ generateCSSVariables,
513
+ generateCSSVariablesString,
514
+ generateTailwindConfig,
515
+ generateTailwindTheme,
516
+ getAccentColor,
517
+ getColorPalette,
518
+ getPrimaryColor,
519
+ recommendFontPairing,
520
+ slateGray,
521
+ softPink,
522
+ themePalettes,
523
+ warmAmber,
524
+ warmBrown
525
+ };
526
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/theme/colors.ts","../../src/theme/index.ts"],"sourcesContent":["/**\n * Theme Color Palettes\n *\n * Pre-defined color palettes for different business types and styles.\n * Each palette follows Tailwind's color scale (50-950).\n */\n\nimport type { ColorPalette, ThemePreset } from '../config/types';\n\n/**\n * Warm Brown - Tailoring, leather, traditional crafts\n */\nexport const warmBrown: ColorPalette = {\n primary: {\n 50: '#faf8f6',\n 100: '#f2ede8',\n 200: '#e4d9ce',\n 300: '#d3c0ad',\n 400: '#bfa38a',\n 500: '#a68a6d',\n 600: '#8b7058',\n 700: '#735c49',\n 800: '#604d3f',\n 900: '#514237',\n 950: '#2b221c',\n },\n accent: {\n 50: '#fef3f2',\n 100: '#fee4e2',\n 200: '#fecdca',\n 300: '#fcaca5',\n 400: '#f87d71',\n 500: '#ef5544',\n 600: '#dc3626',\n 700: '#b92a1c',\n 800: '#99261b',\n 900: '#7f261d',\n 950: '#450f0a',\n },\n};\n\n/**\n * Cool Blue - Professional services, tech, trust\n */\nexport const coolBlue: ColorPalette = {\n primary: {\n 50: '#f0f7ff',\n 100: '#e0effe',\n 200: '#b9dffd',\n 300: '#7cc5fc',\n 400: '#36a8f8',\n 500: '#0c8de9',\n 600: '#006fc7',\n 700: '#0159a1',\n 800: '#064c85',\n 900: '#0b406e',\n 950: '#072849',\n },\n accent: {\n 50: '#f0fdf4',\n 100: '#dcfce7',\n 200: '#bbf7d0',\n 300: '#86efac',\n 400: '#4ade80',\n 500: '#22c55e',\n 600: '#16a34a',\n 700: '#15803d',\n 800: '#166534',\n 900: '#14532d',\n 950: '#052e16',\n },\n};\n\n/**\n * Earth Green - Natural, organic, outdoor\n */\nexport const earthGreen: ColorPalette = {\n primary: {\n 50: '#f4f9f4',\n 100: '#e5f2e7',\n 200: '#cce5d0',\n 300: '#a3d0ac',\n 400: '#72b381',\n 500: '#4f9760',\n 600: '#3d7a4c',\n 700: '#33613f',\n 800: '#2c4e35',\n 900: '#26412e',\n 950: '#112317',\n },\n accent: {\n 50: '#fefce8',\n 100: '#fef9c3',\n 200: '#fef08a',\n 300: '#fde047',\n 400: '#facc15',\n 500: '#eab308',\n 600: '#ca8a04',\n 700: '#a16207',\n 800: '#854d0e',\n 900: '#713f12',\n 950: '#422006',\n },\n};\n\n/**\n * Warm Amber - Food, hospitality, warmth\n */\nexport const warmAmber: ColorPalette = {\n primary: {\n 50: '#fffbeb',\n 100: '#fef3c7',\n 200: '#fde68a',\n 300: '#fcd34d',\n 400: '#fbbf24',\n 500: '#f59e0b',\n 600: '#d97706',\n 700: '#b45309',\n 800: '#92400e',\n 900: '#78350f',\n 950: '#451a03',\n },\n accent: {\n 50: '#fef2f2',\n 100: '#fee2e2',\n 200: '#fecaca',\n 300: '#fca5a5',\n 400: '#f87171',\n 500: '#ef4444',\n 600: '#dc2626',\n 700: '#b91c1c',\n 800: '#991b1b',\n 900: '#7f1d1d',\n 950: '#450a0a',\n },\n};\n\n/**\n * Elegant Gold - Luxury, formal, upscale\n */\nexport const elegantGold: ColorPalette = {\n primary: {\n 50: '#fdfcf7',\n 100: '#f9f5e7',\n 200: '#f2e9cb',\n 300: '#e8d7a5',\n 400: '#dcc07a',\n 500: '#cfaa58',\n 600: '#c09548',\n 700: '#a0783d',\n 800: '#826037',\n 900: '#6b4f31',\n 950: '#3b2a19',\n },\n accent: {\n 50: '#f8fafc',\n 100: '#f1f5f9',\n 200: '#e2e8f0',\n 300: '#cbd5e1',\n 400: '#94a3b8',\n 500: '#64748b',\n 600: '#475569',\n 700: '#334155',\n 800: '#1e293b',\n 900: '#0f172a',\n 950: '#020617',\n },\n};\n\n/**\n * Fresh Teal - Modern, creative, spa\n */\nexport const freshTeal: ColorPalette = {\n primary: {\n 50: '#f0fdfa',\n 100: '#ccfbf1',\n 200: '#99f6e4',\n 300: '#5eead4',\n 400: '#2dd4bf',\n 500: '#14b8a6',\n 600: '#0d9488',\n 700: '#0f766e',\n 800: '#115e59',\n 900: '#134e4a',\n 950: '#042f2e',\n },\n accent: {\n 50: '#fdf4ff',\n 100: '#fae8ff',\n 200: '#f5d0fe',\n 300: '#f0abfc',\n 400: '#e879f9',\n 500: '#d946ef',\n 600: '#c026d3',\n 700: '#a21caf',\n 800: '#86198f',\n 900: '#701a75',\n 950: '#4a044e',\n },\n};\n\n/**\n * Bold Red - Auto, sports, energy\n */\nexport const boldRed: ColorPalette = {\n primary: {\n 50: '#fef2f2',\n 100: '#fee2e2',\n 200: '#fecaca',\n 300: '#fca5a5',\n 400: '#f87171',\n 500: '#ef4444',\n 600: '#dc2626',\n 700: '#b91c1c',\n 800: '#991b1b',\n 900: '#7f1d1d',\n 950: '#450a0a',\n },\n accent: {\n 50: '#f8fafc',\n 100: '#f1f5f9',\n 200: '#e2e8f0',\n 300: '#cbd5e1',\n 400: '#94a3b8',\n 500: '#64748b',\n 600: '#475569',\n 700: '#334155',\n 800: '#1e293b',\n 900: '#0f172a',\n 950: '#020617',\n },\n};\n\n/**\n * Soft Pink - Beauty, feminine, delicate\n */\nexport const softPink: ColorPalette = {\n primary: {\n 50: '#fdf2f8',\n 100: '#fce7f3',\n 200: '#fbcfe8',\n 300: '#f9a8d4',\n 400: '#f472b6',\n 500: '#ec4899',\n 600: '#db2777',\n 700: '#be185d',\n 800: '#9d174d',\n 900: '#831843',\n 950: '#500724',\n },\n accent: {\n 50: '#faf5ff',\n 100: '#f3e8ff',\n 200: '#e9d5ff',\n 300: '#d8b4fe',\n 400: '#c084fc',\n 500: '#a855f7',\n 600: '#9333ea',\n 700: '#7e22ce',\n 800: '#6b21a8',\n 900: '#581c87',\n 950: '#3b0764',\n },\n};\n\n/**\n * Slate Gray - Minimalist, industrial\n */\nexport const slateGray: ColorPalette = {\n primary: {\n 50: '#f8fafc',\n 100: '#f1f5f9',\n 200: '#e2e8f0',\n 300: '#cbd5e1',\n 400: '#94a3b8',\n 500: '#64748b',\n 600: '#475569',\n 700: '#334155',\n 800: '#1e293b',\n 900: '#0f172a',\n 950: '#020617',\n },\n accent: {\n 50: '#ecfeff',\n 100: '#cffafe',\n 200: '#a5f3fc',\n 300: '#67e8f9',\n 400: '#22d3ee',\n 500: '#06b6d4',\n 600: '#0891b2',\n 700: '#0e7490',\n 800: '#155e75',\n 900: '#164e63',\n 950: '#083344',\n },\n};\n\n/**\n * Forest Green - Deep nature, sustainability\n */\nexport const forestGreen: ColorPalette = {\n primary: {\n 50: '#f0fdf4',\n 100: '#dcfce7',\n 200: '#bbf7d0',\n 300: '#86efac',\n 400: '#4ade80',\n 500: '#22c55e',\n 600: '#16a34a',\n 700: '#15803d',\n 800: '#166534',\n 900: '#14532d',\n 950: '#052e16',\n },\n accent: {\n 50: '#fffbeb',\n 100: '#fef3c7',\n 200: '#fde68a',\n 300: '#fcd34d',\n 400: '#fbbf24',\n 500: '#f59e0b',\n 600: '#d97706',\n 700: '#b45309',\n 800: '#92400e',\n 900: '#78350f',\n 950: '#451a03',\n },\n};\n\n/**\n * Map of theme presets to color palettes.\n */\nexport const themePalettes: Record<ThemePreset, ColorPalette> = {\n 'warm-brown': warmBrown,\n 'cool-blue': coolBlue,\n 'earth-green': earthGreen,\n 'warm-amber': warmAmber,\n 'elegant-gold': elegantGold,\n 'fresh-teal': freshTeal,\n 'bold-red': boldRed,\n 'soft-pink': softPink,\n 'slate-gray': slateGray,\n 'forest-green': forestGreen,\n};\n\n/**\n * Get a color palette by theme preset name.\n */\nexport function getColorPalette(preset: ThemePreset): ColorPalette {\n return themePalettes[preset] || themePalettes['cool-blue'];\n}\n","/**\n * SheetSite Theme Module\n *\n * Provides theming utilities, color palettes, and Tailwind CSS configuration helpers.\n */\n\nimport type { ThemeConfig, ThemePreset, ColorPalette, FontConfig } from '../config/types';\nexport { getColorPalette, themePalettes } from './colors';\nexport * from './colors';\n\n// =============================================================================\n// FONT CONFIGURATIONS\n// =============================================================================\n\n/**\n * Recommended font pairings.\n */\nexport const fontPairings: Record<string, FontConfig> = {\n classic: {\n heading: 'Playfair Display',\n body: 'Inter',\n },\n modern: {\n heading: 'Inter',\n body: 'Inter',\n },\n elegant: {\n heading: 'Cormorant Garamond',\n body: 'Lato',\n },\n friendly: {\n heading: 'Nunito',\n body: 'Open Sans',\n },\n professional: {\n heading: 'Merriweather',\n body: 'Source Sans Pro',\n },\n bold: {\n heading: 'Montserrat',\n body: 'Roboto',\n },\n};\n\n// =============================================================================\n// TAILWIND CONFIGURATION GENERATOR\n// =============================================================================\n\n/**\n * Generate Tailwind CSS theme extension from a theme configuration.\n */\nexport function generateTailwindTheme(config: ThemeConfig): object {\n const { getColorPalette } = require('./colors');\n const palette = config.preset ? getColorPalette(config.preset) : null;\n\n // Merge custom colors with preset\n const colors = {\n primary: {\n ...(palette?.primary || {}),\n ...(config.colors?.primary || {}),\n },\n accent: {\n ...(palette?.accent || {}),\n ...(config.colors?.accent || {}),\n },\n };\n\n return {\n colors,\n fontFamily: config.fonts\n ? {\n heading: [config.fonts.heading, 'serif'],\n body: [config.fonts.body, 'sans-serif'],\n ...(config.fonts.accent ? { accent: [config.fonts.accent, 'sans-serif'] } : {}),\n }\n : undefined,\n borderRadius: config.borderRadius\n ? {\n DEFAULT: getBorderRadiusValue(config.borderRadius),\n }\n : undefined,\n boxShadow: config.shadows\n ? {\n DEFAULT: getShadowValue(config.shadows),\n }\n : undefined,\n };\n}\n\n/**\n * Generate a complete Tailwind config object.\n */\nexport function generateTailwindConfig(config: ThemeConfig): object {\n const themeExtend = generateTailwindTheme(config);\n\n return {\n theme: {\n extend: themeExtend,\n },\n };\n}\n\n/**\n * Generate CSS custom properties from a theme configuration.\n * Useful for CSS-in-JS or custom styling.\n */\nexport function generateCSSVariables(config: ThemeConfig): Record<string, string> {\n const { getColorPalette } = require('./colors');\n const palette = config.preset ? getColorPalette(config.preset) : null;\n const variables: Record<string, string> = {};\n\n // Add color variables\n if (palette) {\n for (const [shade, color] of Object.entries(palette.primary)) {\n variables[`--color-primary-${shade}`] = color as string;\n }\n for (const [shade, color] of Object.entries(palette.accent)) {\n variables[`--color-accent-${shade}`] = color as string;\n }\n }\n\n // Add custom colors\n if (config.colors?.primary) {\n for (const [shade, color] of Object.entries(config.colors.primary)) {\n variables[`--color-primary-${shade}`] = color;\n }\n }\n if (config.colors?.accent) {\n for (const [shade, color] of Object.entries(config.colors.accent)) {\n variables[`--color-accent-${shade}`] = color;\n }\n }\n\n // Add font variables\n if (config.fonts) {\n if (config.fonts.heading) {\n variables['--font-heading'] = config.fonts.heading;\n }\n if (config.fonts.body) {\n variables['--font-body'] = config.fonts.body;\n }\n if (config.fonts.accent) {\n variables['--font-accent'] = config.fonts.accent;\n }\n }\n\n return variables;\n}\n\n/**\n * Generate the CSS string for custom properties.\n */\nexport function generateCSSVariablesString(config: ThemeConfig): string {\n const variables = generateCSSVariables(config);\n const lines = Object.entries(variables).map(([key, value]) => ` ${key}: ${value};`);\n return `:root {\\n${lines.join('\\n')}\\n}`;\n}\n\n// =============================================================================\n// HELPERS\n// =============================================================================\n\nfunction getBorderRadiusValue(size: ThemeConfig['borderRadius']): string {\n const values: Record<NonNullable<ThemeConfig['borderRadius']>, string> = {\n none: '0',\n sm: '0.125rem',\n md: '0.375rem',\n lg: '0.5rem',\n xl: '0.75rem',\n full: '9999px',\n };\n return values[size || 'md'];\n}\n\nfunction getShadowValue(size: ThemeConfig['shadows']): string {\n const values: Record<NonNullable<ThemeConfig['shadows']>, string> = {\n none: 'none',\n sm: '0 1px 2px 0 rgb(0 0 0 / 0.05)',\n md: '0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1)',\n lg: '0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1)',\n };\n return values[size || 'md'];\n}\n\n// =============================================================================\n// THEME UTILITIES\n// =============================================================================\n\n/**\n * Get the primary color for a given shade.\n */\nexport function getPrimaryColor(config: ThemeConfig, shade: keyof ColorPalette['primary'] = 600): string {\n const { getColorPalette } = require('./colors');\n\n // Check custom colors first\n if (config.colors?.primary?.[shade]) {\n return config.colors.primary[shade];\n }\n\n // Fall back to preset\n if (config.preset) {\n const palette = getColorPalette(config.preset);\n return palette.primary[shade];\n }\n\n // Default\n return '#0c8de9'; // cool-blue 500\n}\n\n/**\n * Get the accent color for a given shade.\n */\nexport function getAccentColor(config: ThemeConfig, shade: keyof ColorPalette['accent'] = 600): string {\n const { getColorPalette } = require('./colors');\n\n // Check custom colors first\n if (config.colors?.accent?.[shade]) {\n return config.colors.accent[shade];\n }\n\n // Fall back to preset\n if (config.preset) {\n const palette = getColorPalette(config.preset);\n return palette.accent[shade];\n }\n\n // Default\n return '#16a34a'; // green 600\n}\n\n/**\n * Recommend a font pairing for a business type.\n */\nexport function recommendFontPairing(businessType: string): FontConfig {\n const recommendations: Record<string, string> = {\n tailor: 'classic',\n restaurant: 'elegant',\n 'home-kitchen': 'friendly',\n salon: 'modern',\n accountant: 'professional',\n lawyer: 'professional',\n 'auto-repair': 'bold',\n 'shoe-repair': 'classic',\n generic: 'modern',\n };\n\n const pairingName = recommendations[businessType] || 'modern';\n return fontPairings[pairingName];\n}\n"],"mappings":"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","names":["getColorPalette"]}
package/package.json ADDED
@@ -0,0 +1,96 @@
1
+ {
2
+ "name": "@aws505/sheetsite",
3
+ "version": "1.0.0",
4
+ "publishConfig": {
5
+ "access": "public"
6
+ },
7
+ "description": "Build Google Sheets-powered websites for small businesses. Optimized for AI-assisted development with Claude Code.",
8
+ "main": "dist/index.js",
9
+ "module": "dist/index.mjs",
10
+ "types": "dist/index.d.ts",
11
+ "exports": {
12
+ ".": {
13
+ "types": "./dist/index.d.ts",
14
+ "import": "./dist/index.mjs",
15
+ "require": "./dist/index.js"
16
+ },
17
+ "./components": {
18
+ "types": "./dist/components/index.d.ts",
19
+ "import": "./dist/components/index.mjs",
20
+ "require": "./dist/components/index.js"
21
+ },
22
+ "./data": {
23
+ "types": "./dist/data/index.d.ts",
24
+ "import": "./dist/data/index.mjs",
25
+ "require": "./dist/data/index.js"
26
+ },
27
+ "./theme": {
28
+ "types": "./dist/theme/index.d.ts",
29
+ "import": "./dist/theme/index.mjs",
30
+ "require": "./dist/theme/index.js"
31
+ },
32
+ "./seo": {
33
+ "types": "./dist/seo/index.d.ts",
34
+ "import": "./dist/seo/index.mjs",
35
+ "require": "./dist/seo/index.js"
36
+ },
37
+ "./config": {
38
+ "types": "./dist/config/index.d.ts",
39
+ "import": "./dist/config/index.mjs",
40
+ "require": "./dist/config/index.js"
41
+ }
42
+ },
43
+ "files": [
44
+ "dist",
45
+ "src/components",
46
+ "src/config",
47
+ "src/data",
48
+ "src/theme",
49
+ "src/seo",
50
+ "README.md"
51
+ ],
52
+ "scripts": {
53
+ "build": "tsup",
54
+ "dev": "tsup --watch",
55
+ "lint": "eslint src/",
56
+ "typecheck": "tsc --noEmit",
57
+ "test": "vitest",
58
+ "prepublishOnly": "npm run build"
59
+ },
60
+ "keywords": [
61
+ "google-sheets",
62
+ "website-builder",
63
+ "small-business",
64
+ "nextjs",
65
+ "react",
66
+ "tailwindcss",
67
+ "claude-code",
68
+ "ai-development",
69
+ "local-business",
70
+ "cms",
71
+ "headless"
72
+ ],
73
+ "author": "WebSeller",
74
+ "license": "MIT",
75
+ "peerDependencies": {
76
+ "next": ">=14.0.0",
77
+ "react": ">=18.0.0",
78
+ "react-dom": ">=18.0.0",
79
+ "tailwindcss": ">=3.0.0"
80
+ },
81
+ "dependencies": {
82
+ "zod": "^3.22.4"
83
+ },
84
+ "devDependencies": {
85
+ "@types/node": "^20.10.0",
86
+ "@types/react": "^18.2.0",
87
+ "@types/react-dom": "^18.2.0",
88
+ "eslint": "^8.56.0",
89
+ "tsup": "^8.0.1",
90
+ "typescript": "^5.3.0",
91
+ "vitest": "^1.2.0"
92
+ },
93
+ "engines": {
94
+ "node": ">=18.0.0"
95
+ }
96
+ }