Compare commits
4 Commits
resume-pdf
...
tr-letter
| Author | SHA1 | Date | |
|---|---|---|---|
|
a19c6fb921
|
|||
|
e5579a0e77
|
|||
|
5e7fe99969
|
|||
|
2305b246c1
|
7
.gitmodules
vendored
Normal file
7
.gitmodules
vendored
Normal file
@@ -0,0 +1,7 @@
|
|||||||
|
[submodule "content/letter"]
|
||||||
|
path = content/letter
|
||||||
|
url = ssh://git@git.kevin-mok.com:399/Kevin-Mok/cover-letters.git
|
||||||
|
branch = master
|
||||||
|
[submodule "static/pdf"]
|
||||||
|
path = static/pdf
|
||||||
|
url = ssh://git@git.kevin-mok.com:399/Kevin-Mok/resume-pdf.git
|
||||||
@@ -88,6 +88,15 @@ $vert-phone-width: 500px;
|
|||||||
}
|
}
|
||||||
}// }}}
|
}// }}}
|
||||||
|
|
||||||
|
@mixin a-no-underline() {// {{{
|
||||||
|
a {
|
||||||
|
text-decoration: none;
|
||||||
|
&:hover {
|
||||||
|
text-decoration: none;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}// }}}
|
||||||
|
|
||||||
// }}} mixins //
|
// }}} mixins //
|
||||||
|
|
||||||
// general elements {{{ //
|
// general elements {{{ //
|
||||||
@@ -104,7 +113,8 @@ body {
|
|||||||
line-height: 1.5;
|
line-height: 1.5;
|
||||||
// font-size: 100%;
|
// font-size: 100%;
|
||||||
font-size: 15px;
|
font-size: 15px;
|
||||||
/* font-family: 'Source Code Pro', monospace; */
|
// font-size: 25px;
|
||||||
|
// font-family: 'Hack Nerd Font Mono', monospace;
|
||||||
font-family: 'Hack', monospace;
|
font-family: 'Hack', monospace;
|
||||||
display: flex;
|
display: flex;
|
||||||
flex-direction: column;
|
flex-direction: column;
|
||||||
@@ -205,12 +215,17 @@ footer {
|
|||||||
position: relative;
|
position: relative;
|
||||||
padding-right: $side-padding;
|
padding-right: $side-padding;
|
||||||
// padding-right: .9em;
|
// padding-right: .9em;
|
||||||
|
@include a-no-underline();
|
||||||
|
|
||||||
img {
|
img {
|
||||||
height: 1.5em;
|
height: 1.5em;
|
||||||
@include vert-margin-rem(.2);
|
@include vert-margin-rem(.2);
|
||||||
padding-left: .5em;
|
padding-left: .5em;
|
||||||
opacity: .6;
|
opacity: .6;
|
||||||
|
|
||||||
|
&:hover {
|
||||||
|
opacity: 1;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -474,22 +489,23 @@ header {// {{{
|
|||||||
float: right;
|
float: right;
|
||||||
|
|
||||||
img {
|
img {
|
||||||
height: 1.75em;
|
height: 2em !important;
|
||||||
position: relative;
|
position: absolute;
|
||||||
top: 1em;
|
top: 1em;
|
||||||
}
|
}
|
||||||
}// }}}
|
}// }}}
|
||||||
|
|
||||||
#contact-info {// {{{
|
#contact-info {// {{{
|
||||||
@include side-margin-em(0);
|
@include side-margin-em(0);
|
||||||
|
@include side-padding-rem(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);
|
||||||
|
width: 100%;
|
||||||
|
// @media (min-width: 1200px) {
|
||||||
|
// .container{
|
||||||
// min-width: $max-page-width;
|
// min-width: $max-page-width;
|
||||||
@media (min-width: 1200px) {
|
// }
|
||||||
.container{
|
// }
|
||||||
min-width: $max-page-width;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
font-size: .9em;
|
font-size: .9em;
|
||||||
|
|
||||||
@@ -643,6 +659,45 @@ header {// {{{
|
|||||||
// font-size: 1em;
|
// font-size: 1em;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
&.letter {
|
||||||
|
margin-top: 2em;
|
||||||
|
// font-size: 21px;
|
||||||
|
|
||||||
|
img {
|
||||||
|
height: 4.5em;
|
||||||
|
}
|
||||||
|
|
||||||
|
h2 {
|
||||||
|
color: $base-red;
|
||||||
|
// font-size: 30px;
|
||||||
|
// margin-top: 0em;
|
||||||
|
// margin-top: .5em;
|
||||||
|
// margin-top: 1.25em;
|
||||||
|
// margin-bottom: 1em;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
p {
|
||||||
|
margin-bottom: 1.5em;
|
||||||
|
// margin-bottom: 1em;
|
||||||
|
}
|
||||||
|
|
||||||
|
ul {
|
||||||
|
// margin-bottom: 1.5em;
|
||||||
|
margin-bottom: 2em;
|
||||||
|
}
|
||||||
|
|
||||||
|
.no-line-spacing {
|
||||||
|
line-height: .5em;
|
||||||
|
margin-bottom: 2.15em;
|
||||||
|
p {
|
||||||
|
margin-bottom: 1em;
|
||||||
|
}
|
||||||
|
strong {
|
||||||
|
line-height: 1.25em;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}// }}}
|
}// }}}
|
||||||
|
|
||||||
#server {// {{{
|
#server {// {{{
|
||||||
@@ -847,6 +902,16 @@ header {// {{{
|
|||||||
}// }}}
|
}// }}}
|
||||||
}// }}}
|
}// }}}
|
||||||
|
|
||||||
|
#letter-home {// {{{
|
||||||
|
|
||||||
|
#letter-instr {
|
||||||
|
text-align: center;
|
||||||
|
margin-top: 1.5em;
|
||||||
|
// margin-top: 25vh;
|
||||||
|
font-size: 1.4em;
|
||||||
|
}
|
||||||
|
}// }}}
|
||||||
|
|
||||||
// TODO: converted up to here
|
// TODO: converted up to here
|
||||||
|
|
||||||
// hero {{{ //
|
// hero {{{ //
|
||||||
@@ -869,16 +934,16 @@ h1.site-title {// {{{
|
|||||||
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 {
|
||||||
|
|||||||
17
config.yaml
17
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
|
||||||
@@ -29,11 +29,20 @@ menu:
|
|||||||
- name: card
|
- name: card
|
||||||
url: /card
|
url: /card
|
||||||
weight: 15
|
weight: 15
|
||||||
|
# - name: letter
|
||||||
|
# url: /letter
|
||||||
|
# weight: 17
|
||||||
# - name: credits
|
# - name: credits
|
||||||
# url: /credits
|
# url: /credits
|
||||||
# weight: 20
|
# weight: 20
|
||||||
|
|
||||||
blackfriday:
|
# blackfriday:
|
||||||
plainIDAnchors: true
|
# plainIDAnchors: true
|
||||||
hrefTargetBlank: true
|
# hrefTargetBlank: true
|
||||||
|
|
||||||
|
disableKinds: ["RSS"]
|
||||||
|
|
||||||
|
markup:
|
||||||
|
goldmark:
|
||||||
|
renderer:
|
||||||
|
unsafe: true
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
---
|
---
|
||||||
title: "Digital Card"
|
title: "Digital Card"
|
||||||
date: 2019-02-11T07:50:51-05:00
|
date: 2019-02-11T07:50:51-05:00
|
||||||
draft: true
|
draft: false
|
||||||
---
|
---
|
||||||
|
|||||||
@@ -39,5 +39,4 @@ a single branch.
|
|||||||
|
|
||||||
[chezmoi]: https://github.com/twpayne/chezmoi
|
[chezmoi]: https://github.com/twpayne/chezmoi
|
||||||
|
|
||||||
|
|
||||||
<!--- }}} Setup -->
|
<!--- }}} Setup -->
|
||||||
|
|||||||
1
content/letter
Submodule
1
content/letter
Submodule
Submodule content/letter added at 42716f4487
@@ -3,19 +3,10 @@ title: "Resume"
|
|||||||
date: 2019-02-11T07:50:51-05:00
|
date: 2019-02-11T07:50:51-05:00
|
||||||
draft: false
|
draft: false
|
||||||
---
|
---
|
||||||
{{% resume/section overview %}}<!--- {{{ -->
|
|
||||||
|
|
||||||
3<sup>rd</sup> year CS student. Enthusiast of all things
|
|
||||||
Linux and FOSS. Seeking 16-month internship for my PEY
|
|
||||||
co-op program. Looking to gain industry-relevant experience in
|
|
||||||
full-stack web dev, DevOps or system administration.
|
|
||||||
|
|
||||||
{{% /resume/section %}}<!--- }}} -->
|
|
||||||
|
|
||||||
{{% resume/section skills %}}<!--- {{{ -->
|
{{% resume/section skills %}}<!--- {{{ -->
|
||||||
|
|
||||||
#### Languages
|
#### Languages
|
||||||
- **Bash**, C, **CSS**, C++, **Fish** (shell), Godot, **HTML5**,
|
- **Bash**, **C**, **CSS**, C++, **Fish** (shell), Godot, **HTML5**,
|
||||||
**Python**, Java, **Javascript** (ES6), **Sass**
|
**Python**, Java, **Javascript** (ES6), **Sass**
|
||||||
|
|
||||||
#### Frameworks
|
#### Frameworks
|
||||||
@@ -26,8 +17,8 @@ full-stack web dev, DevOps or system administration.
|
|||||||
|
|
||||||
#### Tools
|
#### Tools
|
||||||
- **Arch Linux**, Android Studio, **Debian**, **Command Line**,
|
- **Arch Linux**, Android Studio, **Debian**, **Command Line**,
|
||||||
**Git**, IntelliJ IDEA, **Pycharm**, **NGINX**, **SFTP**, **SSH**,
|
**Git**, IntelliJ IDEA, **Pycharm**, **NGINX**, npm/yarn, **SFTP**,
|
||||||
**Vim**
|
**SSH**, **Vim**
|
||||||
|
|
||||||
{{% /resume/section %}}<!--- }}} -->
|
{{% /resume/section %}}<!--- }}} -->
|
||||||
|
|
||||||
@@ -44,8 +35,9 @@ show="true" %}}
|
|||||||
into **PostgreSQL** database with **Django** backend.
|
into **PostgreSQL** database with **Django** backend.
|
||||||
- Created and tested various relational database schemas to maximize
|
- Created and tested various relational database schemas to maximize
|
||||||
efficiency for use cases.
|
efficiency for use cases.
|
||||||
- Produced bubble chart and (stacked) bar chart using [**d3**]
|
- Produced bubble chart and (stacked) bar chart using
|
||||||
[d3 graph examples] to visualize the artists, genres and features of
|
[**d3**][d3 graph examples] to visualize the artists,
|
||||||
|
genres and features of
|
||||||
tracks in library.
|
tracks in library.
|
||||||
|
|
||||||
[d3 graph examples]: https://github.com/d3/d3/wiki/Gallery
|
[d3 graph examples]: https://github.com/d3/d3/wiki/Gallery
|
||||||
|
|||||||
@@ -1,4 +1,12 @@
|
|||||||
|
// vim: ft=markdown
|
||||||
|
|
||||||
- bg colors
|
- bg colors
|
||||||
|
|
||||||
|
# Resume
|
||||||
- site title max width
|
- site title max width
|
||||||
- switch project shortcode
|
- switch project shortcode
|
||||||
- rm details top margin
|
- rm details top margin
|
||||||
|
|
||||||
|
# Letter
|
||||||
|
- letter font size
|
||||||
|
- h2
|
||||||
|
|||||||
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>
|
||||||
13
layouts/letter/single.html
Normal file
13
layouts/letter/single.html
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
{{ partial "base/header.html" . }}
|
||||||
|
|
||||||
|
{{ partial "base/site-title.html" . }}
|
||||||
|
|
||||||
|
{{ partial "resume/contact-info.html" . }}
|
||||||
|
|
||||||
|
<div id="resume" class="letter">
|
||||||
|
{{ .Content }}
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</body>
|
||||||
|
</html>
|
||||||
@@ -1,7 +1,7 @@
|
|||||||
<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 3<sup>rd</sup> year Computer Science
|
I'm Kevin Mok - a Computer Science
|
||||||
student at the University of Toronto, and I'm greatly interested in all things Linux and
|
student at the University of Toronto, and I'm greatly interested in all things Linux and
|
||||||
<a href="https://www.gnu.org/philosophy/floss-and-foss.en.html"
|
<a href="https://www.gnu.org/philosophy/floss-and-foss.en.html"
|
||||||
target="_blank">FOSS/FLOSS</a>.
|
target="_blank">FOSS/FLOSS</a>.
|
||||||
|
|||||||
@@ -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 }}"
|
||||||
@@ -18,7 +18,7 @@
|
|||||||
</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" target="_blank">
|
<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">
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
<div id="print-icon">
|
<div id="print-icon">
|
||||||
<a href="{{ "kevin-mok-resume.pdf" | relURL }}" target="_blank">
|
<a href="{{ "pdf/kevin-mok-resume.pdf" | relURL }}" target="_blank">
|
||||||
<img src="{{ "img/resume/printer.svg" | relURL }}" alt="printer-icon">
|
<img src="{{ "img/resume/printer.svg" | relURL }}" alt="printer-icon">
|
||||||
</a>
|
</a>
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
8
layouts/shortcodes/resume/letter-print.html
Normal file
8
layouts/shortcodes/resume/letter-print.html
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
<div id="print-icon">
|
||||||
|
{{ $type := .Get "type" }}
|
||||||
|
{{ $code := .Get "code" }}
|
||||||
|
{{ $pdfName := print "pdf/kevin-mok-" $type "-" $code ".pdf" }}
|
||||||
|
<a href="{{ $pdfName | relURL }}" target="_blank">
|
||||||
|
<img src="{{ "img/resume/printer.svg" | relURL }}" alt="printer-icon">
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
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>
|
||||||
@@ -9,7 +9,6 @@
|
|||||||
aria-expanded="false" aria-controls="{{ .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.png" | relURL }}" alt="link-icon">
|
<img class="down-triangle" src="{{ "img/resume/down-triangle.png" | relURL }}" alt="link-icon">
|
||||||
</h2>
|
</h2>
|
||||||
</button>
|
</button>
|
||||||
@@ -17,7 +16,6 @@
|
|||||||
<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="collapse{{ with .Get "show" }} show{{ end }}" 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.
1
static/pdf
Submodule
1
static/pdf
Submodule
Submodule static/pdf added at 803aa46cb9
@@ -38,6 +38,9 @@ const generateTable = (table, data) => {
|
|||||||
aElem.textContent = elem['shortUrl']
|
aElem.textContent = elem['shortUrl']
|
||||||
cell.appendChild(aElem)
|
cell.appendChild(aElem)
|
||||||
break
|
break
|
||||||
|
case 'description':
|
||||||
|
cell.innerHTML = elem[key]
|
||||||
|
break
|
||||||
case 'repo':
|
case 'repo':
|
||||||
aElem.href = elem['repoUrl']
|
aElem.href = elem['repoUrl']
|
||||||
aElem.textContent = elem[key]
|
aElem.textContent = elem[key]
|
||||||
|
|||||||
Reference in New Issue
Block a user