diff --git a/backend_infra.typ b/backend_infra.typ index d06b251..5a7dc5f 100644 --- a/backend_infra.typ +++ b/backend_infra.typ @@ -3,8 +3,8 @@ #let education = indent[ #work_entry( - "B.A.Sc. in Computer Engineering", "University of Waterloo", + "B.A.Sc. in Computer Engineering, Honours", start_date: "Sep 2022", end_date: "Apr 2027", location: "Waterloo, ON", @@ -44,8 +44,8 @@ of Figma designs with Vercel's API], [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) - [Wrote and audited smart contracts on Solana blockchain to add claim fees to our - token vesting platform], + [Wrote and audited smart contracts on the Solana blockchain to add claim fees to + our token vesting platform], ), ) @@ -62,9 +62,10 @@ documents with S3 and Textract], [Championed and shipped features for *SOC 2 security compliance*, including *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 caching strategy], + // [?? Calendly integration + OAuth], [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 ), @@ -82,7 +83,7 @@ [Architected a data query builder and executor engine for customers to visualise their data warehouses by custom-tailoring forms on-the-fly, supporting complex 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], [Developed a serverless microservice to asynchronously ingest email attachments directly into ETL pipelines], @@ -105,10 +106,10 @@ mobile wallet passes over Express], [Overhauled CI/CD pipelines, speeding up builds by *35%* by parallelising testing and type checking], - [Introduced backend tracing with OpenTelemetry and Grafana to profile performance - issues in production], - [Resolved load spike crashes in prod by caching queries via *Redis* and - horizontally scaling services on *Kubernetes*], + [*Introduced backend tracing* with OpenTelemetry and Grafana to profile + performance issues in production], + [*Resolved load spike crashes* in prod by caching queries via Redis and + 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( // "Genshin Rewards Simulator", // "Vue, TypeScript", @@ -181,15 +194,4 @@ // - Aggregated common ingredients heuristically to build a shopping list and a meal // 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 - ), - ) ] \ No newline at end of file diff --git a/lib/lib.typ b/lib/lib.typ index 8e49351..ff76657 100644 --- a/lib/lib.typ +++ b/lib/lib.typ @@ -1,23 +1,26 @@ #import "fontawesome.typ": github, fa, link-icon #let DEFAULT_STRONG = 300; -#let SMALL_STRONG = 200; +#let SMALL_STRONG = 300; #let TITLE_FONT = "Bitter" #let HEADING_FONT = TITLE_FONT #let BODY_FONT = "Open Sans" #let BODY_FONT_SIZE = 9.75pt -#let HEADING_FONT_SIZE = 0.95em +#let HEADING_FONT_SIZE = 0.9em #let TITLE_FONT_SIZE = 2em #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_LIST_SPACING = 0.8em +#let DETAILS_LIST_SPACING = 0.9em #let DETAILS_LIST_INDENT = 1.5em // rest = not top @@ -49,7 +52,7 @@ { set strong(delta: SMALL_STRONG) 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, ) = { cv_entry(left_content: { - set par(leading: 0.75em) - text(1.05em)[*#role*] if tools != none { - text[ | _ #tools _ ] + // text[ | _ #tools _ ] } "\n" set strong(delta: SMALL_STRONG) if company_link == none { - [*#company*] + [_#company _] } else { - [#link(company_link)[*#company*]] + [#link(company_link)[_#company _]] } }, right_content: { - [*#start_date -- #end_date*] + [#start_date -- #end_date] if location != none { "\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) stack( dir: ltr, @@ -149,6 +150,8 @@ box(height: 2pt, fill: color, colored_line(title)), ) } + + set strong(delta: SMALL_STRONG) doc } diff --git a/lib/template_common.typ b/lib/template_common.typ index 273946b..4d5d7f4 100644 --- a/lib/template_common.typ +++ b/lib/template_common.typ @@ -1,7 +1,7 @@ #import "fontawesome.typ": fa, globe, github, linkedin, envelope #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!! #let color = blue // rgb("#ff983e") diff --git a/systems.typ b/systems.typ index 01027c9..4fea8d1 100644 --- a/systems.typ +++ b/systems.typ @@ -3,8 +3,8 @@ #let education = indent[ #work_entry( - "B.A.Sc. in Computer Engineering", "University of Waterloo", + "B.A.Sc. in Computer Engineering, Honours", start_date: "Sep 2022", end_date: "Apr 2027", location: "Waterloo, ON", @@ -44,8 +44,8 @@ portals based off of Figma designs], [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) - [Wrote and audited smart contracts on Solana blockchain to add claim fees to our - token vesting platform], + [Wrote and audited smart contracts on the Solana blockchain to add claim fees to + our token vesting platform], ), ) @@ -62,7 +62,7 @@ documents with S3 and Textract], [Championed and shipped features for *SOC 2 security compliance*, including *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 caching strategy], [Created a parallel *CI/CD system from scratch* with Terraform and Jenkins to @@ -155,7 +155,7 @@ ) #project( - "Arch Linux Server (\"hwaboon\")", + "Arch Linux Server", "Linux, Docker, nginx, systemd", demo_link: "https://eggworld.me", tasks: ( diff --git a/web_fullstack.typ b/web_fullstack.typ index ffc06dc..7e9e4a8 100644 --- a/web_fullstack.typ +++ b/web_fullstack.typ @@ -3,8 +3,8 @@ #let education = indent[ #work_entry( - "B.A.Sc. in Computer Engineering", "University of Waterloo", + "B.A.Sc. in Computer Engineering, Honours", start_date: "Sep 2022", end_date: "Apr 2027", location: "Waterloo, ON", @@ -60,7 +60,7 @@ documents with S3 and Textract], [Championed and shipped features for *SOC 2 security compliance*, including *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 caching strategy], ),