-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
642cbfb
commit 35643aa
Showing
3 changed files
with
45 additions
and
37 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,26 @@ | ||
name: Compile and Commit Image of Resume | ||
on: | ||
push: | ||
tags: | ||
- "**" | ||
|
||
permissions: | ||
contents: write | ||
|
||
jobs: | ||
build: | ||
runs-on: ubuntu-latest | ||
steps: | ||
- name: Checkout Repo | ||
uses: actions/checkout@v4 | ||
|
||
- name: Compile PDF with Typst | ||
uses: ammar-ahmed22/compile-typst-action@v1 | ||
with: | ||
source_paths: src/main.typ | ||
output_paths: 'images/latest.png' | ||
fonts_path: 'src/resources/fonts' | ||
- name: Commit file | ||
uses: stefanzweifel/git-auto-commit-action@v5 | ||
with: | ||
commit_message: '[bot]: Updated latest image' |
File renamed without changes.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,50 +1,32 @@ | ||
# Typst Resume | ||
Writing my resume in Typst (the better version of LaTeX) | ||
# Ammar Ahmed's Resume | ||
[data:image/s3,"s3://crabby-images/99abc/99abc9b8a771ca838ea363278663f3fbe24ed422" alt="Latest release tag"](https://github.com/ammar-ahmed22/typst-resume/releases) | ||
|
||
This repository runs CI which compiles my Typst files into PDF's and releases them whenever there is a new tag, with tags being semantically versioned. | ||
Welcome to the home of my resume! Here I host my data-driven, continously deployed resume made possible by [Typst](https://typst.app)! | ||
|
||
## How does this work? | ||
I was inspired by [@jskherman](https://github.com/jskherman/cv.typ) who used `.yaml` files to store the data of his resume to be updated easily and simply. | ||
data:image/s3,"s3://crabby-images/5eaee/5eaee1ccdba78cf4936655be54ddfb00b62b45a8" alt="Latest Resume Image" | ||
|
||
I could have simply forked his repo to make my resume in the same way but I wanted to take on the challenge of doing it myself! | ||
## How It Works | ||
This section explains the workflow and technologies behind the creation and maintenance of my resume. | ||
|
||
Typst comes built-in with file reading and parsing capabilities for `.yaml` files so I used that in conjuction with functions written myself to format the data into my resume. | ||
- **Automated Updates:** On every tagged update, the source files are compiled and released with a [custom authored GitHub action](https://github.com/ammar-ahmed22/compile-typst-action). | ||
- **Data-Driven Resume:** Due to the power of [Typst](https://typst.app), all my resume data is housed in a `.yml` file. Typst is able to read and parse the data which I used to define custom functions to render my resume! | ||
- **Version Control:** All tags and releases are semantically versioned. I've also authored a custom post-commit hook which prompts me if I want to tag the commit. The git hook automatically bumps the version based on the latest tag and whether it is a major, minor, or patch change! | ||
|
||
## How to run? | ||
Being a Node.js guy, I included a `package.json` to make use of `yarn` (or npm) to run the compilation commands easily. | ||
|
||
### Install the following: | ||
- yarn (or npm) | ||
- typst | ||
|
||
Run `yarn build` to compile into a PDF | ||
|
||
Run `yarn watch` to compile ino a PDF and watch for changes in the source file. | ||
|
||
|
||
## Continuous Deployment | ||
### Compile and Release Resume | ||
- GitHub Action that runs whenever a new tag is released | ||
- Compiles the Typst code to PDF and releases it with a timestamp | ||
#### Steps | ||
1. Checks out the repository (so it's available for the action to use) | ||
2. Compiles the Typst code to PDF | ||
3. Uploads the generated PDF as an artifact | ||
4. Releases the generated PDF with the timestamp | ||
|
||
### `post-commit` Git Hook | ||
- Whenever I commit changes locally, I am prompted if I want to tag the commit | ||
- Pulls the latest version | ||
+ Prompted to bump major or minor version | ||
+ Creates the new tag based on the latest | ||
#### Here's how it looks for me: | ||
Here's how it looks when I make a commit: | ||
```bash | ||
>> git add . && git commit -m "Some changes" | ||
[post-commit hook] Commit done! | ||
Would you like to tag this commit? [y/N] y | ||
[current-version]: v1.7 | ||
Is this a major change or a minor change? minor | ||
[bumping-version]: v1.8 | ||
[main 0d0fce2] Updating README.md | ||
[main 0d0fce2] Some changes | ||
2 files changed, 30 insertions(+), 4 deletions(-) | ||
``` | ||
``` | ||
|
||
- **Testing:** Being a `NodeJS` fan, I set up a `package.json` in this repo to be able to run `yarn` commands to compile my resume locally. | ||
|
||
## Connect With Me | ||
I am always open to connecting with professionals from the industry and discussing potential opportunities. | ||
|
||
[data:image/s3,"s3://crabby-images/4782c/4782cd3afefdebcc472b35551b0474231523fdbf" alt="LinkedIn Profile"](https://linkedin.com/in/ammarahmed2203) [data:image/s3,"s3://crabby-images/750da/750dad3d9dd6ef8c99677c2e4411fd0099bad728" alt="Personal Website"](https://ammarahmed.ca) [data:image/s3,"s3://crabby-images/421ae/421aed0e10d78fbad38b45bf5ff5b5986a39241e" alt="Mail"](mailto:[email protected]) |