Compare commits

..

1 Commits

Author SHA1 Message Date
eggy
280d0f7eba feat: add flashnote
for mozilla only!
2023-11-03 18:38:17 -04:00
2 changed files with 70 additions and 95 deletions

View File

@@ -2,7 +2,7 @@
#import "lib.typ": template, work_entry, project, indent, SMALL_STRONG, DEFAULT_STRONG
// orange!!
#let color = rgb("#ff983e")
#let color = blue // rgb("#ff983e")
#let name = "Daniel Chen"
#let contact_data = ((
@@ -27,15 +27,30 @@
// MAIN CONTENT STARTS here
= Education
#indent[
#work_entry(
"University of Waterloo",
"B.A.Sc. in Computer Engineering",
start_date: "Sep 2022",
end_date: "Apr 2027 (expected)",
location: "Waterloo, ON",
tasks: (
[Courses: Object-oriented programming, data structures & algorithms, digital
computers & circuits],
),
)
]
= Skills
#indent[
*Languages:* Python, TypeScript, JavaScript, Rust, SQL, MATLAB, C, C++, Java,
HTML, CSS, Dart \
*Languages:* Python, TypeScript/JavaScript, Rust, SQL, C++, Java, HTML, CSS \
*Frameworks:* Node.js, Express, React, Next.js, Vue, Flutter, Qt, Prisma,
Apollo, Axum, Jest, Pytest \
*Tools:* Linux, Git, Docker, PostgreSQL, Redis, Kubernetes, AWS, GCP, Heroku,
OpenTelemetry, GraphQL, Android
Apollo, Axum \
*Tools:* Linux, Git, Docker, PostgreSQL, Redis, Kubernetes, AWS, GCP,
OpenTelemetry, GraphQL
]
= Experience
@@ -49,30 +64,30 @@
end_date: "Aug 2023",
location: "Remote",
tasks: (
[Engineered a database-specific *SQL IDE autocompletion tool* via a heuristic
algorithm to validate queries],
[Developed a service to sync HubSpot and Airtable data with Google Sheets via
*AWS Lambda*],
[Constructed dynamic forms in *react-hook-form* by generating questions from the
backend on-the-fly],
[Created testing infrastructure for the backend with *Pytest* to catch
regressions across database engines],
[Developed a *FastAPI backend* to sync HubSpot and Airtable data with Google
Sheets via *AWS Lambda*],
[Engineered a *heuristic algorithm* to guarantee *SQL* aliases referenced in
queries match the database schema],
[Refactored the frontend to use *react-hook-form* to aggregate and validate user
input, improving DX],
[Built a #link("https://dropmail.dev")[service] for *validating and importing
CSV/Excel* files from customer emails into client databases],
),
)
#work_entry(
"Backend Developer",
"Hack the North",
"Techyon",
start_date: "Mar 2023",
end_date: "present",
location: "Waterloo, ON",
tasks: (
[Streamlined registration by dynamically generating *user-specific Apple Wallet
passes* over *Apollo GraphQL*],
[Dynamically generated user-specific *Apple Wallet* passes over *Apollo GraphQL*
Server to streamline check-in],
[Horizontally scaled the *Node.js* server to handle *1000+ concurrent users* with
*Redis* and *Kubernetes*],
[Automated judging scheduling by creating a *greedy algorithm* to match judges to
project themes],
[Automated judge-to-hacker matching and scheduling with a custom algorithm based
on their preferences],
[Integrated *OpenTelemetry* and Grafana in a *Kubernetes* cluster to collect
traces and improve observability],
),
@@ -84,68 +99,52 @@
#indent[
#project(
"RecipeReady",
"https://devpost.com/software/recipeready-wk4bo9",
"Flashnote Flashcard Generator",
"https://github.com/potatoeggy/flashnote",
"Java, Android",
)
- Created an Android app to generate study flashcards from handwritten notes using *Google Cloud*
- Interfaced with GCP's Vision and NLP APIs to extract text and
keywords from images with *Retrofit* and *Gson*
#project(
"RecipeReady Recipe Aggregator",
"https://github.com/vincentjguo/recipeready-server",
"Flutter, Selenium, FastAPI, Android",
)
- Developed a *Flutter app* to generate recipes based on ingredients and filters
through a FastAPI server
- Scraped thousands of websites for recipes to build a database with a robust
*many-to-many tag system*
*many-to-many tagging system*
- Aggregated common ingredients heuristically to build a shopping list and a meal
plan for each week
#project(
"Mandown Comic Converter",
"https://github.com/potatoeggy/mandown",
"Python, Qt",
)
- Created a CLI and GUI to scrape, download, and convert webcomics into
e-ink-optimised ebooks (EPUB, PDF)
- Designed an *intermediate representation* to store metadata and images as a
standardised conversion target
- Implemented *image caching and multiprocessing* to increase download and update
speeds by *300%*
- Minimised regressions between release cycles by writing *unit and integration
tests* with 55% code coverage
#project(
"Genshin Simulator",
"Primoprod Genshin Simulator",
"https://github.com/potatoeggy/primoprod",
"Vue, TypeScript, Capacitor, Android",
"Vue, TypeScript",
)
- Built an realistic *cross-platform loot box simulator* with fluid animations
based off a popular game
- Reduced action latency by *90%* by lazily loading art assets at opportune times,
such as during cutscenes
- Built an interactive, realistic, and beautiful game simulator with fluid
animations based off a popular game
- Ported the game to native desktop and mobile applications with *Capacitor*, *WebView*, and *Electron*
#project(
"Flashcard Generator",
"https://github.com/potatoeggy/flashnote",
"Java, Android",
)
- Created an Android app to generate study *flashcards from handwritten notes*
using *Google Cloud*
- Interfaced with GCP's Vision and NLP APIs to extract text and keywords from
images with *Retrofit* and *Gson*
- Isolated key terms with GCP's NLP API to convert declarative sentences into
questions and answers
#project(
"Kobo Sync Server",
"https://github.com/potatoeggy/kobink",
"Rust, Axum",
)
- Developed an Axum backend to *automatically convert and sync* ebooks to a Kobo
eReader over the network
- *Reverse-engineered* the Kobo eReader Sync API to support updating ebook
metadata and covers
// #project(
// "Comic Downloader & Converter",
// "https://github.com/potatoeggy/mandown",
// "Python, Qt",
// )
// - Created a CLI and GUI to scrape, download, and convert webcomics into
// e-ink-optimised ebooks (EPUB, PDF)
// - Designed an *intermediate representation* to store metadata and images as a
// standardised conversion target
// - Implemented *image caching and multiprocessing* to increase download and update
// speeds by *300%*
// - Minimised regressions between release cycles by writing *unit and integration
// tests* with 55% code coverage
// #project("Arch Linux Server", none, "Linux, nginx, systemd")
// - Created a *self-hosted CI/CD pipeline* with *Gitea* to automatically deploy
// personal projects behind *nginx*
// - Set up *Jellyfin* for media streaming, a *Minecraft* server, *Calibre* for ebook
// syncing, and other services
// #project("Kobink — Kobo Sync Server", "https://github.com/potatoeggy/kobink", "Rust, Axum, Postgres")
// - ??? something here (reverse engineering)
// - ??? something here (synchronisation and DB, HTTP headers)
]
= Awards
@@ -156,19 +155,3 @@
StormHacks 2022 from 350+ participants
- Winner of the #link("https://github.com/anyuan-chen/perdiem")[IBM Open Source] prize
at YRHacks 2022 from 90+ participants
= Education
#indent[
#work_entry(
"University of Waterloo",
"B.A.Sc. in Computer Engineering",
start_date: "Sep 2022",
end_date: "Apr 2027",
location: "Waterloo, ON",
tasks: (
[Courses: Object-oriented programming, data structures & algorithms, digital
computers & circuits],
),
)
]

12
lib.typ
View File

@@ -67,11 +67,7 @@
none
}
cv_entry(left_content: {
set par(leading: 0.75em)
text(1.1em)[*#role*]
"\n"
set strong(delta: SMALL_STRONG)
text[*#company*]
text(1.1em)[*#role*] + "\n" + text[#emph[#company]]
}, right_content: {
[*#start_date -- #end_date*]
@@ -83,11 +79,7 @@
#let project(title, repo_link, tools) = {
set strong(delta: DEFAULT_STRONG)
if repo_link != none {
link(repo_link)[#text(1.1em)[*#title* #fa(github)]] + [ | _ #tools _ ]
} else {
text(1.1em)[*#title*] + [ | _ #tools _ ]
}
link(repo_link)[#text(1.1em)[*#title* #fa(github)]] + [ | _ #tools _ ]
}
// Set name and contact data and format headings