⚛️ 💎 My resume built with React and rendered to Sketch using
react-sketchapp
.
Requirements: Sketch 43+, Raleway font family.
- 🎂 Dynamic age based on my birthdate
- 📅 Events sorted in descending chronological order
- 🎓 Timelines' state updated at every render (circles get filled when a contract with a university or a company is over)
- 🔢 Retrieve only my last projects and experiences
- 🔤 Sort items alphabetically
- Fetch my GitHub pinned repositories
- 🇫🇷 Translate to any language (only French and English are relevant to me)
- Install dependencies:
yarn install
- Run the images server:
yarn serve
- Render to Sketch:
yarn render
Alternatively, you can use yarn start
to serve the images and render.
- Render in French:
yarn render:fr
- Render in English:
yarn render:en
- Render in prototype mode:
yarn render:mock
- Render in production:
yarn render:production
By default, the resume is in mock
environment (doesn't pull real data from GitHub) when developing.
- Create an OAuth token to get access to the GitHub GraphQL API (only
public_repo
scope is required) - Option 1:
- Add your newly generated token in
config/.config.github.js
- Change the environment config variable in
config/.config.env.js
to anything butmock
(e.g.production
)
- Add your newly generated token in
- Option 2:
- Stay in
mock
environment - Duplicate
.env.sample
, rename it.env
and fill the right GitHub information - Run
yarn github:fetch
to re-generate your up-to-date pinned repositories
- Stay in
- Run
yarn render
to render to Sketch
Once you have saved your PDF in output/resume.[lang].pdf
, run yarn pdf:metadata
to fill the correct Exif metadata.
All the information of the resume is stored in the data
folder, both in English and French.
react-sketchapp
is still in early development and doesn't support local image import. I had to serve my images
folder to render them in the artboard.
Everything is rendered with React, except gradients and skew lines shown on the screenshot, which are not yet supported by react-sketchapp
. I added some fancy tweaks manually in Sketch.
The main reason I have never kept my resume updated is that the workflow was terrible. I will now only need to update the data and render in any language.
I was quite bored with "static" resumes and thought it was a good opportunity to display some real data in there. I used the GitHub GraphQL API to fetch my pinned repositories and inject them into Sketch.
I'm more a developer than a designer, eh.
MIT © François Chalifour