Special thanks to elipapa's project as my inspiration and references. This CV is using Jekyll-based page and is rendered by the GitHub page pipeline. Features:
- Customizable templates π¨
- Pre-build Pipeline for generating PDF files π
- Pre-build docker-compose π³
- Fork this repository
- Create a new branch from the main branch
- Enable GitHub page on new branch
- Edit
index.md
content on the new branch - Commit, see the result on
https://[your-username].github.io/[repo-name]
You can use this repo to start creating your markdown-based CV.
You can start to fork this repo, create a new branch (example: gh-pages
), and directly edit the index.md
content. to name it available online, you can enable GitHub pages on Settings > Pages. on the Branch section, choose the gh-pages
branch and Save
it. The GitHub pages will deploy your site to https://[your-username].github.io/[repo-name]
There are several templates available that will be added soon to this repo, you can take a look at ./media/
.
It has naming format [template_name]-print.css
and [template_name]-screen.css
. You can edit _config.yml
, and edit the style: ...
value to template_name
you want to use.
If you want to preview the results first before committing to the repo, you can install Jekyll in your local env. Please refer to Jekyll official website about how to install Jekyll locally.
If you have docker installed, you can utilize docker-compose.yml
that is already created here.
Clone this repo to your local. Use the terminal/command prompt, change the current directory to this repo, and type the following command:
docker-compose up -d
It will create use port 4000
by default. You can customize the port by editing the docker-compose.yml
file. For example, if you want to change 4000
to 4077
change the port section to:
...
ports:
- '4077:4000'
...
Jekyll will automatically update the content based on the md file state, it has a refresh period time (on my testing it will be around the 20s). So you don't have to re-create the container to update the page render. But, if you edit _config.yml
you can re-up the container by retyping the command above
To clean up the container, you can type the following command:
docker-compose down
Workflow:
graph TD;
A[Generate Jekyll page artifacts]-->B[Setup Variables]
B[Setup Variables]-->C[Create PDF from artifacts]
C[Create PDF from artifacts]-->D[Create release tag]
D[Create release tag]-->E[Embed PDF to release tag]
To enable generate PDF feature, you can enable the GitHub action integration after you fork this repo.
This pipeline also has options to generate PDFs privately in case you want to include sensitive data (phone number). The generated PDF will not create a new release into the repo, and also the PDF will expired 48h after it generated on pipeline artifacts.
You can use this feature by tick the check box β
Build privately & include sensitive data
. To fill the phone number:
- Open repo Settings > Secrets and variables > Actions
- Going to
Secrets
tab and click New repository secret. - Fill Name with
CV_PHONE_NUMBER
, and Secret with your phone number (ex:+62 123123123
)
I believe this project is still far from stable/good, so I also looking for better improvement. You can submit about new templates, new pipeline feature, refactor, etc. by creating Pull Request (PR) to this repo
MIT License
Copyright (c) [David Layardi [email protected]]
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.