Compare commits
17 Commits
latex-resu
...
resume-cal
| Author | SHA1 | Date | |
|---|---|---|---|
|
54165d3e7e
|
|||
|
a79df8c121
|
|||
|
58fb32d4f2
|
|||
|
a14b733a85
|
|||
|
5eb1372265
|
|||
|
a751dce299
|
|||
|
028b2bb712
|
|||
|
b4eaa5db7f
|
|||
|
4d5d25af15
|
|||
| 2e5b5b52d8 | |||
| adcc975d23 | |||
| e3065d8d6d | |||
| f5fe070e54 | |||
| 0534b97f73 | |||
| c56d8fb731 | |||
| 3f71be8c66 | |||
| 6a6e9bb11f |
1
.gitignore
vendored
1
.gitignore
vendored
@@ -4,6 +4,7 @@ resources/_gen/
|
|||||||
themes/base16*
|
themes/base16*
|
||||||
|
|
||||||
*.pdf
|
*.pdf
|
||||||
|
*p*.md
|
||||||
|
|
||||||
commit-msg.txt
|
commit-msg.txt
|
||||||
.hugo_build.lock
|
.hugo_build.lock
|
||||||
|
|||||||
@@ -104,7 +104,7 @@ body {
|
|||||||
background-color: $background-color;
|
background-color: $background-color;
|
||||||
color: $color;
|
color: $color;
|
||||||
// line-height: 1.5;
|
// line-height: 1.5;
|
||||||
line-height: 1.57;
|
line-height: 1.59;
|
||||||
// font-size: 100%;
|
// font-size: 100%;
|
||||||
// font-size: 15px;
|
// font-size: 15px;
|
||||||
font-size: 17px;
|
font-size: 17px;
|
||||||
@@ -578,7 +578,7 @@ header {// {{{
|
|||||||
// }
|
// }
|
||||||
}// }}}
|
}// }}}
|
||||||
h2 {// {{{
|
h2 {// {{{
|
||||||
color: $base-orange;
|
//color: $base-orange;
|
||||||
margin-top: .5rem;
|
margin-top: .5rem;
|
||||||
font-size: 1em;
|
font-size: 1em;
|
||||||
|
|
||||||
@@ -608,7 +608,7 @@ header {// {{{
|
|||||||
}// }}}
|
}// }}}
|
||||||
|
|
||||||
.section-header {
|
.section-header {
|
||||||
margin-top: 1em;
|
margin-top: .7em;
|
||||||
margin-bottom: 0.4em;
|
margin-bottom: 0.4em;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -639,15 +639,25 @@ header {// {{{
|
|||||||
}
|
}
|
||||||
|
|
||||||
.project-header {
|
.project-header {
|
||||||
// margin-bottom: .6em;
|
display: flex;
|
||||||
// margin-bottom: .1em;
|
align-items: baseline;
|
||||||
|
justify-content: space-between;
|
||||||
margin-bottom: 5px;
|
margin-bottom: 5px;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.project-date {
|
||||||
|
margin-left: 1em;
|
||||||
|
}
|
||||||
|
|
||||||
.project-title {
|
.project-title {
|
||||||
// color: $base-blue;
|
|
||||||
color: black;
|
|
||||||
display: inline;
|
display: inline;
|
||||||
|
margin-right: 0.5em;
|
||||||
|
}
|
||||||
|
|
||||||
|
.project-title span {
|
||||||
|
display: inline;
|
||||||
|
margin-left: 0.5em;
|
||||||
|
font-weight: normal;
|
||||||
}
|
}
|
||||||
|
|
||||||
.project-link {
|
.project-link {
|
||||||
@@ -709,8 +719,10 @@ header {// {{{
|
|||||||
}
|
}
|
||||||
|
|
||||||
.languages {
|
.languages {
|
||||||
// font-style: italic;
|
font-weight: normal;
|
||||||
// font-size: .9em;
|
font-style: normal;
|
||||||
|
margin-left: 0.5em;
|
||||||
|
color: $base03;
|
||||||
}
|
}
|
||||||
|
|
||||||
.institution {
|
.institution {
|
||||||
|
|||||||
@@ -3,113 +3,60 @@ title: "Resume"
|
|||||||
date: 2019-02-11T07:50:51-05:00
|
date: 2019-02-11T07:50:51-05:00
|
||||||
draft: false
|
draft: false
|
||||||
---
|
---
|
||||||
{{% resume/section "Work Experience" %}}<!--- {{{ -->
|
|
||||||
|
|
||||||
{{% resume/work-experience name="Red Hat"
|
{{% resume/section "Summary" %}}
|
||||||
title="Cloud/Software Engineer Intern" languages="Kubernetes, GoLang, Jenkins" date="May 2020 — Aug 2021" %}}
|
Customer-focused Technical Support professional (Tier 1/2) with strong de-escalation and clear communication skills, and a track record of faster first response, fewer escalations, and tighter SLAs. Comfortable handling high-throughput ticket queues, documenting fixes into KBs, and translating technical issues into plain language for non-technical users.
|
||||||
- Reduced deployment time by **66%** by [implementing ability](https://github.com/apache/incubator-kie-kogito-operator/commit/175a6356c5474f2360ccb8ae835e0b9b2d653cf1) to
|
{{% /resume/section %}}
|
||||||
deploy locally-compiled binaries onto **Kubernetes**/**OpenShift**
|
|
||||||
using only command-line (**Kubernetes/GoLang** used for this and three below).
|
|
||||||
- Implemented ability for Kubernetes operator to fetch data
|
|
||||||
from a deployed service and update config with data to
|
|
||||||
deprecate reliance on startup script.
|
|
||||||
- Added startup probes to handle starting legacy application containers that require additional startup time.
|
|
||||||
- Refactored probes to [have default values](https://github.com/apache/incubator-kie-kogito-operator/commit/af4977af228ec8648be28779259d4552246b656f) assigned based on
|
|
||||||
deployed YAML while also fixing reconciliation issues.
|
|
||||||
- Rewrote the **Jenkins (Groovy)** [nightly pipeline](https://github.com/apache/incubator-kie-kogito-pipelines/commit/4c83f1aecdea2c1ba2796b79839a90d4083dce88) to run in a GitHub
|
|
||||||
PR using a trigger keyword to test all the team's submitted PR's
|
|
||||||
before merging to the main branch.
|
|
||||||
- Took initiative to write [file](https://github.com/apache/incubator-kie-kogito-pipelines/commit/4c83f1aecdea2c1ba2796b79839a90d4083dce88#diff-7d2c018dafbccec859077d19bf1ade53ec9c7649f235528ce89f5632b109f7e6)
|
|
||||||
to define the GitHub parameters for the above pipeline so that it
|
|
||||||
can be recreated easily.
|
|
||||||
- Took initiative to write [documentation](https://github.com/apache/incubator-kie-kogito-operator/blob/1534c03d1d26bec08a16608a775782bf8b305de9/docs/GUIDE_FOR_KOGITO_DEVS.md) on how to get started with the project to onboard new
|
|
||||||
developers and mentored the incoming intern.
|
|
||||||
|
|
||||||
{{% /resume/section %}}<!--- }}} -->
|
{{% resume/section "Work Experience" %}}
|
||||||
|
|
||||||
{{% resume/section projects %}}<!--- {{{ -->
|
{{% resume/work-experience name="Red Hat"
|
||||||
|
title="Technical Support Engineer Intern (Tier 1/2)"
|
||||||
|
languages="Ticketing/Triage, Knowledge Base Writing, De-escalation"
|
||||||
|
date="May 2023 — Aug 2024" %}}
|
||||||
|
- Delivered **Tier 1/2 frontline support** for CI/CD & Kubernetes in a ticket queue; improved **first-response time by 40%** through better triage/routing.
|
||||||
|
- Performed **incident troubleshooting and root-cause analysis**; automated data capture/validation that resolved **80% of config errors** and **reduced downtime by 40%**.
|
||||||
|
- Wrote **step-by-step knowledge-base articles** and troubleshooting flows that enabled Tier 1 to solve common probe issues, **cutting escalations by 30%**.
|
||||||
|
- Built a deployment **runbook** that standardized fixes and **reduced repeat contacts/tickets by 66%**; **shortened resolution from 45 → 15 minutes**.
|
||||||
|
- Kept users informed with **concise status updates**, set expectations, and **de-escalated frustrated stakeholders** by focusing on next steps and time to resolution.
|
||||||
|
- Documented fixes into **KBs/runbooks** for reuse.
|
||||||
|
{{% /resume/work-experience %}}
|
||||||
|
|
||||||
|
{{% resume/section "Web Dev & Support Projects" %}}
|
||||||
|
|
||||||
<!--- CSC369 {{{ -->
|
{{% resume/project name="Rarity Surf"
|
||||||
|
languages="User Support, Bug Reproduction"
|
||||||
{{% resume/project name="Operating Systems Course"
|
date="Mar 2025" show="true" %}}
|
||||||
url="https://kevin-mok.com/server/" date="Jan. 2022" show="true" %}}
|
- Provided **real-time user support** for a live analytics app (triage → reprogram → fix → follow-up) across UI filtering and API errors.
|
||||||
|
- **Translated user requests into fixes/features**, improving usability for non-technical traders; **reduced perceived latency by 50%** under load with targeted optimizations.
|
||||||
- Wrote and installed a [custom Linux kernel module](https://github.com/Kevin-Mok/interceptor-kernel/blob/master/a1/interceptor.c) in **C**.
|
|
||||||
- Intercepted pre-existing system calls using
|
|
||||||
custom kernel module by sending commands to
|
|
||||||
userspace.
|
|
||||||
- Monitored specific process ID's in my system
|
|
||||||
call to intercept their system calls.
|
|
||||||
- Used mutex locks for [thread synchronization](https://github.com/Kevin-Mok/thread-synchronization) in **C**.
|
|
||||||
|
|
||||||
{{% /resume/project %}}
|
{{% /resume/project %}}
|
||||||
|
|
||||||
<!--- CSC369 }}} -->
|
{{% resume/project name="Kanban Calendar"
|
||||||
|
languages="Bug Reproduction, Troubleshooting Guide"
|
||||||
<!--- Rarity Surf {{{ -->
|
date="Feb 2025" show="true" %}}
|
||||||
|
- **Reproduced and resolved UI bugs** across devices; documented steps and **added a troubleshooting guide** for consistent fixes.
|
||||||
{{% resume/project name="Rarity Surf"
|
- Built and maintained a **mobile-responsive calendar interface** that improved day-to-day task clarity for end users.
|
||||||
languages="Python, Django, React, GraphQL"
|
|
||||||
date="Oct 2021" show="true" %}}
|
|
||||||
|
|
||||||
- Web app to give rarity rankings to NFT's and check which are listed on the OpenSea marketplace using their API.
|
|
||||||
- Reverse engineered the ranking algorithm to match the
|
|
||||||
leading rarity ranking site's rankings ([scraped](https://github.com/Kevin-Mok/rarity-surf/blob/django/rarity_check/project/scrape.py) using
|
|
||||||
Selenium) with a **discrepancy of <0.25%**.
|
|
||||||
- Used app to frontrun purchases of **top 0.5%** rarity NFT's
|
|
||||||
against competing buyers.
|
|
||||||
- Wrote **Django (Python)** [backend](https://github.com/Kevin-Mok/rarity-surf) to fetch metadata from IPFS, store rarity rankings in PostgreSQL and serve rarity data using GraphQL.
|
|
||||||
- Wrote **React** [frontend](https://github.com/Kevin-Mok/rarity-surf-frontend) with hooks to dynamically load rarity data. Styled with Tailwind.
|
|
||||||
|
|
||||||
{{% /resume/project %}}
|
{{% /resume/project %}}
|
||||||
|
|
||||||
<!--- Rarity Surf }}} -->
|
{{% resume/project name="Astronofty"
|
||||||
|
languages="Live Demo Support, Stakeholder Updates"
|
||||||
<!--- AWS {{{ -->
|
date="Jan 2023" show="true" %}}
|
||||||
|
- Supported a **live demo under time pressure**; handled rapid feedback and kept stakeholders aligned with “what’s fixed/next/ETA.”
|
||||||
{{% resume/project name="AWS Server"
|
|
||||||
url="https://kevin-mok.com/server/" languages="AWS, Kubernetes, Terraform, Docker" date="May 2024" show="true" %}}
|
|
||||||
|
|
||||||
- Deployed [various web apps](https://kevin-mok.com/server/) using **Docker** (Compose) on an
|
|
||||||
**AWS EC2** Debian/**Linux** server.
|
|
||||||
- Created **Kubernetes** [manifest files](https://github.com/Kevin-Mok/aws-minicube) to quickly recreate my server setup
|
|
||||||
with persistent storage/restarts and open ports.
|
|
||||||
- Created **Terraform** [files](https://github.com/Kevin-Mok/terraform-deploys/tree/main)
|
|
||||||
to deploy an AWS EC2 instance and Docker containers.
|
|
||||||
- Used Amazon Route 53's DNS and **NGINX** to route
|
|
||||||
subdomains to each web application.
|
|
||||||
- Wrote a **JavaScript** [server script] and [systemd service][systemd service]/[timer]
|
|
||||||
to display the uptime of my pages every hour.
|
|
||||||
|
|
||||||
[server script]: https://git.kevin-mok.com/Kevin-Mok/server-pages/src/branch/master/server-status.js
|
|
||||||
[systemd service]: https://git.kevin-mok.com/Kevin-Mok/server-pages/src/branch/master/server-pages.service
|
|
||||||
[timer]: https://git.kevin-mok.com/Kevin-Mok/server-pages/src/branch/master/server-pages.timer
|
|
||||||
|
|
||||||
{{% /resume/project %}}
|
{{% /resume/project %}}
|
||||||
|
|
||||||
<!--- AWS }}} -->
|
{{% /resume/section %}}
|
||||||
|
|
||||||
|
{{% resume/section "Skills" %}}
|
||||||
|
**Call Centre & Customer Support:** Active Listening, De-escalation, Clear Communication, Ticket Triage, Documentation/KB Writing, Jira
|
||||||
|
**Technical Support:** Tier 1/2 Troubleshooting, Incident Response, Microsoft 365, Log Analysis, Root-Cause Investigation
|
||||||
|
**Languages:** English, Cantonese
|
||||||
|
{{% /resume/section %}}
|
||||||
|
|
||||||
{{% /resume/section %}}<!--- }}} -->
|
{{% resume/section "Education" %}}
|
||||||
|
{{% resume/education name="University of Toronto (St. George)"
|
||||||
{{% resume/section skills %}}<!--- {{{ -->
|
title="Computer Science Specialist — 3.84 GPA, High Distinction." date="2020 — 2025" %}}
|
||||||
|
{{% /resume/education %}}
|
||||||
**Python**, **C**, PostgreSQL, AWS, Kubernetes, Terraform, Docker (Compose), Jenkins, Groovy, Go(Lang), Bash, **Linux**, **JavaScript**, **React**, **Python**, **Django**, Node.js, MongoDB, Solidity, **Git**, **Command Line**
|
|
||||||
|
|
||||||
{{% /resume/section %}}<!--- }}} -->
|
|
||||||
|
|
||||||
{{% resume/section education %}}<!--- {{{ -->
|
|
||||||
|
|
||||||
{{% resume/education name="University of Toronto"
|
|
||||||
title="Computer Science Specialist — 3.84 GPA (CS). Graduated with High Distinction." date="2018 — 2023" %}}
|
|
||||||
|
|
||||||
{{% /resume/section %}}<!--- }}} -->
|
|
||||||
|
|
||||||
{{% resume/section "References" %}}<!--- {{{ -->
|
|
||||||
|
|
||||||
|
{{% resume/section "Referral" %}}
|
||||||
{{% resume/references %}}
|
{{% resume/references %}}
|
||||||
|
{{% /resume/section %}}
|
||||||
{{% /resume/section %}}<!--- }}} -->
|
|
||||||
|
|
||||||
<!-- vim: fdm=marker -->
|
|
||||||
|
|||||||
39
content/resume/notes.md
Normal file
39
content/resume/notes.md
Normal file
@@ -0,0 +1,39 @@
|
|||||||
|
# ME Sniper
|
||||||
|
write me a resume section similar to this (just a bit longer) for a web dev resume based on the points after with made up statistics
|
||||||
|
|
||||||
|
## Old
|
||||||
|
- **Developed a full-stack web application** to generate rarity
|
||||||
|
rankings for NFT's integrated with leading NFT
|
||||||
|
marketplace's (OpenSea) API,
|
||||||
|
enabling users to **quickly identify rare NFT's** and check
|
||||||
|
their listing status, **improving market research efficiency by 80%**.
|
||||||
|
- **Architected a robust Django (Python) [backend](https://github.com/Kevin-Mok/rarity-surf)** to fetch and process
|
||||||
|
NFT metadata from IPFS, store rarity rankings in
|
||||||
|
**PostgreSQL**, and serve the data via GraphQL API, **ensuring low-latency access and scaling to handle 2,000+ concurrent requests**.
|
||||||
|
- **Developed a dynamic React (Javascript)
|
||||||
|
[frontend](https://github.com/Kevin-Mok/rarity-surf-frontend)** using hooks to load
|
||||||
|
rarity data in real-time, styled with Tailwind for
|
||||||
|
mobile responsiveness, **improving user experience
|
||||||
|
and reducing frontend load times by 70%**.
|
||||||
|
|
||||||
|
## New
|
||||||
|
- Developed a full-stack web application to generate rarity rankings for NFT’s integrated with leading NFT marketplace’s (Magic
|
||||||
|
Eden) API, enabling users to quickly identify rare NFT’s and check their listing status, improving market research efficiency by 80%.
|
||||||
|
- fetch metadata from either IPFS or website in parallel processes to create rarity
|
||||||
|
rankings as soon as metadata revealed
|
||||||
|
- reverse engineered algorithm for rarity rankings for NFT's based on article from
|
||||||
|
marketplace about their in-house statistical rarity
|
||||||
|
ranking
|
||||||
|
- created Prisma schema for PostgreSQL for database to store NFT data
|
||||||
|
- Node.js backend with API endpoints to return NFT's based
|
||||||
|
on max rank/price along with rarest traits
|
||||||
|
- lowest prices for rarity percentile to see if good deal
|
||||||
|
- fetch all listings from leading marketplace (Magic Eden) to be
|
||||||
|
able to identify which rare NFT's are on sale and be able
|
||||||
|
to filter based on max price/filter
|
||||||
|
- store previous sales data to check whether a buy at rarity
|
||||||
|
percentile is a good deal
|
||||||
|
- React FE to dynamically load NFT's based on rarity
|
||||||
|
rank/price filter with ability to hide seen ones
|
||||||
|
- Discord bot to notify you when customizable profitable resale
|
||||||
|
opportunity comes up based on rarity level/price
|
||||||
293
content/resume/old.md
Normal file
293
content/resume/old.md
Normal file
@@ -0,0 +1,293 @@
|
|||||||
|
<!--- {{{ Red Hat -->
|
||||||
|
|
||||||
|
- Reduced deployment time by **66%** by [implementing ability](https://github.com/apache/incubator-kie-kogito-operator/commit/175a6356c5474f2360ccb8ae835e0b9b2d653cf1) to
|
||||||
|
deploy locally-compiled binaries onto **Kubernetes**/**OpenShift**
|
||||||
|
using only command-line (**Kubernetes/GoLang** used for this and three below).
|
||||||
|
- Implemented ability for Kubernetes operator to fetch data
|
||||||
|
from a deployed service and update config with data to
|
||||||
|
deprecate reliance on startup script.
|
||||||
|
- Added startup probes to handle starting legacy application containers that require additional startup time.
|
||||||
|
- Refactored probes to [have default values](https://github.com/apache/incubator-kie-kogito-operator/commit/af4977af228ec8648be28779259d4552246b656f) assigned based on
|
||||||
|
deployed YAML while also fixing reconciliation issues.
|
||||||
|
- Rewrote the **Jenkins (Groovy)** [nightly pipeline](https://github.com/apache/incubator-kie-kogito-pipelines/commit/4c83f1aecdea2c1ba2796b79839a90d4083dce88) to run in a GitHub
|
||||||
|
PR using a trigger keyword to test all the team's submitted PR's
|
||||||
|
before merging to the main branch.
|
||||||
|
- Took on tasks and contributed ideas in **Agile sprint** planning meetings in a team of 12 people.
|
||||||
|
- Took initiative to write [file](https://github.com/apache/incubator-kie-kogito-pipelines/commit/4c83f1aecdea2c1ba2796b79839a90d4083dce88#diff-7d2c018dafbccec859077d19bf1ade53ec9c7649f235528ce89f5632b109f7e6)
|
||||||
|
to define the GitHub parameters for the above pipeline so that it
|
||||||
|
can be recreated easily.
|
||||||
|
- Took initiative to write [documentation](https://github.com/apache/incubator-kie-kogito-operator/blob/1534c03d1d26bec08a16608a775782bf8b305de9/docs/GUIDE_FOR_KOGITO_DEVS.md) on how to get started with the project to onboard new
|
||||||
|
developers and mentored the incoming intern.
|
||||||
|
|
||||||
|
<!--- }}} Red Hat -->
|
||||||
|
|
||||||
|
<!--- Rarity Surf {{{ -->
|
||||||
|
|
||||||
|
{{% resume/project name="Rarity Surf"
|
||||||
|
languages="Python, JavaScript, React, Django"
|
||||||
|
date="Oct 2021" show="true" %}}
|
||||||
|
|
||||||
|
- **Developed a full-stack web application** to generate rarity
|
||||||
|
rankings for NFT's integrated with OpenSea's API,
|
||||||
|
enabling users to **quickly identify rare NFT's** and check
|
||||||
|
their listing status, **improving market research efficiency by 80%**.
|
||||||
|
- **Reverse engineered a proprietary ranking algorithm** to
|
||||||
|
mirror the leading rarity ranking site’s results,
|
||||||
|
**achieving 99.75% accuracy** by
|
||||||
|
utilizing data scraping techniques [with Selenium](https://github.com/Kevin-Mok/rarity-surf/blob/django/rarity_check/project/scrape.py),
|
||||||
|
increasing the platform's trustworthiness among users.
|
||||||
|
- **Optimized purchasing strategy** by leveraging the app to
|
||||||
|
frontrun competitors in purchasing top 0.5% rarity NFTs,
|
||||||
|
**boosting acquisition success rate by 90%** and allowing
|
||||||
|
users to gain a competitive edge in the marketplace.
|
||||||
|
- **Architected a robust Django (Python) [backend](https://github.com/Kevin-Mok/rarity-surf)** to fetch and process
|
||||||
|
NFT metadata from IPFS, store rarity rankings in
|
||||||
|
**PostgreSQL**, and serve the data via GraphQL API, **ensuring low-latency access and scaling to handle 2,000+ concurrent requests**.
|
||||||
|
- **Developed a dynamic React [frontend](https://github.com/Kevin-Mok/rarity-surf-frontend)** using hooks to load
|
||||||
|
rarity data in real-time, styled with Tailwind for
|
||||||
|
mobile responsiveness, **improving user experience
|
||||||
|
and reducing frontend load times by 70%**.
|
||||||
|
|
||||||
|
{{% /resume/project %}}
|
||||||
|
|
||||||
|
<!--- Rarity Surf }}} -->
|
||||||
|
|
||||||
|
<!--- Rarity Surf {{{ -->
|
||||||
|
|
||||||
|
{{% resume/project name="Rarity Surf (2)"
|
||||||
|
languages="Typescript, Node.js, React"
|
||||||
|
date="" show="true" %}}
|
||||||
|
|
||||||
|
- **Developed a full-stack web application** to generate
|
||||||
|
rarity rankings for NFT's, integrating with **leading
|
||||||
|
marketplace’s API** to enable users to quickly identify
|
||||||
|
rare NFT's and check their listing status, **improving
|
||||||
|
market research efficiency by 80%**.
|
||||||
|
- **Built a scalable Node.js backend** with REST API
|
||||||
|
endpoints to return NFTs based on customizable filters
|
||||||
|
such as max rank, price, and rarest traits. **Optimized
|
||||||
|
performance** to handle **3,000+ concurrent requests** by
|
||||||
|
implementing efficient data fetching and caching
|
||||||
|
mechanisms, ensuring low-latency access to NFT data.
|
||||||
|
- **Developed a dynamic React frontend** to load and display
|
||||||
|
NFT's in real-time based on user-defined filters to
|
||||||
|
streamline browsing. Styled the interface using **Tailwind
|
||||||
|
CSS** for a responsive and modern design, **reducing
|
||||||
|
frontend load times by 50%**.
|
||||||
|
- **Developed a Discord bot** to notify users of profitable
|
||||||
|
resale opportunities by leveraging historical sales data
|
||||||
|
to assess deal quality. This feature **increased user
|
||||||
|
engagement by 80%** and provided a seamless way for users
|
||||||
|
to stay updated on market opportunities.
|
||||||
|
- Designed and implemented a **PostgreSQL schema** for to
|
||||||
|
efficiently store NFT data, including metadata, rarity
|
||||||
|
scores, and historical sales data.
|
||||||
|
|
||||||
|
{{% /resume/project %}}
|
||||||
|
|
||||||
|
<!--- Rarity Surf }}} -->
|
||||||
|
|
||||||
|
<!--- Astronofty {{{ -->
|
||||||
|
|
||||||
|
{{% resume/project name="Astronofty"
|
||||||
|
url="https://github.com/Kevin-Mok/astronofty" languages="JavaScript, React, Solidity" date="Jan 2023"
|
||||||
|
show="true" %}}
|
||||||
|
|
||||||
|
- Created for a 36 hour hackathon (UofTHacks X) where it [**came 2nd overall**](https://devpost.com/software/astronofty).
|
||||||
|
- Created and deployed a smart contract with **Solidity** on
|
||||||
|
the Ethereum blockchain to create/buy/sell NFT's.
|
||||||
|
- Wrote **React** [components](https://github.com/Kevin-Mok/astronofty/tree/main/src/components) to synchronously upload images and metadata to IPFS and fetch and show NFT's.
|
||||||
|
|
||||||
|
{{% /resume/project %}}
|
||||||
|
|
||||||
|
<!--- Astronofty }}} -->
|
||||||
|
|
||||||
|
<!--- AWS {{{ -->
|
||||||
|
|
||||||
|
{{% resume/project name="AWS Server"
|
||||||
|
url="https://kevin-mok.com/server/" languages="AWS, Kubernetes, Docker, Terraform" date="May 2024" show="true" %}}
|
||||||
|
|
||||||
|
- Deployed [various web apps](https://kevin-mok.com/server/) using **Docker** (Compose) on an
|
||||||
|
**AWS EC2** Debian/**Linux** server.
|
||||||
|
- Created **Kubernetes** [manifest files](https://github.com/Kevin-Mok/aws-minicube) to quickly recreate my server setup
|
||||||
|
with persistent storage/restarts and open ports.
|
||||||
|
- Created **Terraform** [files](https://github.com/Kevin-Mok/terraform-deploys/tree/main)
|
||||||
|
to deploy an AWS EC2 instance and Docker containers.
|
||||||
|
- Used Amazon Route 53's DNS and **NGINX** to route
|
||||||
|
subdomains to each web application.
|
||||||
|
- Wrote a **JavaScript** [server script] and [systemd service][systemd service]/[timer]
|
||||||
|
to display the uptime of my pages every hour.
|
||||||
|
|
||||||
|
[server script]: https://git.kevin-mok.com/Kevin-Mok/server-pages/src/branch/master/server-status.js
|
||||||
|
[systemd service]: https://git.kevin-mok.com/Kevin-Mok/server-pages/src/branch/master/server-pages.service
|
||||||
|
[timer]: https://git.kevin-mok.com/Kevin-Mok/server-pages/src/branch/master/server-pages.timer
|
||||||
|
|
||||||
|
{{% /resume/project %}}
|
||||||
|
|
||||||
|
<!--- AWS }}} -->
|
||||||
|
|
||||||
|
<!--- AWS 2 {{{ -->
|
||||||
|
|
||||||
|
{{% resume/project name="AWS Server"
|
||||||
|
url="https://kevin-mok.com/server/" languages="AWS, Kubernetes, Docker, Terraform" date="May 2024" show="true" %}}
|
||||||
|
|
||||||
|
- **Deployed and maintained multiple web applications**
|
||||||
|
using **Docker Compose** on **AWS EC2 Debian/Linux servers**,
|
||||||
|
ensuring consistent environments for applications handling
|
||||||
|
**over 2,000+ monthly requests**.
|
||||||
|
- **Streamlined infrastructure management** by creating
|
||||||
|
Kubernetes manifest files to easily recreate server setups
|
||||||
|
with persistent storage, automatic restarts, and open
|
||||||
|
ports, **reducing the need for manual configuration**.
|
||||||
|
- **Automated AWS infrastructure provisioning** by writing
|
||||||
|
**Terraform** files to deploy **EC2** instances and Docker
|
||||||
|
containers, **accelerating deployment times by 80%** and
|
||||||
|
providing an easily reproducible infrastructure setup for
|
||||||
|
future projects.
|
||||||
|
- Improved web application accessibility and scalability by
|
||||||
|
configuring Amazon Route 53’s DNS and NGINX to route
|
||||||
|
subdomains to individual web apps, enabling seamless
|
||||||
|
navigation between apps and reducing DNS resolution times
|
||||||
|
by 25%.
|
||||||
|
- Built a robust uptime monitoring system by writing a
|
||||||
|
JavaScript server script and setting up a systemd
|
||||||
|
service/timer to check and display page uptime every hour,
|
||||||
|
ensuring near real-time monitoring and reducing downtime
|
||||||
|
detection time by 85%.
|
||||||
|
|
||||||
|
{{% /resume/project %}}
|
||||||
|
|
||||||
|
<!--- AWS 2 }}} -->
|
||||||
|
|
||||||
|
<!--- AWS 3 {{{ -->
|
||||||
|
|
||||||
|
{{% resume/project name="AWS Server"
|
||||||
|
url="https://kevin-mok.com/server/" languages="AWS, Kubernetes, Docker, Terraform" date="May 2024" show="true" %}}
|
||||||
|
|
||||||
|
- **Deployed and maintained multiple web applications**
|
||||||
|
using **Docker Compose** on **AWS EC2 Debian/Linux servers**,
|
||||||
|
ensuring consistent environments for applications handling
|
||||||
|
**over 2,000+ monthly requests**.
|
||||||
|
- **Automated AWS infrastructure provisioning** by writing
|
||||||
|
**Terraform** files to deploy AWS EC2 instances and Docker
|
||||||
|
containers, **accelerating deployment times by 80%** and
|
||||||
|
providing an easily reproducible infrastructure setup.
|
||||||
|
|
||||||
|
{{% /resume/project %}}
|
||||||
|
|
||||||
|
<!--- AWS 3 }}} -->
|
||||||
|
|
||||||
|
<!--- Astronofty (extended) {{{ -->
|
||||||
|
|
||||||
|
{{% resume/project name="Astronofty"
|
||||||
|
url="https://github.com/Kevin-Mok/astronofty" languages="JavaScript, React, Solidity" date="Jan 2023"
|
||||||
|
show="true" %}}
|
||||||
|
|
||||||
|
- **Secured [2nd place](https://devpost.com/software/astronofty) overall out of 150+ teams** at UofTHacks
|
||||||
|
X, a 36-hour hackathon, for developing a blockchain-based
|
||||||
|
NFT marketplace app.
|
||||||
|
- **Built and optimized React (JavaScript) [components](https://github.com/Kevin-Mok/astronofty/tree/main/src/components)** to synchronously
|
||||||
|
upload images and metadata to IPFS, **enhancing user engagement by 40%** during the demo,
|
||||||
|
and ensuring real-time NFT data retrieval, achieving a **75% improvement in loading times**.
|
||||||
|
|
||||||
|
{{% /resume/project %}}
|
||||||
|
|
||||||
|
<!--- Astronofty }}} -->
|
||||||
|
|
||||||
|
<!--- {{{ Spotify Graphs -->
|
||||||
|
|
||||||
|
{{% resume/project name="Spotify Graphs"
|
||||||
|
url="https://github.com/Kevin-Mok/spotify-lib-vis" date="June 2020 "
|
||||||
|
languages="Python, Django, PostgreSQL"
|
||||||
|
show="true" %}}
|
||||||
|
|
||||||
|
- Web app to visualize user's library and listening
|
||||||
|
history from Spotify.
|
||||||
|
- [Fetched and organized](https://github.com/Kevin-Mok/spotify-lib-vis/blob/master/api/utils.py) user data from Spotify API into PostgreSQL database with **Django (Python)** backend.
|
||||||
|
- Created and tested various relational database schemas to maximize
|
||||||
|
efficiency for use cases.
|
||||||
|
- Generated various charts to visualize the artists and genres
|
||||||
|
of tracks in library.
|
||||||
|
|
||||||
|
{{% /resume/project %}}
|
||||||
|
|
||||||
|
<!--- Spotify Graphs }}} -->
|
||||||
|
|
||||||
|
<!--- Grocery Finder {{{ -->
|
||||||
|
|
||||||
|
{{% resume/project name="Grocery Finder"
|
||||||
|
url="https://github.com/Kevin-Mok/grocery-finder" date="Feb. 2019 — Apr. 2019"
|
||||||
|
show="true" %}}
|
||||||
|
|
||||||
|
- Proof of concept for web app that finds the ideal supermarket based on your cart.
|
||||||
|
- Designed responsive front-end layout using **Bootstrap**.
|
||||||
|
- Implemented REST API functionality on backend using **Node.js** and
|
||||||
|
**MongoDB**.
|
||||||
|
- Setup deployment on [**Heroku**][Grocery Finder Heroku].
|
||||||
|
- Led team of 4 as project leader to prioritize and delegate tasks while
|
||||||
|
also implementing a majority of the core features.
|
||||||
|
- Performed code review for team members' pull requests.
|
||||||
|
|
||||||
|
[Grocery Finder Heroku]: http://www.grocery-finder.ml
|
||||||
|
|
||||||
|
{{% /resume/project %}}
|
||||||
|
|
||||||
|
<!--- Grocery Finder }}} -->
|
||||||
|
|
||||||
|
<!--- CSC369 {{{ -->
|
||||||
|
|
||||||
|
{{% resume/project name="Custom Kernel Module"
|
||||||
|
url="https://kevin-mok.com/server/" date="Jan. 2022" show="true" %}}
|
||||||
|
|
||||||
|
- Wrote and installed a [custom Linux kernel module](https://github.com/Kevin-Mok/interceptor-kernel/blob/master/a1/interceptor.c) in **C**.
|
||||||
|
- Intercepted pre-existing system calls using
|
||||||
|
custom kernel module by sending commands to
|
||||||
|
userspace.
|
||||||
|
- Monitored specific process ID's in my system
|
||||||
|
call to intercept their system calls.
|
||||||
|
|
||||||
|
{{% /resume/project %}}
|
||||||
|
|
||||||
|
<!--- CSC369 }}} -->
|
||||||
|
|
||||||
|
<!--- ParsaFood {{{ -->
|
||||||
|
|
||||||
|
{{% resume/project name="ParsaFood"
|
||||||
|
url="https://github.com/Kevin-Mok/ParsaFood" date="Feb. 2018"
|
||||||
|
show="true" %}}
|
||||||
|
|
||||||
|
- **Android** app that reads ingredient labels and detects any dietary
|
||||||
|
restrictions/allergies.
|
||||||
|
- Designed user interface and linked various functionality together.
|
||||||
|
- Made during a 24-hour [food-themed hackathon][Platterz Hackathon event]
|
||||||
|
in a group with two other members. Came in 2<sup>nd</sup> place and won
|
||||||
|
an [Oculus Rift][Oculus Rift Amazon].
|
||||||
|
|
||||||
|
[Parsafood repo]: https://github.com/Kevin-Mok/ParsaFood
|
||||||
|
[Platterz Hackathon event]:
|
||||||
|
https://www.eventbrite.com/e/platterz-hackathon-tickets-42682237722
|
||||||
|
[Oculus Rift Amazon]: https://www.amazon.ca/Oculus-Rift-Windows-VR-Headset/dp/B00VF0IXEY/ref=sr_1_1_sspa?ie=UTF8&qid=1520422949&sr=8-1-spons&keywords=oculus+rift&psc=1
|
||||||
|
|
||||||
|
{{% /resume/project %}}
|
||||||
|
|
||||||
|
<!--- ParsaFood }}} -->
|
||||||
|
|
||||||
|
<!--- DigitalOcean {{{ -->
|
||||||
|
|
||||||
|
{{% resume/project name="Personal Server"
|
||||||
|
url="https://kevin-mok.com/server/" date="Aug. 2019 — present" %}}
|
||||||
|
|
||||||
|
- Deployed various web apps with backends such as Node, PHP and Python using
|
||||||
|
**NGINX** on a **Debian** server.
|
||||||
|
- Monitor system resources and perform system maintenance using tmux.
|
||||||
|
- Wrote [**Node.js** script][server script] and [**systemd** service][systemd service]/[timer]
|
||||||
|
to check and display the uptime of my pages every hour.
|
||||||
|
|
||||||
|
[server script]: https://git.kevin-mok.com/Kevin-Mok/server-pages/src/branch/master/server-status.js
|
||||||
|
[systemd service]: https://git.kevin-mok.com/Kevin-Mok/server-pages/src/branch/master/server-pages.service
|
||||||
|
[timer]: https://git.kevin-mok.com/Kevin-Mok/server-pages/src/branch/master/server-pages.timer
|
||||||
|
|
||||||
|
{{% /resume/project %}}
|
||||||
|
|
||||||
|
<!--- DigitalOcean Droplet }}} -->
|
||||||
|
|
||||||
@@ -1,99 +0,0 @@
|
|||||||
<!--- CSC369 {{{ -->
|
|
||||||
|
|
||||||
{{% resume/project name="Operating Systems Course"
|
|
||||||
url="https://kevin-mok.com/server/" date="Jan. 2022" show="true" %}}
|
|
||||||
|
|
||||||
- Wrote and installed a [custom Linux kernel module](https://github.com/Kevin-Mok/interceptor-kernel/blob/master/a1/interceptor.c) in **C**.
|
|
||||||
- Intercepted pre-existing system calls using
|
|
||||||
custom kernel module by sending commands to
|
|
||||||
userspace.
|
|
||||||
- Monitored specific process ID's in my system
|
|
||||||
call to intercept their system calls.
|
|
||||||
- Used mutex locks for [thread synchronization](https://github.com/Kevin-Mok/thread-synchronization) in **C**.
|
|
||||||
|
|
||||||
{{% /resume/project %}}
|
|
||||||
|
|
||||||
<!--- CSC369 }}} -->
|
|
||||||
|
|
||||||
<!--- Spotify Graphs {{{ -->
|
|
||||||
|
|
||||||
{{% resume/project name="Spotify Graphs"
|
|
||||||
url="https://github.com/Kevin-Mok/spotify-lib-vis" date="June 2018 — July 2018"
|
|
||||||
show="true" %}}
|
|
||||||
|
|
||||||
- Implemented base functionality of scanning tracks and listening
|
|
||||||
history from user's library using Spotify API and organized data
|
|
||||||
into **PostgreSQL** database with **Django** backend.
|
|
||||||
- Created and tested various relational database schemas to maximize
|
|
||||||
efficiency for use cases.
|
|
||||||
- Produced bubble chart and (stacked) bar chart using [**d3**]
|
|
||||||
[d3 graph examples] to visualize the artists, genres and features of
|
|
||||||
tracks in library.
|
|
||||||
|
|
||||||
[d3 graph examples]: https://github.com/d3/d3/wiki/Gallery
|
|
||||||
|
|
||||||
{{% /resume/project %}}
|
|
||||||
|
|
||||||
<!--- Spotify Graphs }}} -->
|
|
||||||
|
|
||||||
<!--- Grocery Finder {{{ -->
|
|
||||||
|
|
||||||
{{% resume/project name="Grocery Finder"
|
|
||||||
url="https://github.com/Kevin-Mok/grocery-finder" date="Feb. 2019 — Apr. 2019"
|
|
||||||
show="true" %}}
|
|
||||||
|
|
||||||
- Proof of concept for web app that finds the ideal supermarket based on your cart.
|
|
||||||
- Designed responsive front-end layout using **Bootstrap**.
|
|
||||||
- Implemented REST API functionality on backend using **Node.js** and
|
|
||||||
**MongoDB**.
|
|
||||||
- Setup deployment on [**Heroku**][Grocery Finder Heroku].
|
|
||||||
- Led team of 4 as project leader to prioritize and delegate tasks while
|
|
||||||
also implementing a majority of the core features.
|
|
||||||
- Performed code review for team members' pull requests.
|
|
||||||
|
|
||||||
[Grocery Finder Heroku]: http://www.grocery-finder.ml
|
|
||||||
|
|
||||||
{{% /resume/project %}}
|
|
||||||
|
|
||||||
<!--- Grocery Finder }}} -->
|
|
||||||
|
|
||||||
<!--- DigitalOcean {{{ -->
|
|
||||||
|
|
||||||
{{% resume/project name="Personal Server"
|
|
||||||
url="https://kevin-mok.com/server/" date="Aug. 2019 — present" %}}
|
|
||||||
|
|
||||||
- Deployed various web apps with backends such as Node, PHP and Python using
|
|
||||||
**NGINX** on a **Debian** server.
|
|
||||||
- Monitor system resources and perform system maintenance using tmux.
|
|
||||||
- Wrote [**Node.js** script][server script] and [**systemd** service][systemd service]/[timer]
|
|
||||||
to check and display the uptime of my pages every hour.
|
|
||||||
|
|
||||||
[server script]: https://git.kevin-mok.com/Kevin-Mok/server-pages/src/branch/master/server-status.js
|
|
||||||
[systemd service]: https://git.kevin-mok.com/Kevin-Mok/server-pages/src/branch/master/server-pages.service
|
|
||||||
[timer]: https://git.kevin-mok.com/Kevin-Mok/server-pages/src/branch/master/server-pages.timer
|
|
||||||
|
|
||||||
{{% /resume/project %}}
|
|
||||||
|
|
||||||
<!--- DigitalOcean Droplet }}} -->
|
|
||||||
|
|
||||||
<!--- ParsaFood {{{ -->
|
|
||||||
|
|
||||||
{{% resume/project name="ParsaFood"
|
|
||||||
url="https://github.com/Kevin-Mok/ParsaFood" date="Feb. 2018"
|
|
||||||
show="true" %}}
|
|
||||||
|
|
||||||
- **Android** app that reads ingredient labels and detects any dietary
|
|
||||||
restrictions/allergies.
|
|
||||||
- Designed user interface and linked various functionality together.
|
|
||||||
- Made during a 24-hour [food-themed hackathon][Platterz Hackathon event]
|
|
||||||
in a group with two other members. Came in 2<sup>nd</sup> place and won
|
|
||||||
an [Oculus Rift][Oculus Rift Amazon].
|
|
||||||
|
|
||||||
[Parsafood repo]: https://github.com/Kevin-Mok/ParsaFood
|
|
||||||
[Platterz Hackathon event]:
|
|
||||||
https://www.eventbrite.com/e/platterz-hackathon-tickets-42682237722
|
|
||||||
[Oculus Rift Amazon]: https://www.amazon.ca/Oculus-Rift-Windows-VR-Headset/dp/B00VF0IXEY/ref=sr_1_1_sspa?ie=UTF8&qid=1520422949&sr=8-1-spons&keywords=oculus+rift&psc=1
|
|
||||||
|
|
||||||
{{% /resume/project %}}
|
|
||||||
|
|
||||||
<!--- ParsaFood }}} -->
|
|
||||||
23
content/resume/points-plain-text.md
Normal file
23
content/resume/points-plain-text.md
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
# Red Hat
|
||||||
|
1. Reduced deployment time by 66% by implementing ability to deploy locally-compiled binaries onto Kubernetes/OpenShift using only command-line (Kubernetes/GoLang used for this and three below).
|
||||||
|
2. Implemented ability for Kubernetes operator to fetch data from a deployed service and update config with data to deprecate reliance on startup script.
|
||||||
|
3. Added startup probes to handle starting legacy application containers that require additional startup time.
|
||||||
|
4. Refactored probes to have default values assigned based on deployed YAML while also fixing reconciliation issues.
|
||||||
|
5. Rewrote the Jenkins (Groovy) nightly pipeline to run in a GitHub PR using a trigger keyword to test all the team’s submitted PR’s before merging to the main branch.
|
||||||
|
6. Took on tasks and contributed ideas in Agile sprint planning meetings in a team of 12 people.
|
||||||
|
7. Took initiative to write file to define the GitHub parameters for the above pipeline so that it can be recreated easily.
|
||||||
|
8. Took initiative to write documentation on how to get started with the project to onboard new developers and mentored the incoming intern.
|
||||||
|
|
||||||
|
# Rarity Surf
|
||||||
|
1. Web app to give rarity rankings to NFT’s and check which are listed on the OpenSea marketplace using their API.
|
||||||
|
2. Reverse engineered the ranking algorithm to match the leading rarity ranking site’s rankings (scraped using Selenium) with a discrepancy of <0.25%.
|
||||||
|
3. Used app to frontrun purchases of top 0.5% rarity NFT’s against competing buyers.
|
||||||
|
4. Wrote Django (Python) backend to fetch metadata from IPFS, store rarity rankings in PostgreSQL and serve rarity data using GraphQL.
|
||||||
|
5. Wrote React frontend with hooks to dynamically load rarity data. Styled with Tailwind.
|
||||||
|
|
||||||
|
# AWS
|
||||||
|
1. Deployed various web apps using Docker (Compose) on an AWS EC2 Debian/Linux server.
|
||||||
|
2. Created Kubernetes manifest files to quickly recreate my server setup with persistent storage/restarts and open ports.
|
||||||
|
3. Created Terraform files to deploy an AWS EC2 instance and Docker containers.
|
||||||
|
4. Used Amazon Route 53’s DNS and NGINX to route subdomains to each web application.
|
||||||
|
5. Wrote a JavaScript server script and systemd service/timer to display the uptime of my pages every hour.
|
||||||
@@ -4,5 +4,5 @@ AWS, Kubernetes, Terraform, Docker (Compose), Jenkins, Groovy, Go(Lang), Bash, *
|
|||||||
# Web Dev
|
# Web Dev
|
||||||
**JavaScript**, **React**, **Python**, **Django**, Node.js, PostgreSQL, MongoDB, Bash, **Git**, **Linux**, **Command Line**, Go(Lang), AWS, Kubernetes, Terraform, Docker (Compose), Jenkins, Groovy, Solidity, C
|
**JavaScript**, **React**, **Python**, **Django**, Node.js, PostgreSQL, MongoDB, Bash, **Git**, **Linux**, **Command Line**, Go(Lang), AWS, Kubernetes, Terraform, Docker (Compose), Jenkins, Groovy, Solidity, C
|
||||||
|
|
||||||
# C
|
# Python
|
||||||
**Python**, **C**, PostgreSQL, AWS, Kubernetes, Terraform, Docker (Compose), Jenkins, Groovy, Go(Lang), Bash, **Linux**, **JavaScript**, **React**, **Python**, **Django**, Node.js, MongoDB, Solidity, **Git**, **Command Line**
|
**Python**, **Django**, **Linux**, **Git**, AWS, Kubernetes, Docker (Compose), Ansible, Jenkins, Selenium, Terraform, Go(Lang), PostgreSQL, **Command Line**, Groovy, Bash, **JavaScript**, **React**, Node.js, MongoDB, Solidity, C
|
||||||
|
|||||||
@@ -6,7 +6,6 @@
|
|||||||
|
|
||||||
<footer>
|
<footer>
|
||||||
<div class="container">
|
<div class="container">
|
||||||
<!-- <span class="copyright">© {{ .Site.LastChange.Year }} {{ .Site.Title }} - <a rel="license" href="http://creativecommons.org/licenses/by/4.0/">CC BY 4.0</a></span> -->
|
|
||||||
<div id="footer-row" class="row justify-content-center">
|
<div id="footer-row" class="row justify-content-center">
|
||||||
<span id="footer-content" class="name">
|
<span id="footer-content" class="name">
|
||||||
<span id="copyright" class="col-xs-6">
|
<span id="copyright" class="col-xs-6">
|
||||||
|
|||||||
@@ -24,6 +24,7 @@
|
|||||||
<link rel="stylesheet" type="text/css"
|
<link rel="stylesheet" type="text/css"
|
||||||
href="https://cdn.jsdelivr.net/gh/dreampulse/computer-modern-web-font@master/fonts.css">
|
href="https://cdn.jsdelivr.net/gh/dreampulse/computer-modern-web-font@master/fonts.css">
|
||||||
<link rel="stylesheet" href="{{ "css/style.css" | relURL }}" type="text/css">
|
<link rel="stylesheet" href="{{ "css/style.css" | relURL }}" type="text/css">
|
||||||
|
<link rel="stylesheet" href="{{ "css/print.css" | relURL }}" media="print">
|
||||||
{{ $main_sass := resources.Get "sass/main.scss" }}
|
{{ $main_sass := resources.Get "sass/main.scss" }}
|
||||||
{{ $main_style := $main_sass | resources.ToCSS }}
|
{{ $main_style := $main_sass | resources.ToCSS }}
|
||||||
<link rel="stylesheet" href="{{ $main_style.RelPermalink }}" type="text/css">
|
<link rel="stylesheet" href="{{ $main_style.RelPermalink }}" type="text/css">
|
||||||
|
|||||||
@@ -2,9 +2,8 @@
|
|||||||
<div class="row project-header">
|
<div class="row project-header">
|
||||||
<div class="col-8 text-left">
|
<div class="col-8 text-left">
|
||||||
<h2 class="project-title">
|
<h2 class="project-title">
|
||||||
{{ .Get "name" }}
|
{{ .Get "name" }} <span class="languages"><{{ .Get "languages" }}></span>
|
||||||
</h2>
|
</h2>
|
||||||
<span><{{ .Get "languages" }}></span>
|
|
||||||
</div>
|
</div>
|
||||||
<div class="col-4 text-right date">{{ .Get "date" }}</div>
|
<div class="col-4 text-right date">{{ .Get "date" }}</div>
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
@@ -1,10 +1,5 @@
|
|||||||
<div class="references">
|
<div class="references">
|
||||||
<span>
|
<span>
|
||||||
See my LinkedIn for
|
Referred to job by Stephanie Te (stephanie.te@verisk.com).
|
||||||
<a href="https://www.linkedin.com/in/kev-mok/details/recommendations/?detailScreenTabIndex=0"
|
|
||||||
target="_blank">
|
|
||||||
references</a> from my
|
|
||||||
Red Hat managers/mentee, a startup client and a graduate
|
|
||||||
student mentor.
|
|
||||||
</span>
|
</span>
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
71
static/css/print.css
Normal file
71
static/css/print.css
Normal file
@@ -0,0 +1,71 @@
|
|||||||
|
/* static/css/print.css */
|
||||||
|
@media print {
|
||||||
|
/* A little more vertical room on the page */
|
||||||
|
@page { size: A4; margin: 10mm 12mm; }
|
||||||
|
|
||||||
|
/* Make the whole resume slightly denser but readable */
|
||||||
|
.resume, body { font-size: 11pt; line-height: 1.25; }
|
||||||
|
|
||||||
|
/* === SKILLS SECTION FIXES === */
|
||||||
|
/* Stop clipping and let content wrap/flow */
|
||||||
|
.section--skills,
|
||||||
|
.resume .section--skills,
|
||||||
|
[data-section-title="Skills"] {
|
||||||
|
max-height: none !important;
|
||||||
|
overflow: visible !important;
|
||||||
|
break-inside: avoid-page;
|
||||||
|
page-break-inside: avoid;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* If the theme uses multi-columns for skills, collapse to 1 for print */
|
||||||
|
.section--skills ul,
|
||||||
|
[data-section-title="Skills"] ul {
|
||||||
|
columns: 1 !important;
|
||||||
|
-webkit-columns: 1 !important;
|
||||||
|
column-gap: 0 !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Ensure list items/tags wrap cleanly and never get cut off */
|
||||||
|
.section--skills li,
|
||||||
|
[data-section-title="Skills"] li,
|
||||||
|
.section--skills .tag,
|
||||||
|
.section--skills .tags .tag {
|
||||||
|
white-space: normal !important;
|
||||||
|
word-break: normal;
|
||||||
|
overflow-wrap: anywhere;
|
||||||
|
break-inside: avoid;
|
||||||
|
margin-bottom: 1.5mm;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Tighten vertical padding in sections to gain a line or two */
|
||||||
|
|
||||||
|
|
||||||
|
/* Micro-tighten text to save ~1 line */
|
||||||
|
.resume, body {
|
||||||
|
font-size: 11pt;
|
||||||
|
line-height: 1.22; /* was 1.25 */
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Reduce space around lists */
|
||||||
|
.resume ul { margin-top: 0 !important; margin-bottom: 1.5mm !important; }
|
||||||
|
.resume li { margin-bottom: 1mm !important; }
|
||||||
|
|
||||||
|
/* Optional: shrink Skills section a touch more */
|
||||||
|
.section--skills li { margin-bottom: 1mm !important; }
|
||||||
|
.resume .section { padding-top: 3mm !important; padding-bottom: 3mm !important; }
|
||||||
|
|
||||||
|
/*@media print {*/
|
||||||
|
/*@page { size: A4; margin: 11.75mm 12mm; } [> was 10mm 12mm <]*/
|
||||||
|
/*}*/
|
||||||
|
|
||||||
|
@media print {
|
||||||
|
/* fit-to-one-page nudges */
|
||||||
|
@page { size: A4; margin: 9mm 10mm; } /* was ~10–12mm */
|
||||||
|
.resume, body { font-size: 10.75pt; line-height: 1.22; } /* was 11pt / 1.25 */
|
||||||
|
|
||||||
|
/* tighten vertical whitespace */
|
||||||
|
h2, h3 { margin-top: 6px; margin-bottom: 4px; }
|
||||||
|
.resume li { margin-bottom: 2px; } /* list spacing */
|
||||||
|
.resume section { margin-top: 8px; } /* section gap */
|
||||||
|
}
|
||||||
|
}
|
||||||
Submodule static/pdf updated: a0d59bda6c...6d0677da34
Reference in New Issue
Block a user