feat: improve formatting
This commit is contained in:
parent
4e79e361e5
commit
94ff3febe8
@ -3,8 +3,8 @@
|
|||||||
|
|
||||||
#let education = indent[
|
#let education = indent[
|
||||||
#work_entry(
|
#work_entry(
|
||||||
"B.A.Sc. in Computer Engineering",
|
|
||||||
"University of Waterloo",
|
"University of Waterloo",
|
||||||
|
"B.A.Sc. in Computer Engineering, Honours",
|
||||||
start_date: "Sep 2022",
|
start_date: "Sep 2022",
|
||||||
end_date: "Apr 2027",
|
end_date: "Apr 2027",
|
||||||
location: "Waterloo, ON",
|
location: "Waterloo, ON",
|
||||||
@ -44,8 +44,8 @@
|
|||||||
of Figma designs with Vercel's API],
|
of Figma designs with Vercel's API],
|
||||||
[Developed a new external REST API for customers who wanted to access their token
|
[Developed a new external REST API for customers who wanted to access their token
|
||||||
data programmatically], // termination display (FE), external API for customers not using our platform (BE)
|
data programmatically], // termination display (FE), external API for customers not using our platform (BE)
|
||||||
[Wrote and audited smart contracts on Solana blockchain to add claim fees to our
|
[Wrote and audited smart contracts on the Solana blockchain to add claim fees to
|
||||||
token vesting platform],
|
our token vesting platform],
|
||||||
),
|
),
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -62,9 +62,10 @@
|
|||||||
documents with S3 and Textract],
|
documents with S3 and Textract],
|
||||||
[Championed and shipped features for *SOC 2 security compliance*, including
|
[Championed and shipped features for *SOC 2 security compliance*, including
|
||||||
*role-based permissions with JWTs* in Spring Boot, alert logging with
|
*role-based permissions with JWTs* in Spring Boot, alert logging with
|
||||||
CloudWatch, and stronger privacy controls for user data],
|
CloudWatch, and strong privacy controls for user data],
|
||||||
[Reduced dashboard load time by 38% by implementing a stale-while-revalidate
|
[Reduced dashboard load time by 38% by implementing a stale-while-revalidate
|
||||||
caching strategy],
|
caching strategy],
|
||||||
|
// [?? Calendly integration + OAuth],
|
||||||
[Created a parallel *CI/CD system from scratch* with Terraform and Jenkins to
|
[Created a parallel *CI/CD system from scratch* with Terraform and Jenkins to
|
||||||
automatically deploy AWS Lambdas], // BE-infra only, FE ver is admin dashboard
|
automatically deploy AWS Lambdas], // BE-infra only, FE ver is admin dashboard
|
||||||
),
|
),
|
||||||
@ -82,7 +83,7 @@
|
|||||||
[Architected a data query builder and executor engine for customers to visualise
|
[Architected a data query builder and executor engine for customers to visualise
|
||||||
their data warehouses by custom-tailoring forms on-the-fly, supporting complex
|
their data warehouses by custom-tailoring forms on-the-fly, supporting complex
|
||||||
nested logic for 3000+ enterprise users across 8 database types], //
|
nested logic for 3000+ enterprise users across 8 database types], //
|
||||||
[Shipped an *LSP server for our custom query DSL*, including user-specific
|
[Shipped an *LSP server for our custom query language*, including user-specific
|
||||||
autocomplete and syntax highlighting],
|
autocomplete and syntax highlighting],
|
||||||
[Developed a serverless microservice to asynchronously ingest email attachments
|
[Developed a serverless microservice to asynchronously ingest email attachments
|
||||||
directly into ETL pipelines],
|
directly into ETL pipelines],
|
||||||
@ -105,10 +106,10 @@
|
|||||||
mobile wallet passes over Express],
|
mobile wallet passes over Express],
|
||||||
[Overhauled CI/CD pipelines, speeding up builds by *35%* by parallelising testing
|
[Overhauled CI/CD pipelines, speeding up builds by *35%* by parallelising testing
|
||||||
and type checking],
|
and type checking],
|
||||||
[Introduced backend tracing with OpenTelemetry and Grafana to profile performance
|
[*Introduced backend tracing* with OpenTelemetry and Grafana to profile
|
||||||
issues in production],
|
performance issues in production],
|
||||||
[Resolved load spike crashes in prod by caching queries via *Redis* and
|
[*Resolved load spike crashes* in prod by caching queries via Redis and
|
||||||
horizontally scaling services on *Kubernetes*],
|
horizontally scaling services on Kubernetes],
|
||||||
),
|
),
|
||||||
)
|
)
|
||||||
]
|
]
|
||||||
@ -143,6 +144,18 @@
|
|||||||
),
|
),
|
||||||
)
|
)
|
||||||
|
|
||||||
|
#project(
|
||||||
|
"Arch Linux Server",
|
||||||
|
"Linux, Docker, nginx, systemd",
|
||||||
|
demo_link: "https://eggworld.me",
|
||||||
|
tasks: (
|
||||||
|
[Created a *self-hosted CI/CD pipeline* with *Gitea* to automatically deploy
|
||||||
|
personal projects behind *nginx*], // TODO
|
||||||
|
[Managed services with *Docker* and *systemd* to simplify deployment and resource
|
||||||
|
constrainment], // TODO
|
||||||
|
),
|
||||||
|
)
|
||||||
|
|
||||||
// #project(
|
// #project(
|
||||||
// "Genshin Rewards Simulator",
|
// "Genshin Rewards Simulator",
|
||||||
// "Vue, TypeScript",
|
// "Vue, TypeScript",
|
||||||
@ -181,15 +194,4 @@
|
|||||||
// - Aggregated common ingredients heuristically to build a shopping list and a meal
|
// - Aggregated common ingredients heuristically to build a shopping list and a meal
|
||||||
// plan for each week
|
// plan for each week
|
||||||
|
|
||||||
#project(
|
|
||||||
"Arch Linux Server (\"hwaboon\")",
|
|
||||||
"Linux, Docker, nginx, systemd",
|
|
||||||
demo_link: "https://eggworld.me",
|
|
||||||
tasks: (
|
|
||||||
[Created a *self-hosted CI/CD pipeline* with *Gitea* to automatically deploy
|
|
||||||
personal projects behind *nginx*], // TODO
|
|
||||||
[Managed services with *Docker* and *systemd* to simplify deployment and resource
|
|
||||||
constrainment], // TODO
|
|
||||||
),
|
|
||||||
)
|
|
||||||
]
|
]
|
29
lib/lib.typ
29
lib/lib.typ
@ -1,23 +1,26 @@
|
|||||||
#import "fontawesome.typ": github, fa, link-icon
|
#import "fontawesome.typ": github, fa, link-icon
|
||||||
|
|
||||||
#let DEFAULT_STRONG = 300;
|
#let DEFAULT_STRONG = 300;
|
||||||
#let SMALL_STRONG = 200;
|
#let SMALL_STRONG = 300;
|
||||||
|
|
||||||
#let TITLE_FONT = "Bitter"
|
#let TITLE_FONT = "Bitter"
|
||||||
#let HEADING_FONT = TITLE_FONT
|
#let HEADING_FONT = TITLE_FONT
|
||||||
#let BODY_FONT = "Open Sans"
|
#let BODY_FONT = "Open Sans"
|
||||||
|
|
||||||
#let BODY_FONT_SIZE = 9.75pt
|
#let BODY_FONT_SIZE = 9.75pt
|
||||||
#let HEADING_FONT_SIZE = 0.95em
|
#let HEADING_FONT_SIZE = 0.9em
|
||||||
#let TITLE_FONT_SIZE = 2em
|
#let TITLE_FONT_SIZE = 2em
|
||||||
|
|
||||||
#let HEADING_LINE_GAP = 3mm
|
#let HEADING_LINE_GAP = 3mm
|
||||||
#let BODY_LINE_HEIGHT = 0.75em
|
#let HEADING_ABOVE_GAP = 1em
|
||||||
|
#let HEADING_BELOW_GAP = 0.75em
|
||||||
|
|
||||||
#let HEADING_DETAILS_LIST_SPACING = 0.9em
|
#let BODY_LINE_HEIGHT = 0.7em
|
||||||
|
|
||||||
|
#let HEADING_DETAILS_LIST_SPACING = 1em
|
||||||
#let DETAILS_TITLE_FONT_SIZE = 1.075em
|
#let DETAILS_TITLE_FONT_SIZE = 1.075em
|
||||||
|
|
||||||
#let DETAILS_LIST_SPACING = 0.8em
|
#let DETAILS_LIST_SPACING = 0.9em
|
||||||
#let DETAILS_LIST_INDENT = 1.5em
|
#let DETAILS_LIST_INDENT = 1.5em
|
||||||
|
|
||||||
// rest = not top
|
// rest = not top
|
||||||
@ -49,7 +52,7 @@
|
|||||||
{
|
{
|
||||||
set strong(delta: SMALL_STRONG)
|
set strong(delta: SMALL_STRONG)
|
||||||
show link: underline
|
show link: underline
|
||||||
list(tight: false, spacing: DETAILS_LIST_SPACING, marker: [•], ..details)
|
list(tight: false, spacing: DETAILS_LIST_SPACING, marker: [*•*], ..details)
|
||||||
},
|
},
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
@ -66,24 +69,22 @@
|
|||||||
company_link: none,
|
company_link: none,
|
||||||
) = {
|
) = {
|
||||||
cv_entry(left_content: {
|
cv_entry(left_content: {
|
||||||
set par(leading: 0.75em)
|
|
||||||
|
|
||||||
text(1.05em)[*#role*]
|
text(1.05em)[*#role*]
|
||||||
|
|
||||||
if tools != none {
|
if tools != none {
|
||||||
text[ | _ #tools _ ]
|
// text[ | _ #tools _ ]
|
||||||
}
|
}
|
||||||
|
|
||||||
"\n"
|
"\n"
|
||||||
set strong(delta: SMALL_STRONG)
|
set strong(delta: SMALL_STRONG)
|
||||||
|
|
||||||
if company_link == none {
|
if company_link == none {
|
||||||
[*#company*]
|
[_#company _]
|
||||||
} else {
|
} else {
|
||||||
[#link(company_link)[*#company*]]
|
[#link(company_link)[_#company _]]
|
||||||
}
|
}
|
||||||
}, right_content: {
|
}, right_content: {
|
||||||
[*#start_date -- #end_date*]
|
[#start_date -- #end_date]
|
||||||
|
|
||||||
if location != none {
|
if location != none {
|
||||||
"\n" + format_location(location)
|
"\n" + format_location(location)
|
||||||
@ -140,7 +141,7 @@
|
|||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
set block(above: 0.9em, below: 0.75em)
|
set block(above: HEADING_ABOVE_GAP, below: HEADING_BELOW_GAP)
|
||||||
set text(size: HEADING_FONT_SIZE, fill: color, font: HEADING_FONT)
|
set text(size: HEADING_FONT_SIZE, fill: color, font: HEADING_FONT)
|
||||||
stack(
|
stack(
|
||||||
dir: ltr,
|
dir: ltr,
|
||||||
@ -149,6 +150,8 @@
|
|||||||
box(height: 2pt, fill: color, colored_line(title)),
|
box(height: 2pt, fill: color, colored_line(title)),
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
set strong(delta: SMALL_STRONG)
|
||||||
doc
|
doc
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
#import "fontawesome.typ": fa, globe, github, linkedin, envelope
|
#import "fontawesome.typ": fa, globe, github, linkedin, envelope
|
||||||
#import "lib.typ": template, work_entry, project, indent, SMALL_STRONG, DEFAULT_STRONG, render_contact_data
|
#import "lib.typ": template, work_entry, project, indent, SMALL_STRONG, DEFAULT_STRONG, render_contact_data
|
||||||
|
|
||||||
#let SEQUENCE = ("skills", "content", "education")
|
#let SEQUENCE = ("content", "skills", "education")
|
||||||
|
|
||||||
// orange!!
|
// orange!!
|
||||||
#let color = blue // rgb("#ff983e")
|
#let color = blue // rgb("#ff983e")
|
||||||
|
10
systems.typ
10
systems.typ
@ -3,8 +3,8 @@
|
|||||||
|
|
||||||
#let education = indent[
|
#let education = indent[
|
||||||
#work_entry(
|
#work_entry(
|
||||||
"B.A.Sc. in Computer Engineering",
|
|
||||||
"University of Waterloo",
|
"University of Waterloo",
|
||||||
|
"B.A.Sc. in Computer Engineering, Honours",
|
||||||
start_date: "Sep 2022",
|
start_date: "Sep 2022",
|
||||||
end_date: "Apr 2027",
|
end_date: "Apr 2027",
|
||||||
location: "Waterloo, ON",
|
location: "Waterloo, ON",
|
||||||
@ -44,8 +44,8 @@
|
|||||||
portals based off of Figma designs],
|
portals based off of Figma designs],
|
||||||
[Developed a new external REST API for customers who wanted to access their token
|
[Developed a new external REST API for customers who wanted to access their token
|
||||||
data programmatically], // termination display (FE), external API for customers not using our platform (BE)
|
data programmatically], // termination display (FE), external API for customers not using our platform (BE)
|
||||||
[Wrote and audited smart contracts on Solana blockchain to add claim fees to our
|
[Wrote and audited smart contracts on the Solana blockchain to add claim fees to
|
||||||
token vesting platform],
|
our token vesting platform],
|
||||||
),
|
),
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -62,7 +62,7 @@
|
|||||||
documents with S3 and Textract],
|
documents with S3 and Textract],
|
||||||
[Championed and shipped features for *SOC 2 security compliance*, including
|
[Championed and shipped features for *SOC 2 security compliance*, including
|
||||||
*role-based permissions with JWTs* in Spring Boot, alert logging with
|
*role-based permissions with JWTs* in Spring Boot, alert logging with
|
||||||
CloudWatch, and stronger privacy controls for user data],
|
CloudWatch, and strong privacy controls for user data],
|
||||||
[Reduced dashboard load time by *38%* by implementing a stale-while-revalidate
|
[Reduced dashboard load time by *38%* by implementing a stale-while-revalidate
|
||||||
caching strategy],
|
caching strategy],
|
||||||
[Created a parallel *CI/CD system from scratch* with Terraform and Jenkins to
|
[Created a parallel *CI/CD system from scratch* with Terraform and Jenkins to
|
||||||
@ -155,7 +155,7 @@
|
|||||||
)
|
)
|
||||||
|
|
||||||
#project(
|
#project(
|
||||||
"Arch Linux Server (\"hwaboon\")",
|
"Arch Linux Server",
|
||||||
"Linux, Docker, nginx, systemd",
|
"Linux, Docker, nginx, systemd",
|
||||||
demo_link: "https://eggworld.me",
|
demo_link: "https://eggworld.me",
|
||||||
tasks: (
|
tasks: (
|
||||||
|
@ -3,8 +3,8 @@
|
|||||||
|
|
||||||
#let education = indent[
|
#let education = indent[
|
||||||
#work_entry(
|
#work_entry(
|
||||||
"B.A.Sc. in Computer Engineering",
|
|
||||||
"University of Waterloo",
|
"University of Waterloo",
|
||||||
|
"B.A.Sc. in Computer Engineering, Honours",
|
||||||
start_date: "Sep 2022",
|
start_date: "Sep 2022",
|
||||||
end_date: "Apr 2027",
|
end_date: "Apr 2027",
|
||||||
location: "Waterloo, ON",
|
location: "Waterloo, ON",
|
||||||
@ -60,7 +60,7 @@
|
|||||||
documents with S3 and Textract],
|
documents with S3 and Textract],
|
||||||
[Championed and shipped features for *SOC 2 security compliance*, including
|
[Championed and shipped features for *SOC 2 security compliance*, including
|
||||||
*role-based permissions with JWTs* in Spring Boot, alert logging with
|
*role-based permissions with JWTs* in Spring Boot, alert logging with
|
||||||
CloudWatch, and stronger privacy controls for user data],
|
CloudWatch, and strong privacy controls for user data],
|
||||||
[Reduced dashboard load time by 38% by implementing a stale-while-revalidate
|
[Reduced dashboard load time by 38% by implementing a stale-while-revalidate
|
||||||
caching strategy],
|
caching strategy],
|
||||||
),
|
),
|
||||||
|
Loading…
Reference in New Issue
Block a user