Compare commits
8 Commits
2bedc77f1b
...
resume-pdf
| Author | SHA1 | Date | |
|---|---|---|---|
|
162d3d7c25
|
|||
|
7f6743f8d9
|
|||
|
497ad86122
|
|||
|
d1d191e413
|
|||
|
b546a2a529
|
|||
|
8b794bfa8e
|
|||
|
d14bcf3c8f
|
|||
|
e9ce8bd5d1
|
4
.gitmodules
vendored
Normal file
4
.gitmodules
vendored
Normal file
@@ -0,0 +1,4 @@
|
|||||||
|
[submodule "content/letter"]
|
||||||
|
path = content/letter
|
||||||
|
url = ssh://git@git.kevin-mok.com:399/Kevin-Mok/cover-letters.git
|
||||||
|
branch = drafts
|
||||||
@@ -105,7 +105,8 @@ body {
|
|||||||
color: $color;
|
color: $color;
|
||||||
line-height: 1.5;
|
line-height: 1.5;
|
||||||
// font-size: 100%;
|
// font-size: 100%;
|
||||||
font-size: 15px;
|
// font-size: 15px;
|
||||||
|
font-size: 20px;
|
||||||
/* font-family: 'Source Code Pro', monospace; */
|
/* font-family: 'Source Code Pro', monospace; */
|
||||||
font-family: 'Hack', monospace;
|
font-family: 'Hack', monospace;
|
||||||
display: flex;
|
display: flex;
|
||||||
@@ -244,22 +245,22 @@ p {
|
|||||||
margin-bottom: 1rem;
|
margin-bottom: 1rem;
|
||||||
}
|
}
|
||||||
|
|
||||||
h1 {
|
// h1 {
|
||||||
font-size: 2rem;
|
// font-size: 2rem;
|
||||||
|
|
||||||
@media (max-width: $phone-width) {
|
// @media (max-width: $phone-width) {
|
||||||
font-size: 1.75rem;
|
// font-size: 1.75rem;
|
||||||
}
|
// }
|
||||||
}
|
// }
|
||||||
h2 {
|
// h2 {
|
||||||
font-size: 1.5rem;
|
// font-size: 1.5rem;
|
||||||
|
|
||||||
@media (max-width: $phone-width) {
|
// @media (max-width: $phone-width) {
|
||||||
font-size: 1.4rem;
|
// font-size: 1.4rem;
|
||||||
}
|
// }
|
||||||
}
|
// }
|
||||||
h3 { font-size: 1.25rem }
|
h3 { font-size: 1.25rem }
|
||||||
h4 { font-size: 1rem }
|
// h4 { font-size: 1rem }
|
||||||
h5 { font-size: .875rem }
|
h5 { font-size: .875rem }
|
||||||
h6 { font-size: .75rem }
|
h6 { font-size: .75rem }
|
||||||
|
|
||||||
@@ -474,6 +475,7 @@ header {// {{{
|
|||||||
|
|
||||||
#print-icon {// {{{
|
#print-icon {// {{{
|
||||||
float: right;
|
float: right;
|
||||||
|
display: none;
|
||||||
|
|
||||||
img {
|
img {
|
||||||
height: 1.75em;
|
height: 1.75em;
|
||||||
@@ -492,6 +494,12 @@ header {// {{{
|
|||||||
min-width: $max-page-width;
|
min-width: $max-page-width;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
a {// {{{
|
||||||
|
text-decoration: none;
|
||||||
|
&:hover {
|
||||||
|
text-decoration: none;
|
||||||
|
}
|
||||||
|
}// }}}
|
||||||
|
|
||||||
font-size: .9em;
|
font-size: .9em;
|
||||||
|
|
||||||
@@ -518,11 +526,11 @@ header {// {{{
|
|||||||
margin-left: 5px;
|
margin-left: 5px;
|
||||||
// position: relative;
|
// position: relative;
|
||||||
// left: -8px;
|
// left: -8px;
|
||||||
@media (max-width: $phone-width) {
|
// @media (max-width: $phone-width) {
|
||||||
// display: none;
|
// // display: none;
|
||||||
// font-size: 10px;
|
// // font-size: 10px;
|
||||||
font-size: .8em;
|
// font-size: .8em;
|
||||||
}
|
// }
|
||||||
}
|
}
|
||||||
|
|
||||||
}// }}}
|
}// }}}
|
||||||
@@ -537,45 +545,44 @@ header {// {{{
|
|||||||
|
|
||||||
h1 {// {{{
|
h1 {// {{{
|
||||||
color: $base-orange;
|
color: $base-orange;
|
||||||
margin-top: 1rem;
|
margin-top: 1.3rem;
|
||||||
|
|
||||||
@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;
|
||||||
|
|
||||||
@media (max-width: $phone-width) {
|
// @media (max-width: $phone-width) {
|
||||||
font-size: 1.2em;
|
// font-size: 1.2em;
|
||||||
margin-top: .75rem;
|
// margin-top: .75rem;
|
||||||
}
|
// }
|
||||||
}// }}}
|
}// }}}
|
||||||
h4 {// {{{
|
h4 {// {{{
|
||||||
color: $base-yellow;
|
color: $base-yellow;
|
||||||
margin-top: .5rem;
|
margin-top: .5rem;
|
||||||
|
|
||||||
@media (max-width: $phone-width) {
|
// @media (max-width: $phone-width) {
|
||||||
font-size: 1.2em;
|
// font-size: 1.2em;
|
||||||
margin-top: .75rem;
|
// margin-top: .75rem;
|
||||||
}
|
// }
|
||||||
}// }}}
|
}// }}}
|
||||||
|
|
||||||
.date {// {{{
|
.date {// {{{
|
||||||
padding-top: .8em;
|
|
||||||
float: right;
|
float: right;
|
||||||
color: $base03;
|
color: $base03;
|
||||||
|
|
||||||
@media (max-width: $phone-width) {
|
// @media (max-width: $phone-width) {
|
||||||
padding-top: 0em;
|
// padding-top: 0em;
|
||||||
}
|
// }
|
||||||
}// }}}
|
}// }}}
|
||||||
|
|
||||||
#projects {// {{{
|
#projects {// {{{
|
||||||
h1 {
|
// // h1 {
|
||||||
margin-bottom: 3px;
|
// // margin-bottom: 3px;
|
||||||
}
|
// // }
|
||||||
|
|
||||||
.project {// {{{
|
.project {// {{{
|
||||||
@include vert-padding-rem(.2);
|
@include vert-padding-rem(.2);
|
||||||
@@ -589,6 +596,10 @@ header {// {{{
|
|||||||
height: 1.2em;
|
height: 1.2em;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.project-header {
|
||||||
|
margin-bottom: .6em;
|
||||||
|
}
|
||||||
|
|
||||||
.project-link {
|
.project-link {
|
||||||
&:hover {
|
&:hover {
|
||||||
text-decoration: none;
|
text-decoration: none;
|
||||||
@@ -640,11 +651,35 @@ header {// {{{
|
|||||||
}
|
}
|
||||||
}// }}}
|
}// }}}
|
||||||
|
|
||||||
@media (max-width: $phone-width) {
|
// @media (max-width: $phone-width) {
|
||||||
font-size: 14px;
|
// font-size: 14px;
|
||||||
// font-size: 1em;
|
// // font-size: 1em;
|
||||||
|
// }
|
||||||
|
|
||||||
|
&.letter {
|
||||||
|
margin-top: 2em;
|
||||||
|
|
||||||
|
img {
|
||||||
|
height: 4.5em;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
h2 {
|
||||||
|
color: $base-red;
|
||||||
|
margin-top: 0em;
|
||||||
|
}
|
||||||
|
|
||||||
|
p {
|
||||||
|
margin-bottom: 1.25em;
|
||||||
|
}
|
||||||
|
|
||||||
|
.no-line-spacing {
|
||||||
|
line-height: .5em;
|
||||||
|
margin-bottom: 2em;
|
||||||
|
p {
|
||||||
|
margin-bottom: 1em;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}// }}}
|
}// }}}
|
||||||
|
|
||||||
#server {// {{{
|
#server {// {{{
|
||||||
@@ -715,20 +750,20 @@ h1.site-title {// {{{
|
|||||||
text-decoration: none;
|
text-decoration: none;
|
||||||
}
|
}
|
||||||
|
|
||||||
@media (max-width: $max-page-width) {
|
// @media (max-width: $phone-width) {
|
||||||
font-size: 3em;
|
// font-size: 3em;
|
||||||
}
|
// }
|
||||||
|
|
||||||
@media (max-width: $phone-width) {
|
// @media (max-width: $phone-width) {
|
||||||
font-size: 3.5em;
|
// font-size: 3.5em;
|
||||||
@include vert-margin-rem(.3);
|
// @include vert-margin-rem(.3);
|
||||||
// font-size: 2.5em;
|
// // font-size: 2.5em;
|
||||||
// font-size: 2em;
|
// // font-size: 2em;
|
||||||
|
|
||||||
.surrounding {
|
// .surrounding {
|
||||||
display: none;
|
// display: none;
|
||||||
}
|
// }
|
||||||
}
|
// }
|
||||||
}// }}}
|
}// }}}
|
||||||
|
|
||||||
.hero-logo img {
|
.hero-logo img {
|
||||||
|
|||||||
10
config.yaml
10
config.yaml
@@ -16,7 +16,7 @@ menu:
|
|||||||
main:
|
main:
|
||||||
- name: resume
|
- name: resume
|
||||||
url: /resume
|
url: /resume
|
||||||
weight: 5
|
weight: 1
|
||||||
# - name: posts/
|
# - name: posts/
|
||||||
# url: /posts
|
# url: /posts
|
||||||
# weight: 6
|
# weight: 6
|
||||||
@@ -26,6 +26,12 @@ menu:
|
|||||||
- name: config
|
- name: config
|
||||||
url: /config
|
url: /config
|
||||||
weight: 10
|
weight: 10
|
||||||
|
- name: card
|
||||||
|
url: /card
|
||||||
|
weight: 15
|
||||||
|
- name: letter
|
||||||
|
url: /letter
|
||||||
|
weight: 17
|
||||||
# - name: credits
|
# - name: credits
|
||||||
# url: /credits
|
# url: /credits
|
||||||
# weight: 20
|
# weight: 20
|
||||||
@@ -34,3 +40,5 @@ blackfriday:
|
|||||||
plainIDAnchors: true
|
plainIDAnchors: true
|
||||||
hrefTargetBlank: true
|
hrefTargetBlank: true
|
||||||
|
|
||||||
|
disableKinds: ["RSS"]
|
||||||
|
|
||||||
|
|||||||
5
content/card/_index.md
Normal file
5
content/card/_index.md
Normal file
@@ -0,0 +1,5 @@
|
|||||||
|
---
|
||||||
|
title: "Digital Card"
|
||||||
|
date: 2019-02-11T07:50:51-05:00
|
||||||
|
draft: true
|
||||||
|
---
|
||||||
@@ -1,5 +0,0 @@
|
|||||||
---
|
|
||||||
title: "Credits"
|
|
||||||
date: 2019-02-11T03:10:25-05:00
|
|
||||||
draft: true
|
|
||||||
---
|
|
||||||
1
content/letter
Submodule
1
content/letter
Submodule
Submodule content/letter added at 56c2d30c4a
@@ -15,8 +15,8 @@ full-stack web dev, DevOps or system administration.
|
|||||||
{{% resume/section skills %}}<!--- {{{ -->
|
{{% resume/section skills %}}<!--- {{{ -->
|
||||||
|
|
||||||
#### Languages
|
#### Languages
|
||||||
- **Bash**, C, **CSS**, C++, **Fish**, Godot, **HTML5**, **Python**,
|
- **Bash**, C, **CSS**, C++, **Fish** (shell), Godot, **HTML5**,
|
||||||
Java, **Javascript (ES6)**, **Sass**
|
**Python**, Java, **Javascript** (ES6), **Sass**
|
||||||
|
|
||||||
#### Frameworks
|
#### Frameworks
|
||||||
- **Bootstrap**, **Django**, **Node.js**, **PostgreSQL**
|
- **Bootstrap**, **Django**, **Node.js**, **PostgreSQL**
|
||||||
@@ -39,15 +39,14 @@ full-stack web dev, DevOps or system administration.
|
|||||||
url="https://github.com/Kevin-Mok/spotify-lib-vis" date="June 2018 — July 2018"
|
url="https://github.com/Kevin-Mok/spotify-lib-vis" date="June 2018 — July 2018"
|
||||||
show="true" %}}
|
show="true" %}}
|
||||||
|
|
||||||
- Scan tracks from user's library using Spotify API and organize data into
|
- Implemented base functionality of scanning tracks and listening
|
||||||
database.
|
history from user's library using Spotify API and organized data
|
||||||
- Created and tested various __PostgreSQL__ schemas to increase efficiency for
|
into **PostgreSQL** database with **Django** backend.
|
||||||
use cases.
|
- Created and tested various relational database schemas to maximize
|
||||||
- Produce bubble chart and (stacked) bar chart in [**d3** graphs][d3 graph examples]
|
efficiency for use cases.
|
||||||
to visualize the artists, genres and features of tracks in library.
|
- Produced bubble chart and (stacked) bar chart using [**d3**]
|
||||||
- Implement functionality to keep track of user's listening history. Set up
|
[d3 graph examples] to visualize the artists, genres and features of
|
||||||
`cron` job on my local machine to keep track of my own.
|
tracks in library.
|
||||||
- Uses __Django__ for backend.
|
|
||||||
|
|
||||||
[d3 graph examples]: https://github.com/d3/d3/wiki/Gallery
|
[d3 graph examples]: https://github.com/d3/d3/wiki/Gallery
|
||||||
|
|
||||||
@@ -61,14 +60,14 @@ show="true" %}}
|
|||||||
url="https://github.com/Kevin-Mok/grocery-finder" date="Feb. 2019 — Apr. 2019"
|
url="https://github.com/Kevin-Mok/grocery-finder" date="Feb. 2019 — Apr. 2019"
|
||||||
show="true" %}}
|
show="true" %}}
|
||||||
|
|
||||||
- PoC for web app that finds the ideal supermarket based on your cart.
|
- Proof of concept for web app that finds the ideal supermarket based on your cart.
|
||||||
- Designed responsive front-end layout using **Bootstrap**.
|
- Designed responsive front-end layout using **Bootstrap**.
|
||||||
- Implemented REST API functionality on backend using **Node.js** and
|
- Implemented REST API functionality on backend using **Node.js** and
|
||||||
**MongoDB**.
|
**MongoDB**.
|
||||||
- Setup deployment on [**Heroku**][Grocery Finder Heroku].
|
- Setup deployment on [**Heroku**][Grocery Finder Heroku].
|
||||||
- Led team of 4 as project leader to prioritize and delegate tasks while
|
- Led team of 4 as project leader to prioritize and delegate tasks while
|
||||||
also implementing a majority of the core features.
|
also implementing a majority of the core features.
|
||||||
- Performed code review for team member's pull requests.
|
- Performed code review for team members' pull requests.
|
||||||
|
|
||||||
[Grocery Finder Heroku]: http://www.grocery-finder.ml
|
[Grocery Finder Heroku]: http://www.grocery-finder.ml
|
||||||
|
|
||||||
@@ -117,7 +116,7 @@ url="https://github.com/Kevin-Mok/TrapBot" date="March 2018" %}}
|
|||||||
<!--- DigitalOcean {{{ -->
|
<!--- DigitalOcean {{{ -->
|
||||||
|
|
||||||
{{% resume/project name="Personal Server"
|
{{% resume/project name="Personal Server"
|
||||||
url="https://kevin-mok.com/server/" date="Aug. 2019—present" %}}
|
url="https://kevin-mok.com/server/" date="Aug. 2019 — present" %}}
|
||||||
|
|
||||||
- Deployed various web apps with backends such as Node, PHP and Python using
|
- Deployed various web apps with backends such as Node, PHP and Python using
|
||||||
**NGINX** on a **Debian** server.
|
**NGINX** on a **Debian** server.
|
||||||
@@ -133,32 +132,12 @@ url="https://kevin-mok.com/server/" date="Aug. 2019—present" %}}
|
|||||||
|
|
||||||
<!--- DigitalOcean Droplet }}} -->
|
<!--- 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 %}}<!--- }}} -->
|
||||||
|
|
||||||
{{% resume/section "Work Experience" %}}<!--- {{{ -->
|
{{% resume/section "Work Experience" %}}<!--- {{{ -->
|
||||||
|
|
||||||
{{% resume/education name="Philpott Children's Tennis" title="Head Instructor" date="2013—2015" %}}
|
{{% resume/education name="Philpott Children's Tennis"
|
||||||
|
title="Head Instructor" date="2013 — 2015" %}}
|
||||||
- Ran 8-week summer camp for inner-city youth with assistant coach.
|
- Ran 8-week summer camp for inner-city youth with assistant coach.
|
||||||
- Prepared daily lesson plans for 4 different age groups of children
|
- Prepared daily lesson plans for 4 different age groups of children
|
||||||
with varying skill levels and needs.
|
with varying skill levels and needs.
|
||||||
@@ -168,7 +147,8 @@ url="https://github.com/Kevin-Mok/SuperADABros" date="May 2019" %}}
|
|||||||
|
|
||||||
{{% resume/section education %}}<!--- {{{ -->
|
{{% resume/section education %}}<!--- {{{ -->
|
||||||
|
|
||||||
{{% resume/education name="University of Toronto" title="Computer Science Specialist" date="2017-2021" %}}
|
{{% resume/education name="University of Toronto"
|
||||||
|
title="Computer Science Specialist" date="2017 — 2021" %}}
|
||||||
|
|
||||||
{{% /resume/section %}}<!--- }}} -->
|
{{% /resume/section %}}<!--- }}} -->
|
||||||
|
|
||||||
|
|||||||
@@ -1,20 +0,0 @@
|
|||||||
<!--- Super ADA Bros. {{{ -->
|
|
||||||
|
|
||||||
{{% resume/project name="Super ADA Bros"
|
|
||||||
url="https://github.com/Kevin-Mok/SuperADABros" date="May 2019" %}}
|
|
||||||
|
|
||||||
- Clone of Super Mario Bros 1-1, but Mario is mobility-impaired and
|
|
||||||
uses ramps to get through the level.
|
|
||||||
- Able to played using only head movement by getting input from a
|
|
||||||
face-tracking script (**OpenCV**).
|
|
||||||
- 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
|
|
||||||
|
|
||||||
{{% /resume/project %}}
|
|
||||||
|
|
||||||
|
|
||||||
<!--- Grocery Finder }}} -->
|
|
||||||
|
|
||||||
@@ -1,4 +1,13 @@
|
|||||||
|
# Base
|
||||||
- bg colors
|
- bg colors
|
||||||
- site title max width
|
- increase font size
|
||||||
- switch project shortcode
|
- all phone width blocks
|
||||||
- rm details top margin
|
- reset header sizes
|
||||||
|
- comment out font CSS stylesheet
|
||||||
|
- hide print icon
|
||||||
|
- right margin for social icons
|
||||||
|
|
||||||
|
# Project
|
||||||
|
- remove expand icon and link
|
||||||
|
- rm ADA Bros.
|
||||||
|
- show all sections by default
|
||||||
|
|||||||
69
layouts/card/section.html
Normal file
69
layouts/card/section.html
Normal file
@@ -0,0 +1,69 @@
|
|||||||
|
{{ partial "base/header.html" . }}
|
||||||
|
|
||||||
|
{{ partial "base/site-title.html" . }}
|
||||||
|
|
||||||
|
{{ partial "base/nav-bar.html" . }}
|
||||||
|
|
||||||
|
{{ partial "base/base16-logo.html" . }}
|
||||||
|
|
||||||
|
<main role="main" id="card">
|
||||||
|
<div id="presentational-container" class="container">
|
||||||
|
<div class="row text-center h-100 my-auto">
|
||||||
|
<div id="email-full" class="h-100 mx-auto">
|
||||||
|
<p class="text-center">
|
||||||
|
<nobr>
|
||||||
|
me@kevin-mok.com
|
||||||
|
<span class="social"><span class="spacing">
|
||||||
|
me</span><span class="link-text">@kevi<span
|
||||||
|
class="safari">n</span>
|
||||||
|
<a href="https://fosstodon.org/@Kevin"
|
||||||
|
target="_blank" id="mastodon" class="link link-top">
|
||||||
|
<img src="https://kevin-mok.com/img/social/mastodon.svg" alt=""/>
|
||||||
|
</a></span>
|
||||||
|
</span>
|
||||||
|
<span class="social"><span class="spacing">
|
||||||
|
me@</span><span class="link-text">ke<span
|
||||||
|
class="safari">v</span>
|
||||||
|
<a href="https://www.linkedin.com/in/Kev-Mok" target="_blank"
|
||||||
|
target="_blank" class="link linkedin linkedin-left">
|
||||||
|
<img src="https://kevin-mok.com/img/social/linkedin.svg" alt=""/>
|
||||||
|
</a></span>
|
||||||
|
</span>
|
||||||
|
<span class="social"><span class="spacing">
|
||||||
|
me@kevin</span><span class="link-text">-mo<span
|
||||||
|
class="safari">k</span>
|
||||||
|
<a href="https://www.linkedin.com/in/Kev-Mok" target="_blank" class="link linkedin linkedin-left"></a></span>
|
||||||
|
</span>
|
||||||
|
<span class="social"><span class="spacing">
|
||||||
|
me@kev</span><span class="link-text">i<span
|
||||||
|
class="safari">n</span>
|
||||||
|
<a href="https://www.linkedin.com/in/Kev-Mok" target="_blank"
|
||||||
|
class="link linkedin linkedin-middle"></a></span>
|
||||||
|
</span>
|
||||||
|
<span class="social"><span class="spacing">
|
||||||
|
me@</span><span class="link-text">kevin-mo<span
|
||||||
|
class="safari">k</span>
|
||||||
|
<a href="https://github.com/Kevin-Mok" target="_blank" id="github" class="link">
|
||||||
|
<img src="https://kevin-mok.com/img/social/github.svg" alt=""/>
|
||||||
|
</a></span>
|
||||||
|
</span>
|
||||||
|
<span class="social"><span class="spacing">
|
||||||
|
me@</span><span class="link-text">kevin-mok.co<span
|
||||||
|
class="safari">m</span>
|
||||||
|
<a href="https://kevin-mok.com/" target="_blank" id="site" class="link">
|
||||||
|
<img src="https://kevin-mok.com/img/resume/link.svg" alt=""/>
|
||||||
|
</a></span>
|
||||||
|
</span>
|
||||||
|
<span class="social"><span class="link-text">me@kevin-mok.co<span class="safari"> </span>
|
||||||
|
<a href="mailto:me@kevin-mok.com" target="_blank" id="email" class="link link-top">
|
||||||
|
<img src="https://kevin-mok.com/img/resume/envelope.svg" alt=""/>
|
||||||
|
</a></span>
|
||||||
|
</span>
|
||||||
|
</nobr>
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</main>
|
||||||
|
|
||||||
|
{{ partial "base/footer.html" . }}
|
||||||
22
layouts/letter/section.html
Normal file
22
layouts/letter/section.html
Normal file
@@ -0,0 +1,22 @@
|
|||||||
|
{{ partial "base/header.html" . }}
|
||||||
|
|
||||||
|
{{ partial "base/site-title.html" . }}
|
||||||
|
|
||||||
|
{{ partial "base/nav-bar.html" . }}
|
||||||
|
|
||||||
|
{{ partial "base/base16-logo.html" . }}
|
||||||
|
|
||||||
|
<main role="main" id="letter-home">
|
||||||
|
<!-- <h1 class="list-title">{{ .Title }}</h1> -->
|
||||||
|
<h4 id="letter-instr">Please enter the full URL that I provided
|
||||||
|
for your personalized cover letter. :)</h4>
|
||||||
|
|
||||||
|
<div id="resume" class="letter">
|
||||||
|
{{ .Content }}
|
||||||
|
</div>
|
||||||
|
</main>
|
||||||
|
|
||||||
|
{{ partial "base/footer.html" . }}
|
||||||
|
</div>
|
||||||
|
</body>
|
||||||
|
</html>
|
||||||
15
layouts/letter/single.html
Normal file
15
layouts/letter/single.html
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
{{ partial "base/header.html" . }}
|
||||||
|
|
||||||
|
{{ partial "resume/print-icon.html" . }}
|
||||||
|
|
||||||
|
{{ partial "base/site-title.html" . }}
|
||||||
|
|
||||||
|
{{ partial "resume/contact-info.html" . }}
|
||||||
|
|
||||||
|
<div id="resume" class="letter">
|
||||||
|
{{ .Content }}
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</body>
|
||||||
|
</html>
|
||||||
@@ -29,7 +29,7 @@
|
|||||||
<img src="{{ "img/social/email.svg" | relURL }}"
|
<img src="{{ "img/social/email.svg" | relURL }}"
|
||||||
alt="envelope">
|
alt="envelope">
|
||||||
</a>
|
</a>
|
||||||
<a href="https://fosstodon.org/web/accounts/93113" target="_blank">
|
<a href="https://fosstodon.org/@Kevin" target="_blank">
|
||||||
<img src="{{ "img/social/mastodon.svg" | relURL }}"
|
<img src="{{ "img/social/mastodon.svg" | relURL }}"
|
||||||
alt="mastodon-logo">
|
alt="mastodon-logo">
|
||||||
</a>
|
</a>
|
||||||
|
|||||||
@@ -12,13 +12,13 @@
|
|||||||
{{ .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="http://livejs.com/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>
|
||||||
<script src="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/js/bootstrap.min.js" integrity="sha384-JjSmVgyd0p3pXB1rRibZUAYoIIy6OrQ6VrjIEaFf/nJGzIxFDsf4x0xIM+B07jRM" crossorigin="anonymous"></script>
|
<script src="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/js/bootstrap.min.js" integrity="sha384-JjSmVgyd0p3pXB1rRibZUAYoIIy6OrQ6VrjIEaFf/nJGzIxFDsf4x0xIM+B07jRM" crossorigin="anonymous"></script>
|
||||||
<!-- <link rel="stylesheet" href="https://fonts.googleapis.com/css?family=Source+Code+Pro:400,700" type="text/css"> -->
|
<!-- <link rel="stylesheet" href="https://fonts.googleapis.com/css?family=Source+Code+Pro:400,700" type="text/css"> -->
|
||||||
<link rel='stylesheet' href='//cdn.jsdelivr.net/npm/hack-font@3.3.0/build/web/hack-subset.css'>
|
<!-- <link rel='stylesheet' href='//cdn.jsdelivr.net/npm/hack-font@3.3.0/build/web/hack-subset.css'> -->
|
||||||
<!-- <link rel="stylesheet" href="https://meyerweb.com/eric/tools/css/reset/reset.css" type="text/css" media="all" /> -->
|
<!-- <link rel="stylesheet" href="https://meyerweb.com/eric/tools/css/reset/reset.css" type="text/css" media="all" /> -->
|
||||||
<link rel="stylesheet" href="{{ "css/style.css" | relURL }}" type="text/css">
|
<link rel="stylesheet" href="{{ "css/style.css" | relURL }}" type="text/css">
|
||||||
{{ $main_sass := resources.Get "sass/main.scss" }}
|
{{ $main_sass := resources.Get "sass/main.scss" }}
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
<div id="contact-info" class="container">
|
<div id="contact-info" class="container">
|
||||||
<div class="row row-top justify-content-center">
|
<div class="row row-top justify-content-center mx-auto">
|
||||||
<div id="phone-number" class="col text-left">
|
<div id="phone-number" class="col text-left">
|
||||||
<a href="tel:647-685-2500" target="_blank">
|
<a href="tel:647-685-2500" target="_blank">
|
||||||
<img src="{{ "img/resume/smartphone.svg" | relURL }}"
|
<img src="{{ "img/resume/smartphone.svg" | relURL }}"
|
||||||
@@ -10,7 +10,7 @@
|
|||||||
</a>
|
</a>
|
||||||
</div>
|
</div>
|
||||||
<div id="linkedin" class="col text-right">
|
<div id="linkedin" class="col text-right">
|
||||||
<a href="https://www.linkedin.com/in/Kev-Mok">
|
<a href="https://www.linkedin.com/in/Kev-Mok" target="_blank">
|
||||||
<span class="url-info">
|
<span class="url-info">
|
||||||
Kev-Mok
|
Kev-Mok
|
||||||
</span>
|
</span>
|
||||||
@@ -18,9 +18,9 @@
|
|||||||
</a>
|
</a>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="row justify-content-center">
|
<div class="row mx-auto">
|
||||||
<div id="email" class="col col-left">
|
<div id="email" class="col col-left">
|
||||||
<a href="mailto:me@kevin-mok.com">
|
<a href="mailto:me@kevin-mok.com" target="_blank">
|
||||||
<img src="{{ "img/resume/envelope.svg" | relURL }}" alt="envelope-icon">
|
<img src="{{ "img/resume/envelope.svg" | relURL }}" alt="envelope-icon">
|
||||||
<span class="url-info">
|
<span class="url-info">
|
||||||
me@kevin-mok.com
|
me@kevin-mok.com
|
||||||
@@ -28,7 +28,7 @@
|
|||||||
</a>
|
</a>
|
||||||
</div>
|
</div>
|
||||||
<div id="website" class="col text-right">
|
<div id="website" class="col text-right">
|
||||||
<a href="https://kevin-mok.com/">
|
<a href="https://kevin-mok.com/" target="_blank">
|
||||||
<span class="url-info">
|
<span class="url-info">
|
||||||
kevin-mok.com
|
kevin-mok.com
|
||||||
</span>
|
</span>
|
||||||
|
|||||||
4
layouts/shortcodes/resume/no-spacing.html
Normal file
4
layouts/shortcodes/resume/no-spacing.html
Normal file
@@ -0,0 +1,4 @@
|
|||||||
|
{{ $_hugo_config := `{ "version": 1 }` }}
|
||||||
|
<div class="no-line-spacing">
|
||||||
|
{{ .Inner }}
|
||||||
|
</div>
|
||||||
@@ -1,23 +1,20 @@
|
|||||||
<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> -->
|
||||||
<a class="project-link" href="{{ .Get "url" }}" target="_blank">
|
<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.svg" | relURL }}" alt="link-icon"> -->
|
<!-- <img class="down-triangle" src="{{ "img/resume/down-triangle.svg" | relURL }}" alt="link-icon"> -->
|
||||||
<img class="down-triangle" src="{{ "img/resume/down-triangle.png" | relURL }}" alt="link-icon">
|
<!-- <img class="down-triangle" src="{{ "img/resume/down-triangle.png" | relURL }}" alt="link-icon"> -->
|
||||||
</h2>
|
</h2>
|
||||||
</button>
|
</a>
|
||||||
</div>
|
</div>
|
||||||
<div class="col-4 text-right date">{{ .Get "date" }}</div>
|
<div class="col-4 text-right date">{{ .Get "date" }}</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="collapse{{ with .Get "show" }} show{{ end }}" id="{{ .Get "name" | lower | urlize }}-details">
|
<div class="show" id="{{ .Get "name" | lower | urlize }}-details">
|
||||||
<!-- <div class="show" id="{{ .Get "name" | lower | urlize }}-details"> -->
|
|
||||||
<div>
|
<div>
|
||||||
{{ .Inner }}
|
{{ .Inner }}
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
21
layouts/sitemap.xml
Normal file
21
layouts/sitemap.xml
Normal file
@@ -0,0 +1,21 @@
|
|||||||
|
<urlset xmlns="http://www.sitemaps.org/schemas/sitemap/0.9"
|
||||||
|
xmlns:xhtml="http://www.w3.org/1999/xhtml">
|
||||||
|
{{ range .Data.Pages }}{{ if ne .Params.sitemap_exclude true }}
|
||||||
|
<url>
|
||||||
|
<loc>{{ .Permalink }}</loc>{{ if not .Lastmod.IsZero }}
|
||||||
|
<lastmod>{{ safeHTML ( .Lastmod.Format "2006-01-02T15:04:05-07:00" ) }}</lastmod>{{ end }}{{ with .Sitemap.ChangeFreq }}
|
||||||
|
<changefreq>{{ . }}</changefreq>{{ end }}{{ if ge .Sitemap.Priority 0.0 }}
|
||||||
|
<priority>{{ .Sitemap.Priority }}</priority>{{ end }}{{ if .IsTranslated }}{{ range .Translations }}
|
||||||
|
<xhtml:link
|
||||||
|
rel="alternate"
|
||||||
|
hreflang="{{ .Lang }}"
|
||||||
|
href="{{ .Permalink }}"
|
||||||
|
/>{{ end }}
|
||||||
|
<xhtml:link
|
||||||
|
rel="alternate"
|
||||||
|
hreflang="{{ .Lang }}"
|
||||||
|
href="{{ .Permalink }}"
|
||||||
|
/>{{ end }}
|
||||||
|
</url>
|
||||||
|
{{ end }}{{ end }}
|
||||||
|
</urlset>
|
||||||
BIN
static/img/resume/signature-white.png
Normal file
BIN
static/img/resume/signature-white.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 465 KiB |
BIN
static/img/resume/signature.png
Normal file
BIN
static/img/resume/signature.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 467 KiB |
Binary file not shown.
Reference in New Issue
Block a user