@jsonresume/jsonresume-theme-creative-studio 1.0.0 → 1.0.1
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/.eslintrc.js +9 -0
- package/.turbo/turbo-build.log +11 -0
- package/dist/index.js +6423 -0
- package/dist/style.css +139 -0
- package/package.json +24 -8
- package/src/ui/{Awards.js → Awards.jsx} +1 -1
- package/src/ui/{Certificates.js → Certificates.jsx} +1 -1
- package/src/ui/Date.js +2 -1
- package/src/ui/{Education.js → Education.jsx} +2 -2
- package/src/ui/{Interests.js → Interests.jsx} +1 -1
- package/src/ui/{Languages.js → Languages.jsx} +1 -1
- package/src/ui/{Projects.js → Projects.jsx} +2 -2
- package/src/ui/{Publications.js → Publications.jsx} +1 -1
- package/src/ui/{References.js → References.jsx} +1 -1
- package/src/ui/Resume.jsx +447 -0
- package/src/ui/{Skills.js → Skills.jsx} +1 -1
- package/src/ui/{Summary.js → Summary.jsx} +1 -1
- package/src/ui/{Volunteer.js → Volunteer.jsx} +2 -2
- package/src/ui/{Work.js → Work.jsx} +2 -2
- package/vite.config.js +33 -0
- package/src/ui/Resume.js +0 -43
- /package/src/{index.js → index.jsx} +0 -0
- /package/src/ui/{DateRange.js → DateRange.jsx} +0 -0
- /package/src/ui/{Hero.js → Hero.jsx} +0 -0
- /package/src/ui/{Section.js → Section.jsx} +0 -0
package/dist/style.css
ADDED
|
@@ -0,0 +1,139 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Resume Core Design Tokens
|
|
3
|
+
* Framework-agnostic CSS variables for theming
|
|
4
|
+
* Based on 2025 resume best practices and ATS compatibility research
|
|
5
|
+
*/
|
|
6
|
+
|
|
7
|
+
:root {
|
|
8
|
+
/* Typography - ATS-friendly fonts */
|
|
9
|
+
--resume-font-sans: "Helvetica Neue", Helvetica, Arial, sans-serif;
|
|
10
|
+
--resume-font-serif: Cambria, Georgia, "Times New Roman", serif;
|
|
11
|
+
--resume-font-mono: "Courier New", Courier, monospace;
|
|
12
|
+
|
|
13
|
+
/* Font Sizes - Optimal readability */
|
|
14
|
+
--resume-size-name: 36px; /* Large, prominent name */
|
|
15
|
+
--resume-size-heading: 16px; /* Section titles */
|
|
16
|
+
--resume-size-subheading: 14px; /* Job titles, degrees */
|
|
17
|
+
--resume-size-body: 11px; /* Body text, descriptions */
|
|
18
|
+
--resume-size-small: 10px; /* Dates, locations, metadata */
|
|
19
|
+
|
|
20
|
+
/* Font Weights */
|
|
21
|
+
--resume-weight-normal: 400;
|
|
22
|
+
--resume-weight-medium: 500;
|
|
23
|
+
--resume-weight-semibold: 600;
|
|
24
|
+
--resume-weight-bold: 700;
|
|
25
|
+
|
|
26
|
+
/* Line Heights */
|
|
27
|
+
--resume-line-height-tight: 1.2;
|
|
28
|
+
--resume-line-height-normal: 1.5;
|
|
29
|
+
--resume-line-height-relaxed: 1.75;
|
|
30
|
+
|
|
31
|
+
/* Colors - Professional Theme (default) */
|
|
32
|
+
--resume-color-primary: #1a1a1a;
|
|
33
|
+
--resume-color-secondary: #4a4a4a;
|
|
34
|
+
--resume-color-accent: #2563eb;
|
|
35
|
+
--resume-color-background: #ffffff;
|
|
36
|
+
--resume-color-border: #e5e7eb;
|
|
37
|
+
|
|
38
|
+
/* Spacing - Consistent rhythm */
|
|
39
|
+
--resume-space-section: 24px; /* Between major sections */
|
|
40
|
+
--resume-space-item: 16px; /* Between list items */
|
|
41
|
+
--resume-space-tight: 8px; /* Within items */
|
|
42
|
+
--resume-space-margin: 48px; /* Page margins */
|
|
43
|
+
|
|
44
|
+
/* Layout - Optimal line length */
|
|
45
|
+
--resume-max-width: 660px; /* ~80 chars at body size */
|
|
46
|
+
--resume-column-gap: 24px;
|
|
47
|
+
|
|
48
|
+
/* Border Radius */
|
|
49
|
+
--resume-radius-sm: 4px;
|
|
50
|
+
--resume-radius-md: 8px;
|
|
51
|
+
--resume-radius-lg: 12px;
|
|
52
|
+
|
|
53
|
+
/* Shadows - Subtle depth */
|
|
54
|
+
--resume-shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
|
|
55
|
+
--resume-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
/* Modern Theme Variant */
|
|
59
|
+
[data-theme="modern"] {
|
|
60
|
+
--resume-color-primary: #0f172a;
|
|
61
|
+
--resume-color-secondary: #475569;
|
|
62
|
+
--resume-color-accent: #8b5cf6;
|
|
63
|
+
--resume-font-sans: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
/* Classic Theme Variant */
|
|
67
|
+
[data-theme="classic"] {
|
|
68
|
+
--resume-color-primary: #000000;
|
|
69
|
+
--resume-color-secondary: #333333;
|
|
70
|
+
--resume-color-accent: #0066cc;
|
|
71
|
+
--resume-font-sans: Georgia, "Times New Roman", serif;
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
/* Minimal Theme Variant */
|
|
75
|
+
[data-theme="minimal"] {
|
|
76
|
+
--resume-color-primary: #18181b;
|
|
77
|
+
--resume-color-secondary: #71717a;
|
|
78
|
+
--resume-color-accent: #000000;
|
|
79
|
+
--resume-space-section: 32px;
|
|
80
|
+
--resume-space-item: 20px;
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
/* High Contrast Variant (Accessibility) */
|
|
84
|
+
[data-theme="high-contrast"] {
|
|
85
|
+
--resume-color-primary: #000000;
|
|
86
|
+
--resume-color-secondary: #000000;
|
|
87
|
+
--resume-color-accent: #0000ff;
|
|
88
|
+
--resume-color-background: #ffffff;
|
|
89
|
+
--resume-color-border: #000000;
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
/* Print Styles - ATS-Friendly PDF Export */
|
|
93
|
+
@media print {
|
|
94
|
+
:root {
|
|
95
|
+
/* Optimize for print */
|
|
96
|
+
--resume-space-section: 18px;
|
|
97
|
+
--resume-space-item: 12px;
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
@page {
|
|
101
|
+
size: A4;
|
|
102
|
+
margin: 0.5in;
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
/* Prevent awkward breaks */
|
|
106
|
+
.resume-section {
|
|
107
|
+
page-break-inside: avoid;
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
.resume-item {
|
|
111
|
+
break-inside: avoid;
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
/* Widows and orphans control */
|
|
115
|
+
p, li {
|
|
116
|
+
widows: 3;
|
|
117
|
+
orphans: 3;
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
/* Hyphenation for long words */
|
|
121
|
+
.resume-description {
|
|
122
|
+
hyphens: auto;
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
/* Hide interactive elements */
|
|
126
|
+
.no-print {
|
|
127
|
+
display: none !important;
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
|
|
131
|
+
/* RTL Support */
|
|
132
|
+
[dir="rtl"] {
|
|
133
|
+
text-align: right;
|
|
134
|
+
}
|
|
135
|
+
|
|
136
|
+
[dir="rtl"] .resume-item {
|
|
137
|
+
padding-left: 0;
|
|
138
|
+
padding-right: var(--resume-space-tight);
|
|
139
|
+
}
|
package/package.json
CHANGED
|
@@ -1,24 +1,40 @@
|
|
|
1
1
|
{
|
|
2
2
|
"private": false,
|
|
3
3
|
"name": "@jsonresume/jsonresume-theme-creative-studio",
|
|
4
|
-
"version": "1.0.
|
|
5
|
-
"
|
|
4
|
+
"version": "1.0.1",
|
|
5
|
+
"type": "module",
|
|
6
|
+
"main": "./src/index.jsx",
|
|
6
7
|
"license": "MIT",
|
|
7
8
|
"description": "Creative Studio theme - artistic yet professional with warm coral accents and rounded typography",
|
|
8
9
|
"devDependencies": {
|
|
9
|
-
"
|
|
10
|
-
"
|
|
11
|
-
"
|
|
10
|
+
"@repo/eslint-config-custom": "workspace:^",
|
|
11
|
+
"react": "^19.2.0",
|
|
12
|
+
"styled-components": "^6.1.19",
|
|
13
|
+
"@vitejs/plugin-react": "^4.3.4",
|
|
14
|
+
"vite": "^5.4.21"
|
|
12
15
|
},
|
|
13
16
|
"peerDependencies": {
|
|
14
17
|
"styled-components": "^6"
|
|
15
18
|
},
|
|
19
|
+
"scripts": {
|
|
20
|
+
"lint": "eslint src || exit 0",
|
|
21
|
+
"publish": "npm publish --access public",
|
|
22
|
+
"build": "vite build"
|
|
23
|
+
},
|
|
16
24
|
"dependencies": {
|
|
25
|
+
"@jsonresume/core": "workspace:^",
|
|
17
26
|
"marked": "^16.3.0",
|
|
18
27
|
"prismjs": "^1.29.0",
|
|
19
28
|
"react-icons": "^5.0.1"
|
|
20
29
|
},
|
|
21
|
-
"
|
|
22
|
-
"
|
|
30
|
+
"exports": {
|
|
31
|
+
".": {
|
|
32
|
+
"import": "./src/index.jsx",
|
|
33
|
+
"default": "./src/index.jsx"
|
|
34
|
+
},
|
|
35
|
+
"./dist": {
|
|
36
|
+
"import": "./dist/index.js",
|
|
37
|
+
"default": "./dist/index.js"
|
|
38
|
+
}
|
|
23
39
|
}
|
|
24
|
-
}
|
|
40
|
+
}
|
package/src/ui/Date.js
CHANGED
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
const Date = ({ date }) => {
|
|
2
2
|
if (!date) return null;
|
|
3
3
|
|
|
4
|
-
|
|
4
|
+
// Use global Date constructor instead of window.Date for SSR compatibility
|
|
5
|
+
const dateObj = new globalThis.Date(date);
|
|
5
6
|
const month = dateObj.toLocaleString('default', { month: 'short' });
|
|
6
7
|
const year = dateObj.getFullYear();
|
|
7
8
|
|