Compare commits
21 Commits
resume-pdf
...
server
| Author | SHA1 | Date | |
|---|---|---|---|
| 6e5ad11eb7 | |||
| 4d29261b3c | |||
| b7a493c8c9 | |||
| 275c5b679b | |||
| 161cc14764 | |||
| 49cda38430 | |||
| c3f43c408d | |||
| 35ca126618 | |||
| a61b6e2761 | |||
| 20a120e33e | |||
| e3c8fee6e8 | |||
| 68a7866b18 | |||
| 30e8771472 | |||
| a06054f737 | |||
| 4a55c02468 | |||
| 8101b4dbfa | |||
| f0056972e3 | |||
| d0a21e8b36 | |||
| 24b999b2f2 | |||
| 67ecb5ddb5 | |||
| 12f0be4536 |
@@ -103,12 +103,19 @@ body {
|
|||||||
margin: 0;
|
margin: 0;
|
||||||
background-color: $background-color;
|
background-color: $background-color;
|
||||||
color: $color;
|
color: $color;
|
||||||
line-height: 1.5;
|
// line-height: 1.5;
|
||||||
|
line-height: 1.57;
|
||||||
// font-size: 100%;
|
// font-size: 100%;
|
||||||
// font-size: 15px;
|
// font-size: 15px;
|
||||||
font-size: 20px;
|
font-size: 17px;
|
||||||
|
// font-size: 20px;
|
||||||
|
// font-size: 22px;
|
||||||
/* font-family: 'Source Code Pro', monospace; */
|
/* font-family: 'Source Code Pro', monospace; */
|
||||||
font-family: 'Hack', monospace;
|
// font-family: 'Hack', monospace;
|
||||||
|
// body {
|
||||||
|
// font-family: 'Times New Roman', serif;
|
||||||
|
font-family: "Computer Modern Serif";
|
||||||
|
// }
|
||||||
display: flex;
|
display: flex;
|
||||||
flex-direction: column;
|
flex-direction: column;
|
||||||
min-height: 100vh;
|
min-height: 100vh;
|
||||||
@@ -170,7 +177,8 @@ footer {
|
|||||||
margin-top: 2rem;
|
margin-top: 2rem;
|
||||||
$vertical-margin: .2em;
|
$vertical-margin: .2em;
|
||||||
text-align: center;
|
text-align: center;
|
||||||
font-size: 0.8em;
|
// font-size: 0.8em;
|
||||||
|
font-size: .85em;
|
||||||
color: #747369;
|
color: #747369;
|
||||||
// bottom: 0;
|
// bottom: 0;
|
||||||
// position: absolute;
|
// position: absolute;
|
||||||
@@ -210,7 +218,8 @@ footer {
|
|||||||
// padding-right: .9em;
|
// padding-right: .9em;
|
||||||
|
|
||||||
img {
|
img {
|
||||||
height: 1.5em;
|
// height: 1.5em;
|
||||||
|
height: 3em;
|
||||||
@include vert-margin-rem(.2);
|
@include vert-margin-rem(.2);
|
||||||
padding-left: .5em;
|
padding-left: .5em;
|
||||||
opacity: .6;
|
opacity: .6;
|
||||||
@@ -368,7 +377,7 @@ header {// {{{
|
|||||||
display: inline;
|
display: inline;
|
||||||
|
|
||||||
&#gnu {
|
&#gnu {
|
||||||
background-color: $base04;
|
// background-color: $base04;
|
||||||
// background-color: $base05;
|
// background-color: $base05;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -491,7 +500,7 @@ header {// {{{
|
|||||||
#contact-info {// {{{
|
#contact-info {// {{{
|
||||||
@include side-margin-em(0);
|
@include side-margin-em(0);
|
||||||
// @include vert-padding-rem(0.5);
|
// @include vert-padding-rem(0.5);
|
||||||
@include a-color($base-sky-blue);
|
// @include a-color($base-sky-blue);
|
||||||
// min-width: $max-page-width;
|
// min-width: $max-page-width;
|
||||||
@media (min-width: 1200px) {
|
@media (min-width: 1200px) {
|
||||||
.container{
|
.container{
|
||||||
@@ -499,17 +508,20 @@ header {// {{{
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
a {// {{{
|
a {// {{{
|
||||||
|
color: #4287cd;
|
||||||
text-decoration: none;
|
text-decoration: none;
|
||||||
&:hover {
|
&:hover {
|
||||||
text-decoration: none;
|
text-decoration: none;
|
||||||
}
|
}
|
||||||
}// }}}
|
}// }}}
|
||||||
|
|
||||||
font-size: .9em;
|
// font-size: .9em;
|
||||||
|
font-size: .8em;
|
||||||
|
|
||||||
.row {
|
.row {
|
||||||
// flex-grow: 1;
|
// flex-grow: 1;
|
||||||
color: $base05;
|
// color: $base05;
|
||||||
|
color: #4287cd;
|
||||||
|
|
||||||
img {
|
img {
|
||||||
height: 1em;
|
height: 1em;
|
||||||
@@ -527,7 +539,9 @@ header {// {{{
|
|||||||
}
|
}
|
||||||
|
|
||||||
.url-info {
|
.url-info {
|
||||||
|
font-size: 1em;
|
||||||
margin-left: 5px;
|
margin-left: 5px;
|
||||||
|
// text-decoration: underline;
|
||||||
// position: relative;
|
// position: relative;
|
||||||
// left: -8px;
|
// left: -8px;
|
||||||
// @media (max-width: $phone-width) {
|
// @media (max-width: $phone-width) {
|
||||||
@@ -541,23 +555,32 @@ header {// {{{
|
|||||||
|
|
||||||
#resume {// {{{
|
#resume {// {{{
|
||||||
a {// {{{
|
a {// {{{
|
||||||
text-decoration: none;
|
// text-decoration: none;
|
||||||
|
// color: $base-blue;
|
||||||
|
color: #4287cd;
|
||||||
|
// color: blue;
|
||||||
|
text-decoration: underline;
|
||||||
&:hover {
|
&:hover {
|
||||||
text-decoration: underline;
|
text-decoration: underline;
|
||||||
}
|
}
|
||||||
}// }}}
|
}// }}}
|
||||||
|
|
||||||
h1 {// {{{
|
h1 {// {{{
|
||||||
color: $base-orange;
|
// color: $base-orange;
|
||||||
margin-top: 1.3rem;
|
color: black;
|
||||||
|
// margin-top: 1.3rem;
|
||||||
|
margin-top: 1rem;
|
||||||
|
// font-size: 1.2em;
|
||||||
|
font-size: 1.3em;
|
||||||
|
|
||||||
// @media (max-width: $phone-width) {
|
// @media (max-width: $phone-width) {
|
||||||
// margin-top: .75rem;
|
// margin-top: .75rem;
|
||||||
// }
|
// }
|
||||||
}// }}}
|
}// }}}
|
||||||
h2 {// {{{
|
h2 {// {{{
|
||||||
color: $base-orange;
|
//color: $base-orange;
|
||||||
margin-top: .5rem;
|
margin-top: .5rem;
|
||||||
|
font-size: 1em;
|
||||||
|
|
||||||
// @media (max-width: $phone-width) {
|
// @media (max-width: $phone-width) {
|
||||||
// font-size: 1.2em;
|
// font-size: 1.2em;
|
||||||
@@ -567,6 +590,7 @@ header {// {{{
|
|||||||
h4 {// {{{
|
h4 {// {{{
|
||||||
color: $base-yellow;
|
color: $base-yellow;
|
||||||
margin-top: .5rem;
|
margin-top: .5rem;
|
||||||
|
font-size: 1.2em;
|
||||||
|
|
||||||
// @media (max-width: $phone-width) {
|
// @media (max-width: $phone-width) {
|
||||||
// font-size: 1.2em;
|
// font-size: 1.2em;
|
||||||
@@ -583,6 +607,19 @@ header {// {{{
|
|||||||
// }
|
// }
|
||||||
}// }}}
|
}// }}}
|
||||||
|
|
||||||
|
.section-header {
|
||||||
|
margin-top: .7em;
|
||||||
|
margin-bottom: 0.4em;
|
||||||
|
}
|
||||||
|
|
||||||
|
ul {
|
||||||
|
margin-bottom: 5px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.work-experience {
|
||||||
|
margin-bottom: 5px;
|
||||||
|
}
|
||||||
|
|
||||||
#projects {// {{{
|
#projects {// {{{
|
||||||
// // h1 {
|
// // h1 {
|
||||||
// // margin-bottom: 3px;
|
// // margin-bottom: 3px;
|
||||||
@@ -594,6 +631,7 @@ header {// {{{
|
|||||||
h2 {
|
h2 {
|
||||||
color: $base-sky-blue;
|
color: $base-sky-blue;
|
||||||
display: inline;
|
display: inline;
|
||||||
|
font-size: 1.1em;
|
||||||
}
|
}
|
||||||
|
|
||||||
img {
|
img {
|
||||||
@@ -601,10 +639,21 @@ header {// {{{
|
|||||||
}
|
}
|
||||||
|
|
||||||
.project-header {
|
.project-header {
|
||||||
margin-bottom: .6em;
|
// margin-bottom: .6em;
|
||||||
|
// margin-bottom: .1em;
|
||||||
|
margin-bottom: 5px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.project-title {
|
||||||
|
// color: $base-blue;
|
||||||
|
color: black;
|
||||||
|
display: inline;
|
||||||
}
|
}
|
||||||
|
|
||||||
.project-link {
|
.project-link {
|
||||||
|
&:link {
|
||||||
|
text-decoration: none;
|
||||||
|
}
|
||||||
&:hover {
|
&:hover {
|
||||||
text-decoration: none;
|
text-decoration: none;
|
||||||
}
|
}
|
||||||
@@ -638,8 +687,37 @@ header {// {{{
|
|||||||
}
|
}
|
||||||
}// }}}
|
}// }}}
|
||||||
|
|
||||||
|
.company {
|
||||||
|
// color: #fe4646;
|
||||||
|
color: black;
|
||||||
|
font-weight: bold;
|
||||||
|
font-size: 1.2em;
|
||||||
|
margin-bottom: 5px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.position {
|
||||||
|
// color: black;
|
||||||
|
// color: $base-sky-blue;
|
||||||
|
// color: $base-blue;
|
||||||
|
color: black;
|
||||||
|
font-weight: bold;
|
||||||
|
// font-style: italic;
|
||||||
|
// font-size: 1.1em;
|
||||||
|
font-size: 1em;
|
||||||
|
// margin-bottom: 5px;
|
||||||
|
margin-bottom: 15px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.languages {
|
||||||
|
// font-style: italic;
|
||||||
|
// font-size: .9em;
|
||||||
|
}
|
||||||
|
|
||||||
.institution {
|
.institution {
|
||||||
color: $base-yellow;
|
// color: $base-yellow;
|
||||||
|
// color: $base-dark-orange;
|
||||||
|
// color: $base-blue;
|
||||||
|
color: black;
|
||||||
font-weight: bold;
|
font-weight: bold;
|
||||||
font-size: 1.1em;
|
font-size: 1.1em;
|
||||||
margin-bottom: 5px;
|
margin-bottom: 5px;
|
||||||
@@ -744,16 +822,22 @@ header {// {{{
|
|||||||
|
|
||||||
h1.site-title {// {{{
|
h1.site-title {// {{{
|
||||||
text-align: center;
|
text-align: center;
|
||||||
font-size: 4.2em;
|
// font-size: 4.2em;
|
||||||
|
// font-size: 3.2em;
|
||||||
|
font-size: 2.5em;
|
||||||
// color: #66cccc;
|
// color: #66cccc;
|
||||||
color: $base05;
|
color: $base05;
|
||||||
// margin-top: 1rem;
|
// margin-top: 1rem;
|
||||||
// margin-bottom: 0.75rem;
|
// margin-bottom: 0.75rem;
|
||||||
@include vert-margin-rem(.75);
|
@include vert-margin-rem(.75);
|
||||||
|
|
||||||
@include a-color($base-sky-blue);
|
// @include a-color($base-sky-blue);
|
||||||
a {
|
a {
|
||||||
text-decoration: none;
|
color: black;
|
||||||
|
// text-decoration: none;
|
||||||
|
text-decoration: underline;
|
||||||
|
text-decoration-thickness: 2px;
|
||||||
|
text-underline-offset: 5px;
|
||||||
}
|
}
|
||||||
|
|
||||||
// @media (max-width: $phone-width) {
|
// @media (max-width: $phone-width) {
|
||||||
@@ -919,7 +1003,8 @@ article.single section.body h5 { color: #515151; }
|
|||||||
article.single section.body h6 { color: #747369; }
|
article.single section.body h6 { color: #747369; }
|
||||||
|
|
||||||
// article.single section.body a,a:visited { color: #a06700; }
|
// article.single section.body a,a:visited { color: #a06700; }
|
||||||
article.single section.body a,a:visited { color: $base-sky-blue; }
|
// article.single section.body a,a:visited { color: $base-sky-blue; }
|
||||||
|
// article.single section.body a,a:visited { color: $base-sky-blue; }
|
||||||
|
|
||||||
/* Article Elements */
|
/* Article Elements */
|
||||||
|
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
baseURL: http://localhost:1313/
|
# baseURL: http://localhost:1313/
|
||||||
# baseURL: https://kevin-mok.com/
|
baseURL: https://kevin-mok.com/
|
||||||
# baseURL: /home/kevin/coding/mf-site/public
|
# baseURL: /home/kevin/coding/mf-site/public
|
||||||
languageCode: en-us
|
languageCode: en-us
|
||||||
# title: Kevin Mok's Website
|
# title: Kevin Mok's Website
|
||||||
|
|||||||
Submodule content/letter updated: 996ec6349b...1f7a5be6bc
@@ -3,165 +3,109 @@ title: "Resume"
|
|||||||
date: 2019-02-11T07:50:51-05:00
|
date: 2019-02-11T07:50:51-05:00
|
||||||
draft: false
|
draft: false
|
||||||
---
|
---
|
||||||
{{% resume/section skills %}}<!--- {{{ -->
|
{{% resume/section "Web Dev Projects" %}}<!--- {{{ -->
|
||||||
|
|
||||||
#### Languages
|
<!--- Rarity Surf {{{ -->
|
||||||
- **Bash**, **C**, **CSS**, C++, **Fish** (shell), Godot, **HTML5**,
|
|
||||||
**Python**, Java, **Javascript** (ES6), **Sass**
|
|
||||||
|
|
||||||
#### Frameworks
|
{{% resume/project name="Rarity Surf"
|
||||||
- **Bootstrap**, **Django**, **Node.js**, **PostgreSQL**
|
languages="TypeScript, JavaScript, Node.js, React"
|
||||||
|
date="March 2025" show="true" %}}
|
||||||
|
|
||||||
#### Services
|
- **Developed a full-stack web application
|
||||||
- **DigitalOcean**, **Linux**, Heroku, **REST/Web API's**
|
(TypeScript/JavaScript)** 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](https://github.com/Rarity-Surf/ME-sniper-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 using **PostgreSQL** , ensuring low-latency
|
||||||
|
access to NFT data.
|
||||||
|
- **Built a dynamic [React frontend](https://github.com/Rarity-Surf/ME-sniper-frontend) (TypeScript/JavaScript)** to load and display NFTs in real-time with user-defined filters. Styled
|
||||||
|
using a mobile-responsive library, **reducing load times by 50%**.
|
||||||
|
- **Developed a [Discord bot](https://github.com/Rarity-Surf/ME-sniper-discord-bot) (TypeScript/JavaScript/Node.js)** 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.
|
||||||
|
|
||||||
#### Tools
|
{{% /resume/project %}}
|
||||||
- **Arch Linux**, Android Studio, **Debian**, **Command Line**,
|
|
||||||
**Git**, IntelliJ IDEA, **Pycharm**, **NGINX**, npm/yarn, **SFTP**,
|
|
||||||
**SSH**, **Vim**
|
|
||||||
|
|
||||||
{{% /resume/section %}}<!--- }}} -->
|
<!--- Rarity Surf }}} -->
|
||||||
|
|
||||||
{{% resume/section projects %}}<!--- {{{ -->
|
<!--- Astronofty {{{ -->
|
||||||
|
|
||||||
<!--- Spotify Graphs {{{ -->
|
{{% resume/project name="Astronofty"
|
||||||
|
url="https://github.com/Kevin-Mok/astronofty"
|
||||||
{{% resume/project name="Spotify Graphs"
|
languages="JavaScript, React, Solidity" date="Jan 2023"
|
||||||
url="https://github.com/Kevin-Mok/spotify-lib-vis" date="June 2018 — July 2018"
|
|
||||||
show="true" %}}
|
show="true" %}}
|
||||||
|
|
||||||
- Implemented base functionality of scanning tracks and listening
|
- **Secured [2nd place](https://devpost.com/software/astronofty) overall out of 150+ teams** at UofTHacks
|
||||||
history from user's library using Spotify API and organized data
|
X, a 36-hour hackathon, for developing a blockchain-based
|
||||||
into **PostgreSQL** database with **Django** backend.
|
NFT marketplace app.
|
||||||
- Created and tested various relational database schemas to maximize
|
- **Built and optimized React (JavaScript) [components](https://github.com/Kevin-Mok/astronofty/tree/main/src/components)** to synchronously
|
||||||
efficiency for use cases.
|
upload images and metadata to IPFS, **enhancing user engagement by 80%** during the demo.
|
||||||
- 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 %}}
|
{{% /resume/project %}}
|
||||||
|
|
||||||
<!--- Spotify Graphs }}} -->
|
<!--- Astronofty }}} -->
|
||||||
|
|
||||||
<!--- 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 }}} -->
|
|
||||||
|
|
||||||
<!--- 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 }}} -->
|
|
||||||
|
|
||||||
<!--- TrapBot {{{ -->
|
|
||||||
|
|
||||||
{{% resume/project name="TrapBot"
|
|
||||||
url="https://github.com/Kevin-Mok/TrapBot" date="March 2018" %}}
|
|
||||||
|
|
||||||
- Use reddit API wrapper in **Python** to scan music subreddits for user
|
|
||||||
comments containing common track listing formats.
|
|
||||||
- Match detected track name and artists to track on SoundCloud using another
|
|
||||||
Python API wrapper.
|
|
||||||
- Respond to original poster's comment with formatted list of tracks found.
|
|
||||||
- Received positive comment from users who replied to the bot's posts.
|
|
||||||
|
|
||||||
{{% /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 }}} -->
|
|
||||||
|
|
||||||
<!--- Super ADA Bros. {{{ -->
|
|
||||||
|
|
||||||
{{% resume/project name="Super ADA Bros"
|
|
||||||
url="https://github.com/Kevin-Mok/SuperADABros" date="May 2019" %}}
|
|
||||||
|
|
||||||
- Designed clone of Super Mario Bros 1-1, but Mario is mobility-impaired and
|
|
||||||
uses ramps to get through the level.
|
|
||||||
- Uses **OpenCV** to track player's head movement which is then translated to
|
|
||||||
in-game movement. [Video Demo]
|
|
||||||
- Implemented in [**Godot**][Godot site], an open-source game engine.
|
|
||||||
- Made during a 24-hour [accessibility-themed hackathon][PC Hacks event].
|
|
||||||
|
|
||||||
[PC Hacks event]: https://pchacks19.devpost.com/
|
|
||||||
[Godot site]: https://godotengine.org
|
|
||||||
[Video Demo]: https://youtu.be/vRdENLGrBqM
|
|
||||||
|
|
||||||
{{% /resume/project %}}
|
|
||||||
|
|
||||||
|
|
||||||
<!--- Grocery Finder }}} -->
|
|
||||||
|
|
||||||
{{% /resume/section %}}<!--- }}} -->
|
|
||||||
|
|
||||||
{{% resume/section "Work Experience" %}}<!--- {{{ -->
|
{{% resume/section "Work Experience" %}}<!--- {{{ -->
|
||||||
|
|
||||||
{{% resume/education name="Philpott Children's Tennis"
|
{{% resume/work-experience name="Red Hat" title="Cloud/Software Engineer Intern" languages="Kubernetes, GoLang, Jenkins" date="May 2022 — Aug 2023" %}}
|
||||||
title="Head Instructor" date="2013 — 2015" %}}
|
|
||||||
- Ran 8-week summer camp for inner-city youth with assistant coach.
|
- **Reduced deployment time by 66%** by implementing a
|
||||||
- Prepared daily lesson plans for 4 different age groups of children
|
[solution](https://github.com/apache/incubator-kie-kogito-operator/commit/175a6356c5474f2360ccb8ae835e0b9b2d653cf1) for deploying locally-compiled binaries onto
|
||||||
with varying skill levels and needs.
|
Kubernetes/OpenShift via command-line, **cutting average
|
||||||
- Supervised and ensured the safety and enjoyment of up to 20 children at once.
|
deployment times from 45 minutes to 15 minutes**.
|
||||||
|
(**Kubernetes/GoLang** used for this and three below).
|
||||||
|
- **Eliminated 80% of manual configuration errors** by enabling
|
||||||
|
the Kubernetes operator to automatically fetch data from
|
||||||
|
deployed services and update configurations, **deprecating
|
||||||
|
legacy startup scripts and reducing overall startup time
|
||||||
|
by 40%**.
|
||||||
|
- **Improved application stability** by introducing startup
|
||||||
|
probes for legacy applications with longer boot times,
|
||||||
|
**resulting in a 50% reduction in startup-related failures
|
||||||
|
and downtime during production launches**.
|
||||||
|
- **Enhanced system reliability** by refactoring probes to
|
||||||
|
[assign default values](https://github.com/apache/incubator-kie-kogito-operator/commit/af4977af228ec8648be28779259d4552246b656f) dynamically based on deployed YAML
|
||||||
|
files and fixing reconciliation issues, **increasing probe accuracy by 30%** and preventing misconfigurations.
|
||||||
|
- **Increased CI pipeline efficiency** by rewriting the
|
||||||
|
**Jenkins (Groovy)** [nightly pipeline](https://github.com/apache/incubator-kie-kogito-pipelines/commit/4c83f1aecdea2c1ba2796b79839a90d4083dce88) to run in a GitHub PR
|
||||||
|
environment, allowing for automated testing of all
|
||||||
|
team-submitted PRs prior to merging, **reducing manual
|
||||||
|
intervention by 60%**.
|
||||||
|
- **Increased project reproducibility** by taking initiative to
|
||||||
|
write a [reusable GitHub parameters file](https://github.com/apache/incubator-kie-kogito-pipelines/commit/4c83f1aecdea2c1ba2796b79839a90d4083dce88#diff-7d2c018dafbccec859077d19bf1ade53ec9c7649f235528ce89f5632b109f7e6) for the pipeline,
|
||||||
|
**enabling 100% reusability** and ensuring consistent pipeline
|
||||||
|
setups across different environments.
|
||||||
|
- **Streamlined developer onboarding** by authoring
|
||||||
|
comprehensive [project documentation](https://github.com/apache/incubator-kie-kogito-operator/blob/1534c03d1d26bec08a16608a775782bf8b305de9/docs/GUIDE_FOR_KOGITO_DEVS.md) and mentoring an
|
||||||
|
incoming intern, **reducing onboarding time by 50%** and
|
||||||
|
enhancing new team members' productivity within their
|
||||||
|
first sprint.
|
||||||
|
|
||||||
|
{{% /resume/section %}}<!--- }}} -->
|
||||||
|
|
||||||
|
{{% resume/section skills %}}<!--- {{{ -->
|
||||||
|
|
||||||
|
**TypeScript**, **JavaScript**, **React**, **Node.js**, **Python**,
|
||||||
|
**Django**, PostgreSQL, MongoDB, Bash, **Git**, **Linux**, **Command
|
||||||
|
Line**, Go(Lang), AWS, Kubernetes, Terraform, Docker (Compose),
|
||||||
|
Jenkins, Groovy, Solidity, C
|
||||||
|
|
||||||
{{% /resume/section %}}<!--- }}} -->
|
{{% /resume/section %}}<!--- }}} -->
|
||||||
|
|
||||||
{{% resume/section education %}}<!--- {{{ -->
|
{{% resume/section education %}}<!--- {{{ -->
|
||||||
|
|
||||||
{{% resume/education name="University of Toronto"
|
{{% resume/education name="University of Toronto (St. George)"
|
||||||
title="Computer Science Specialist" date="2017 — 2021" %}}
|
title="Computer Science Specialist — 3.84 GPA (CS). Graduated with High Distinction." date="2019 — 2024" %}}
|
||||||
|
|
||||||
{{% /resume/section %}}<!--- }}} -->
|
{{% /resume/section %}}<!--- }}} -->
|
||||||
|
|
||||||
<!-- vim: fdm=marker -->
|
<!-- vim: fdm=marker -->
|
||||||
|
|
||||||
|
|||||||
82
content/resume/old.txt
Normal file
82
content/resume/old.txt
Normal file
@@ -0,0 +1,82 @@
|
|||||||
|
<!--- 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 }}} -->
|
||||||
9
content/resume/red-hat.txt
Normal file
9
content/resume/red-hat.txt
Normal file
@@ -0,0 +1,9 @@
|
|||||||
|
• Working on the Kogito (cloud-native, open-source business automation technology) Cloud Engineering team.
|
||||||
|
• Implemented ability for Kogito operator to fetch exposed protobuf files from a deployed service and update ConfigMap with data (*Kubernetes*, *Go*, KOGITO-3376).
|
||||||
|
• Reduced deployment time by 66% by implementing ability to deploy locally-compiled Kogito binaries onto OpenShift using only Kogito CLI (*Go*, KOGITO-2113).
|
||||||
|
• Added startup probes to handle starting legacy application containers that require additional startup time
|
||||||
|
(*Go*, KOGITO-4322).
|
||||||
|
• Refactored Kogito probes to have default values assigned based on deployed YAML/runtime while also fixing reconciliation issues (*Kubernetes*, *Go*, KOGITO-4898).
|
||||||
|
• Automated the promotion and release process for Kogito runtimes as part of the release pipeline (*Jenkins*, KOGITO-1653). Wrote unit tests in the Spock framework.
|
||||||
|
• Wrote documentation to onboard new Kogito operator developers and reduce friction needed for them to start contributing (*Kubernetes/minikube/OpenShift*, KOGITO-5127). Was completed as part of mentoring incoming intern to expedite initial onboarding process.
|
||||||
|
• Presented a talk based on my experience called "8 Things I Learned About Software Engineering" to an audience of 75+ in a conference for internship seekers.
|
||||||
18
content/resume/server-ideas.md
Normal file
18
content/resume/server-ideas.md
Normal file
@@ -0,0 +1,18 @@
|
|||||||
|
# To-Do
|
||||||
|
- check price of AWS server
|
||||||
|
- run Docker apps on it
|
||||||
|
- run domain
|
||||||
|
- run/create Docker compose
|
||||||
|
- Dockerize app
|
||||||
|
|
||||||
|
# Done
|
||||||
|
|
||||||
|
# Points
|
||||||
|
- run/deploy K8s locally on minikube using kubectl
|
||||||
|
- features
|
||||||
|
- Dockerize app
|
||||||
|
- run Docker on server (AWS)
|
||||||
|
|
||||||
|
# Replace
|
||||||
|
- personal server
|
||||||
|
- Astronofy
|
||||||
@@ -19,7 +19,7 @@
|
|||||||
<img src="{{ "img/social/github.svg" | relURL }}"
|
<img src="{{ "img/social/github.svg" | relURL }}"
|
||||||
alt="github-logo">
|
alt="github-logo">
|
||||||
</a>
|
</a>
|
||||||
<a href="https://git.kevin-mok.com/" target="_blank">
|
<a href="https://git.kevin-mok.com/Kevin-Mok?tab=activity" target="_blank">
|
||||||
<img src="{{ "img/social/gitea.svg" | relURL }}" alt="gitea-logo">
|
<img src="{{ "img/social/gitea.svg" | relURL }}" alt="gitea-logo">
|
||||||
</a>
|
</a>
|
||||||
·
|
·
|
||||||
|
|||||||
@@ -12,7 +12,7 @@
|
|||||||
{{ hugo.Generator }}
|
{{ hugo.Generator }}
|
||||||
<meta name="google-site-verification" content="3aZhrY5bFgQY0HY2DNNUhbkuIfVEcwkrQHnbJd8jCCQ" />
|
<meta name="google-site-verification" content="3aZhrY5bFgQY0HY2DNNUhbkuIfVEcwkrQHnbJd8jCCQ" />
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1">
|
<meta name="viewport" content="width=device-width, initial-scale=1">
|
||||||
<!-- <script src="https://cdn.khkm.gq/live.js" charset="utf-8"></script> -->
|
<!-- <script src="https://cdn.khkm.tk/live.js" charset="utf-8"></script> -->
|
||||||
<link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/css/bootstrap.min.css" integrity="sha384-ggOyR0iXCbMQv3Xipma34MD+dH/1fQ784/j6cY/iJTQUOhcWr7x9JvoRxT2MZw1T" crossorigin="anonymous">
|
<link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/css/bootstrap.min.css" integrity="sha384-ggOyR0iXCbMQv3Xipma34MD+dH/1fQ784/j6cY/iJTQUOhcWr7x9JvoRxT2MZw1T" crossorigin="anonymous">
|
||||||
<script src="https://code.jquery.com/jquery-3.3.1.slim.min.js" integrity="sha384-q8i/X+965DzO0rT7abK41JStQIAqVgRVzpbzo5smXKp4YfRvH+8abtTE1Pi6jizo" crossorigin="anonymous"></script>
|
<script src="https://code.jquery.com/jquery-3.3.1.slim.min.js" integrity="sha384-q8i/X+965DzO0rT7abK41JStQIAqVgRVzpbzo5smXKp4YfRvH+8abtTE1Pi6jizo" crossorigin="anonymous"></script>
|
||||||
<script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.14.7/umd/popper.min.js" integrity="sha384-UO2eT0CpHqdSJQ6hJty5KVphtPhzWj9WO1clHTMGa3JDZwrnQq4sF86dIHNDz0W1" crossorigin="anonymous"></script>
|
<script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.14.7/umd/popper.min.js" integrity="sha384-UO2eT0CpHqdSJQ6hJty5KVphtPhzWj9WO1clHTMGa3JDZwrnQq4sF86dIHNDz0W1" crossorigin="anonymous"></script>
|
||||||
|
|||||||
@@ -1,10 +1,21 @@
|
|||||||
<div id="about">
|
<div id="about">
|
||||||
<h2>Welcome to my site!</h2>
|
<h2>Welcome to my site!</h2>
|
||||||
<p>
|
<p>
|
||||||
I'm Kevin Mok - a Computer Science
|
I'm Kevin Mok. Here are a few things about myself!
|
||||||
student at the University of Toronto, and I'm greatly interested in all things Linux and
|
<ul>
|
||||||
<a href="https://www.gnu.org/philosophy/floss-and-foss.en.html"
|
<li>I'm an Ex-Cloud Engineer Intern at
|
||||||
target="_blank">FOSS/FLOSS</a>.
|
<a href="https://www.redhat.com/" target="_blank">Red Hat</a>.
|
||||||
|
</li>
|
||||||
|
<li>
|
||||||
|
I'm graduated with a 3.84 GPA studying Computer Science at the
|
||||||
|
University of Toronto in 2024 (currently looking for a full-time position!).
|
||||||
|
</li>
|
||||||
|
<li>
|
||||||
|
I'm greatly interested in all things Linux and
|
||||||
|
<a href="https://www.gnu.org/philosophy/floss-and-foss.en.html"
|
||||||
|
target="_blank">FOSS/FLOSS</a>.
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
{{ partial "home/me-equation.html" . }}
|
{{ partial "home/me-equation.html" . }}
|
||||||
|
|||||||
@@ -1,14 +1,8 @@
|
|||||||
<div class="me-equation">
|
<div class="me-equation">
|
||||||
<div class="equation-part">
|
<div class="equation-part">
|
||||||
<a href="https://www.gnu.org/" target="_blank">
|
<a href="https://www.redhat.com/" target="_blank">
|
||||||
<img src="{{ "img/home/gnu.svg" | relURL }}" id="gnu" alt="gnu-logo">
|
<img src="{{ "img/home/red-hat.svg" | relURL }}"
|
||||||
</a>
|
alt="red-hat-logo">
|
||||||
<p>+</p>
|
|
||||||
</div>
|
|
||||||
<div class="equation-part">
|
|
||||||
<a href="https://www.wikiwand.com/en/Arch_Linux" target="_blank">
|
|
||||||
<img src="{{ "img/home/arch.svg" | relURL }}" alt="linux-logo">
|
|
||||||
<!-- <img src="{{ "img/home/larbs.png" | relURL }}" alt="linux-logo"> -->
|
|
||||||
</a>
|
</a>
|
||||||
<p>+</p>
|
<p>+</p>
|
||||||
</div>
|
</div>
|
||||||
@@ -16,8 +10,14 @@
|
|||||||
<a href="https://www.utoronto.ca/" target="_blank">
|
<a href="https://www.utoronto.ca/" target="_blank">
|
||||||
<img src="{{ "img/home/uoft-logo.svg" | relURL }}" alt="uoft-logo">
|
<img src="{{ "img/home/uoft-logo.svg" | relURL }}" alt="uoft-logo">
|
||||||
</a>
|
</a>
|
||||||
<p>=</p>
|
<p>+</p>
|
||||||
</div>
|
</div>
|
||||||
|
<div class="equation-part">
|
||||||
|
<a href="https://www.gnu.org/" target="_blank">
|
||||||
|
<img src="{{ "img/home/gnu.svg" | relURL }}" id="gnu" alt="gnu-logo">
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
<p>=</p>
|
||||||
<div class="equation-part">
|
<div class="equation-part">
|
||||||
<img src="{{ "img/home/hexatar.png" | relURL }}" id="hexatar" alt="my-avatar">
|
<img src="{{ "img/home/hexatar.png" | relURL }}" id="hexatar" alt="my-avatar">
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
@@ -7,7 +7,8 @@
|
|||||||
</div>
|
</div>
|
||||||
<div class="col text-right date">{{ .Get "date" }}</div>
|
<div class="col text-right date">{{ .Get "date" }}</div>
|
||||||
</div>
|
</div>
|
||||||
<span class="title">
|
<!-- <span class="title"> -->
|
||||||
|
<span>
|
||||||
{{ .Get "title" }}
|
{{ .Get "title" }}
|
||||||
</span>
|
</span>
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
@@ -1,17 +1,10 @@
|
|||||||
<div class="project">
|
<div class="project">
|
||||||
<div class="row project-header">
|
<div class="row project-header">
|
||||||
<div class="col-8 text-left">
|
<div class="col-8 text-left">
|
||||||
<a class="project-link" href="{{ .Get "url" }}" target="_blank">
|
|
||||||
<img src="{{ "img/resume/link.svg" | relURL }}" alt="link-icon">
|
|
||||||
</a>
|
|
||||||
<button class="btn" type="button" data-toggle="collapse"
|
|
||||||
data-target="#{{ .Get "name" | lower | urlize }}-details"
|
|
||||||
aria-expanded="false" aria-controls="{{ .Get "name" | lower | urlize }}-details">
|
|
||||||
<h2 class="project-title">
|
<h2 class="project-title">
|
||||||
{{ .Get "name" }}
|
{{ .Get "name" }}
|
||||||
<img class="down-triangle" src="{{ "img/resume/down-triangle.png" | relURL }}" alt="link-icon">
|
|
||||||
</h2>
|
</h2>
|
||||||
</button>
|
<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>
|
||||||
@@ -21,3 +14,4 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
|||||||
9
layouts/shortcodes/resume/references.html
Normal file
9
layouts/shortcodes/resume/references.html
Normal file
@@ -0,0 +1,9 @@
|
|||||||
|
<div class="references">
|
||||||
|
<span>
|
||||||
|
See my
|
||||||
|
<a href="https://www.linkedin.com/in/Kev-Mok"
|
||||||
|
target="_blank">
|
||||||
|
LinkedIn</a> for references from my Red Hat managers/mentee,
|
||||||
|
a startup client and a graduate student mentor.
|
||||||
|
</span>
|
||||||
|
</div>
|
||||||
18
layouts/shortcodes/resume/work-experience.html
Normal file
18
layouts/shortcodes/resume/work-experience.html
Normal file
@@ -0,0 +1,18 @@
|
|||||||
|
<div class="work-experience">
|
||||||
|
<div class="row">
|
||||||
|
<div class="col-8 text-left">
|
||||||
|
<p class="company">
|
||||||
|
{{ .Get "name" }}
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
<div class="col text-right date">{{ .Get "date" }}</div>
|
||||||
|
</div>
|
||||||
|
<!-- <span class="title"> -->
|
||||||
|
<span class="position">
|
||||||
|
{{ .Get "title" }}
|
||||||
|
</span>
|
||||||
|
<span class="languages">
|
||||||
|
<{{ .Get "languages" }}>
|
||||||
|
</span>
|
||||||
|
</div>
|
||||||
|
|
||||||
18
static/img/home/red-hat.svg
Normal file
18
static/img/home/red-hat.svg
Normal file
@@ -0,0 +1,18 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||||
|
<svg xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:cc="http://creativecommons.org/ns#" xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:svg="http://www.w3.org/2000/svg" xmlns="http://www.w3.org/2000/svg" xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd" xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape" id="b6bdd2b4-52ab-488a-9a30-1e6d1d7dd2d4" data-name="Layer 1" viewBox="0 0 192.30001 146" version="1.1" sodipodi:docname="logo.svg" width="192.3" height="146" inkscape:version="0.92.5 (2060ec1f9f, 2020-04-08)">
|
||||||
|
<metadata id="metadata15">
|
||||||
|
<rdf:RDF>
|
||||||
|
<cc:Work rdf:about="">
|
||||||
|
<dc:format>image/svg+xml</dc:format>
|
||||||
|
<dc:type rdf:resource="http://purl.org/dc/dcmitype/StillImage"/>
|
||||||
|
<dc:title/>
|
||||||
|
</cc:Work>
|
||||||
|
</rdf:RDF>
|
||||||
|
</metadata>
|
||||||
|
<sodipodi:namedview pagecolor="#ffffff" bordercolor="#666666" borderopacity="1" objecttolerance="10" gridtolerance="10" guidetolerance="10" inkscape:pageopacity="0" inkscape:pageshadow="2" inkscape:window-width="1920" inkscape:window-height="1007" id="namedview13" showgrid="false" fit-margin-top="1" fit-margin-right="1" fit-margin-bottom="1" fit-margin-left="1" inkscape:zoom="0.45930043" inkscape:cx="306.89999" inkscape:cy="73" inkscape:window-x="0" inkscape:window-y="0" inkscape:window-maximized="1" inkscape:current-layer="b6bdd2b4-52ab-488a-9a30-1e6d1d7dd2d4"/>
|
||||||
|
<defs id="defs4">
|
||||||
|
<style id="style2">.a737459c-e8c7-4afa-8008-f6cfd15ccda2{fill:#e00;}</style>
|
||||||
|
</defs>
|
||||||
|
<path class="a737459c-e8c7-4afa-8008-f6cfd15ccda2" d="m 128,84 c 12.5,0 30.6,-2.6 30.6,-17.5 a 19.53,19.53 0 0 0 -0.3,-3.4 L 150.9,30.7 C 149.2,23.6 147.7,20.3 135.2,14.1 125.5,9.1 104.4,1 98.1,1 92.2,1 90.5,8.5 83.6,8.5 76.9,8.5 72,2.9 65.7,2.9 c -6,0 -9.9,4.1 -12.9,12.5 0,0 -8.4,23.7 -9.5,27.2 a 6.15,6.15 0 0 0 -0.2,1.9 C 43,53.7 79.3,83.9 128,84 m 32.5,-11.4 c 1.7,8.2 1.7,9.1 1.7,10.1 0,14 -15.7,21.8 -36.4,21.8 C 79,104.5 38.1,77.1 38.1,59 a 18.35,18.35 0 0 1 1.5,-7.3 C 22.8,52.5 1,55.5 1,74.7 1,106.2 75.6,145 134.6,145 c 45.3,0 56.7,-20.5 56.7,-36.7 0,-12.7 -11,-27.1 -30.8,-35.7" id="path8" inkscape:connector-curvature="0" style="fill:#ee0000"/>
|
||||||
|
<path d="m 160.5,72.6 c 1.7,8.2 1.7,9.1 1.7,10.1 0,14 -15.7,21.8 -36.4,21.8 C 79,104.5 38.1,77.1 38.1,59 a 18.35,18.35 0 0 1 1.5,-7.3 l 3.7,-9.1 a 6.15,6.15 0 0 0 -0.2,1.9 c 0,9.2 36.3,39.4 84.9,39.4 12.5,0 30.6,-2.6 30.6,-17.5 A 19.53,19.53 0 0 0 158.3,63 Z" id="path10" inkscape:connector-curvature="0"/>
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 2.5 KiB |
BIN
static/img/resume/signature-white-lg.png
Normal file
BIN
static/img/resume/signature-white-lg.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 465 KiB |
Binary file not shown.
|
Before Width: | Height: | Size: 465 KiB After Width: | Height: | Size: 66 KiB |
Submodule static/pdf updated: ac3a141098...2acb4ee38c
Reference in New Issue
Block a user