Added custom Twig globals, functions. Added Profile icon renderers.
This commit is contained in:
parent
85e463c82f
commit
f94d82770e
19
app/App.php
19
app/App.php
|
@ -69,10 +69,23 @@ class App extends Application {
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return \Noodlehaus\Config
|
* Registers media icons
|
||||||
|
*
|
||||||
|
* @param \Sikofitt\Image\Profile\ProfileIconInterface $icon
|
||||||
*/
|
*/
|
||||||
public function conf2() {
|
public function registerIcon(\Sikofitt\Image\Profile\ProfileIconInterface $icon)
|
||||||
return Noodlehaus\Config::load($this->getConfDirectory());
|
{
|
||||||
|
$this->config(sprintf('app.icons.%s', $icon->getName()), ['icon' => $icon->getIcon(), 'url' => $icon->getDefaultUrl()]);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function boot() {
|
||||||
|
// register default icons
|
||||||
|
$this->registerIcon(new \Sikofitt\Image\Profile\TwitterProfileIcon());
|
||||||
|
$this->registerIcon(new \Sikofitt\Image\Profile\FacebookProfileIcon());
|
||||||
|
$this->registerIcon(new \Sikofitt\Image\Profile\GithubProfileIcon());
|
||||||
|
$this->registerIcon(new \Sikofitt\Image\Profile\GitlabProfileIcon());
|
||||||
|
$this->registerIcon(new \Sikofitt\Image\Profile\LinkedinProfileIcon());
|
||||||
|
return parent::boot();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -4,64 +4,162 @@
|
||||||
{{ app.config.app.title | default('Resume') }}
|
{{ app.config.app.title | default('Resume') }}
|
||||||
{% endblock %}
|
{% endblock %}
|
||||||
{% block body %}
|
{% block body %}
|
||||||
{{ dump(basics) }}
|
|
||||||
|
|
||||||
<div class="uk-grid" data-uk-grid-margin>
|
<div class="uk-grid" data-uk-grid-margin>
|
||||||
<div class="uk-width-1-1">
|
<div class="uk-width-1-1">
|
||||||
<h1 class="uk-heading-large" data-uk-sticky="{top:35}">
|
<h1 class="uk-heading-large">
|
||||||
{% if basics.name is not empty %}
|
{% if basics.name is not empty %}
|
||||||
{{ basics.name }}
|
{{ basics.name }}
|
||||||
{% else %}
|
{% else %}
|
||||||
{{ app.config.app.title|default('Resume') }}
|
{{ app.config.app.title|default('Resume') }}
|
||||||
{% endif %}
|
{% endif %}
|
||||||
{% if basics.label is not empty %}
|
{% if basics.label is not empty %}
|
||||||
<small class="uk-h2">{{ basics.label }}</small>
|
<small class="uk-h2 uk-align-right uk-text-bottom">{{ basics.label }}</small>
|
||||||
{% endif %}
|
|
||||||
</h1>
|
|
||||||
<hr />
|
|
||||||
{% if basics.summary is not empty %}
|
|
||||||
<p class="uk-text-large">
|
|
||||||
|
|
||||||
{{ basics.summary }}
|
|
||||||
</p>
|
|
||||||
{% endif %}
|
{% endif %}
|
||||||
|
</h1>
|
||||||
|
<hr/>
|
||||||
|
{% if basics.summary is not empty %}
|
||||||
|
<p class="uk-text-lead">{{ basics.summary }}</p>
|
||||||
|
{% endif %}
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="uk-grid" data-uk-grid-margin>
|
<div class="uk-grid" data-uk-grid-margin>
|
||||||
<div class="uk-width-medium-3-4">
|
<div class="uk-width-medium-3-4">
|
||||||
{% set position = work|first %}
|
<h1>Experience</h1>
|
||||||
{{ dump(position) }}
|
<div class="uk-panel uk-panel-header">
|
||||||
<p class="resume-positions">Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Aenean commodo ligula eget dolor.
|
|
||||||
Aenean massa. Cum sociis natoque penatibus et magnis dis parturient montes, nascetur ridiculus mus.
|
|
||||||
Donec quam felis, ultricies nec, pellentesque eu, pretium quis, sem. Nulla consequat massa quis enim.
|
|
||||||
</p>
|
|
||||||
|
|
||||||
|
<div class="resume-positions">
|
||||||
|
{% for position in work %}
|
||||||
|
<h3 class="company uk-panel-title uk-animation-slide-left">
|
||||||
|
{{ position.company }}
|
||||||
|
<small class="uk-align-right">
|
||||||
|
{{ position.startDate|date('Y') }} -
|
||||||
|
{% if position.endDate is not defined %}
|
||||||
|
Current
|
||||||
|
{% else %}
|
||||||
|
{{ position.endDate|date('Y') }}
|
||||||
|
{% endif %}
|
||||||
|
|
||||||
|
(~
|
||||||
|
{% if position.endDate is not defined %}
|
||||||
|
{{ position.startDate|date_diff }}
|
||||||
|
{% else %}
|
||||||
|
{{ position.startDate|date_diff(position.endDate) }}
|
||||||
|
{% endif %}
|
||||||
|
)
|
||||||
|
</small>
|
||||||
|
</h3>
|
||||||
|
<h5>{{ position.position }}</h5>
|
||||||
|
<p class="summary uk-text-primary uk-text-large">
|
||||||
|
{{ position.summary|raw }}
|
||||||
|
</p>
|
||||||
|
|
||||||
|
|
||||||
|
{% if position.highlights is not empty and position.highlights is defined %}
|
||||||
|
<dl class="uk-description-list-horizontal uk-animation-slide-right">
|
||||||
|
<dt>Highlights</dt>
|
||||||
|
{% for highlight in position.highlights %}
|
||||||
|
<dd class="uk-margin-small-top uk-margin-small-bottom">{{ highlight|raw }}</dd>
|
||||||
|
{% endfor %}
|
||||||
|
</dl>
|
||||||
|
{% endif %}
|
||||||
|
<hr class="uk-hr-light"/>
|
||||||
|
{% endfor %}
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
<div class="uk-width-medium-1-4">
|
<div class="uk-width-medium-1-4">
|
||||||
|
|
||||||
<div class="uk-panel uk-panel-box" data-uk-sticky="{top:35}">
|
<div class="uk-panel uk-panel-header uk-panel-box" data-uk-sticky="{top:35}">
|
||||||
|
|
||||||
<div class="uk-panel-header"><h3 class="uk-panel-title">Contact<img class="uk-align-right uk-thumbnail uk-border-circle uk-thumbnail-mini uk-animation-scale-up uk-img-preserve" src="{{ basics.picture }}"/></h3></div>
|
|
||||||
<!--
|
<div class="uk-panel-image">
|
||||||
--><ul class="uk-list uk-list-line uk-h5">
|
<img class="uk-align-right uk-thumbnail uk-border-circle uk-thumbnail-mini uk-animation-scale-up uk-img-preserve"
|
||||||
|
src="{{ basics.picture }}"/>
|
||||||
|
</div>
|
||||||
|
<h3 class="uk-panel-title">Contact</h3>
|
||||||
|
|
||||||
|
<ul class="uk-list uk-list-line">
|
||||||
|
|
||||||
{% if basics.email is not empty %}
|
{% if basics.email is not empty %}
|
||||||
<li><a href="#" class="hidden-email">[Click to view email]</a></li>
|
<li class="uk-list-space"><a href="#" class="hidden-email">[Click to view email]</a></li>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
{% if basics.phone is not empty %}
|
{% if basics.phone is not empty %}
|
||||||
<li>{{ basics.phone }}</li>
|
<li class="uk-list-space">{{ basics.phone }}</li>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
{% if basics.website is not empty %}
|
{% if basics.website is not empty %}
|
||||||
<li><a href="{{ basics.website }}" target="_blank" title="Home page">{{ basics.website }}</a></li>
|
<li class="uk-list-space"><a href="{{ basics.website }}" target="_blank"
|
||||||
{% endif %}
|
title="Home page">{{ basics.website }}</a></li>
|
||||||
|
{% endif %}
|
||||||
{% if basics.location|length > 0 and basics.location is not empty %}
|
{% if basics.location|length > 0 and basics.location is not empty %}
|
||||||
<li>
|
<li class="uk-list-space">
|
||||||
<address>
|
<address>
|
||||||
{% set location = basics.location %}
|
{% set location = basics.location %}
|
||||||
|
|
||||||
|
{% if location.address is not empty %}
|
||||||
|
{{ location.address }}<br/>
|
||||||
|
{% endif %}
|
||||||
|
{% if location.city is not empty %}
|
||||||
|
{{ location.city }},
|
||||||
|
{% endif %}
|
||||||
|
{% if location.region is not empty %}
|
||||||
|
{{ location.region }},
|
||||||
|
{% endif %}
|
||||||
|
{% if location.countryCode is not empty %}
|
||||||
|
{{ location.countryCode }}
|
||||||
|
{% endif %}<br/>
|
||||||
|
|
||||||
|
</address>
|
||||||
|
</li>
|
||||||
|
{% endif %}
|
||||||
|
<li class="uk-list-space">
|
||||||
|
{% for profile in basics.profiles %}
|
||||||
|
{{ render_profile(profile)|raw }}
|
||||||
|
{% endfor %}
|
||||||
|
|
||||||
|
</li>
|
||||||
|
<li class="uk-list-divider"></li>
|
||||||
|
</ul>
|
||||||
|
{% if skills is defined and skills is not empty %}
|
||||||
|
|
||||||
|
<h3 class="uk-panel-title">Skills</h3>
|
||||||
|
|
||||||
|
<dl class="uk-description-list-line">
|
||||||
|
{% for skill in skills %}
|
||||||
|
<dt class="uk-text-bold">{{ skill.name }}</dt>
|
||||||
|
<dd>{{ skill.keywords|join(', ')|raw }}</dd>
|
||||||
|
{% endfor %}
|
||||||
|
</dl>
|
||||||
|
|
||||||
|
{% endif %}
|
||||||
|
|
||||||
|
|
||||||
|
</div>
|
||||||
|
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div id="offcanvas" class="uk-offcanvas">
|
||||||
|
<div class="uk-offcanvas-bar">
|
||||||
|
<ul class="uk-list uk-list-line">
|
||||||
|
{% if basics.email is not empty %}
|
||||||
|
<li>{{ basics.email }}</li>
|
||||||
|
{% endif %}
|
||||||
|
{% if basics.phone is not empty %}
|
||||||
|
<li>{{ basics.phone }}</li>
|
||||||
|
{% endif %}
|
||||||
|
{% if basics.location|length > 0 and basics.location is not empty %}
|
||||||
|
<li>
|
||||||
|
<address>
|
||||||
|
{% for location in basics.location %}
|
||||||
{% if location.address is not empty %}
|
{% if location.address is not empty %}
|
||||||
{{ location.address }}<br />
|
{{ location.address }}<br/>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
{% if location.city is not empty %}
|
{% if location.city is not empty %}
|
||||||
{{ location.city }}
|
{{ location.city }}
|
||||||
|
@ -70,49 +168,16 @@
|
||||||
{% endif %}
|
{% endif %}
|
||||||
{% if location.countryCode is not empty %}
|
{% if location.countryCode is not empty %}
|
||||||
{{ location.countryCode }}
|
{{ location.countryCode }}
|
||||||
{% endif %}<br />
|
{% endif %}<br/>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
|
{% endfor %}
|
||||||
</address>
|
</address>
|
||||||
</li>
|
</li>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
|
<li>
|
||||||
|
|
||||||
</ul>
|
</li>
|
||||||
</div>
|
</ul>
|
||||||
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
|
||||||
|
|
||||||
<div id="offcanvas" class="uk-offcanvas">
|
|
||||||
<div class="uk-offcanvas-bar">
|
|
||||||
<ul class="uk-list uk-list-line">
|
|
||||||
{% if basics.email is not empty %}
|
|
||||||
<li>{{ basics.email }}</li>
|
|
||||||
{% endif %}
|
|
||||||
{% if basics.phone is not empty %}
|
|
||||||
<li>{{ basics.phone }}</li>
|
|
||||||
{% endif %}
|
|
||||||
{% if basics.location|length > 0 and basics.location is not empty %}
|
|
||||||
<address>
|
|
||||||
{% for location in basics.location %}
|
|
||||||
{% if location.address is not empty %}
|
|
||||||
{{ location.address }}<br />
|
|
||||||
{% endif %}
|
|
||||||
{% if location.city is not empty %}
|
|
||||||
{{ location.city }}
|
|
||||||
{% if location.postalCode is not empty %}
|
|
||||||
{{ location.postalCode }}
|
|
||||||
{% endif %}
|
|
||||||
{% if location.countryCode is not empty %}
|
|
||||||
{{ location.countryCode }}
|
|
||||||
{% endif %}<br />
|
|
||||||
{% endif %}
|
|
||||||
|
|
||||||
{% endfor %}
|
|
||||||
{% endif %}
|
|
||||||
</address>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
{% endblock %}
|
{% endblock %}
|
|
@ -38,7 +38,8 @@
|
||||||
"symfony/monolog-bridge": "^3.1",
|
"symfony/monolog-bridge": "^3.1",
|
||||||
"google/recaptcha": "^1.1",
|
"google/recaptcha": "^1.1",
|
||||||
"hassankhan/config": "^0.10.0",
|
"hassankhan/config": "^0.10.0",
|
||||||
"silex/web-profiler": "^2.0"
|
"silex/web-profiler": "^2.0",
|
||||||
|
"twig/extensions": "^1.3"
|
||||||
},
|
},
|
||||||
"require-dev": {
|
"require-dev": {
|
||||||
"symfony/debug": "~2.8|^3.0",
|
"symfony/debug": "~2.8|^3.0",
|
||||||
|
|
|
@ -4,8 +4,8 @@
|
||||||
"Read more about it at https://getcomposer.org/doc/01-basic-usage.md#composer-lock-the-lock-file",
|
"Read more about it at https://getcomposer.org/doc/01-basic-usage.md#composer-lock-the-lock-file",
|
||||||
"This file is @generated automatically"
|
"This file is @generated automatically"
|
||||||
],
|
],
|
||||||
"hash": "b95f44a2d8bcbac673a62298f16f4ad9",
|
"hash": "d47e1d8d6470d4d29deb55649ecc969b",
|
||||||
"content-hash": "d0a7cfefe30599f33ddbe16cd3cce33d",
|
"content-hash": "3c41da3f56c72d6c1bc86d0a1889d6d9",
|
||||||
"packages": [
|
"packages": [
|
||||||
{
|
{
|
||||||
"name": "google/recaptcha",
|
"name": "google/recaptcha",
|
||||||
|
@ -2187,6 +2187,58 @@
|
||||||
"homepage": "https://symfony.com",
|
"homepage": "https://symfony.com",
|
||||||
"time": "2016-06-29 05:41:56"
|
"time": "2016-06-29 05:41:56"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"name": "twig/extensions",
|
||||||
|
"version": "v1.3.0",
|
||||||
|
"source": {
|
||||||
|
"type": "git",
|
||||||
|
"url": "https://github.com/twigphp/Twig-extensions.git",
|
||||||
|
"reference": "449e3c8a9ffad7c2479c7864557275a32b037499"
|
||||||
|
},
|
||||||
|
"dist": {
|
||||||
|
"type": "zip",
|
||||||
|
"url": "https://api.github.com/repos/twigphp/Twig-extensions/zipball/449e3c8a9ffad7c2479c7864557275a32b037499",
|
||||||
|
"reference": "449e3c8a9ffad7c2479c7864557275a32b037499",
|
||||||
|
"shasum": ""
|
||||||
|
},
|
||||||
|
"require": {
|
||||||
|
"twig/twig": "~1.20|~2.0"
|
||||||
|
},
|
||||||
|
"require-dev": {
|
||||||
|
"symfony/translation": "~2.3"
|
||||||
|
},
|
||||||
|
"suggest": {
|
||||||
|
"symfony/translation": "Allow the time_diff output to be translated"
|
||||||
|
},
|
||||||
|
"type": "library",
|
||||||
|
"extra": {
|
||||||
|
"branch-alias": {
|
||||||
|
"dev-master": "1.3-dev"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"autoload": {
|
||||||
|
"psr-0": {
|
||||||
|
"Twig_Extensions_": "lib/"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"notification-url": "https://packagist.org/downloads/",
|
||||||
|
"license": [
|
||||||
|
"MIT"
|
||||||
|
],
|
||||||
|
"authors": [
|
||||||
|
{
|
||||||
|
"name": "Fabien Potencier",
|
||||||
|
"email": "fabien@symfony.com"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"description": "Common additional features for Twig that do not directly belong in core",
|
||||||
|
"homepage": "http://twig.sensiolabs.org/doc/extensions/index.html",
|
||||||
|
"keywords": [
|
||||||
|
"i18n",
|
||||||
|
"text"
|
||||||
|
],
|
||||||
|
"time": "2015-08-22 16:38:35"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"name": "twig/twig",
|
"name": "twig/twig",
|
||||||
"version": "v1.24.1",
|
"version": "v1.24.1",
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
"email": "eric@ericwheeler.net",
|
"email": "eric@ericwheeler.net",
|
||||||
"phone": "",
|
"phone": "",
|
||||||
"website": "https://code.reric.me",
|
"website": "https://code.reric.me",
|
||||||
"summary": "",
|
"summary": "My name is Eric Wheeler. I enjoy programming, working on computer hardware/electronics, music and gardening.",
|
||||||
"location": {
|
"location": {
|
||||||
"address": "",
|
"address": "",
|
||||||
"postalCode": "CA 94578",
|
"postalCode": "CA 94578",
|
||||||
|
@ -18,7 +18,7 @@
|
||||||
{
|
{
|
||||||
"network": "Twitter",
|
"network": "Twitter",
|
||||||
"username": "sikofitt",
|
"username": "sikofitt",
|
||||||
"url": ""
|
"url": "https://twitter.com/sikofitt"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"network": "Github",
|
"network": "Github",
|
||||||
|
@ -26,7 +26,7 @@
|
||||||
"url": ""
|
"url": ""
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"network": "Private Git",
|
"network": "Gitlab",
|
||||||
"username": "sikofitt",
|
"username": "sikofitt",
|
||||||
"url": "https://repos.bgemi.net/u/sikofitt"
|
"url": "https://repos.bgemi.net/u/sikofitt"
|
||||||
},
|
},
|
||||||
|
@ -43,12 +43,12 @@
|
||||||
"position": "Developer / Systems Administrator",
|
"position": "Developer / Systems Administrator",
|
||||||
"website": "https://ee.stanford.edu",
|
"website": "https://ee.stanford.edu",
|
||||||
"startDate": "2007-05-27",
|
"startDate": "2007-05-27",
|
||||||
"endDate": "2016-07-02",
|
"summary": "I have done many different things during my employment at Stanford University.<br />A few of things things have been : Desktop Support, Computer cluster administration for the NSF and NNIN using Scyld Clusterware, General programing/debugging and frontend as well as backend web development using a number of different technologies.",
|
||||||
"summary": "",
|
|
||||||
"highlights": [
|
"highlights": [
|
||||||
"Build an algorithm for artist to detect if their music was violating copy right infringement laws",
|
"Upgraded and Maintained a 64 node research computing cluster for the NNIN funded by the <b>NSF</b>.",
|
||||||
"Successfully won Techcrunch Disrupt",
|
"Converted Electrical Engineering's static web site to Drupal 7.",
|
||||||
"Optimized an algorithm that holds the current world record for Weisman Scores"
|
"Created many Drupal 7 modules for the EE website including a custom events, lecture and committe minutes content type, a CDN module for uploading and recieving images/videos/documents, an Orglist module for displaying Faculty, Students, and Staff from a custom API.",
|
||||||
|
"Created a custom Drupal 7 site for the SystemX organization with integrated login for affiliates as well as Stanford staff."
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
@ -80,6 +80,22 @@
|
||||||
"Let's Encrypt"
|
"Let's Encrypt"
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"name": "PHP",
|
||||||
|
"level": "",
|
||||||
|
"keywords": [
|
||||||
|
"PHP5",
|
||||||
|
"PHP7",
|
||||||
|
"<b>Drupal 7</b>",
|
||||||
|
"Symfony 2",
|
||||||
|
"Symfony 3",
|
||||||
|
"OOP",
|
||||||
|
"Silex",
|
||||||
|
"Slim",
|
||||||
|
"Doctrine",
|
||||||
|
"Composer"
|
||||||
|
]
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"name": "PHP",
|
"name": "PHP",
|
||||||
"level": "",
|
"level": "",
|
||||||
|
@ -95,6 +111,7 @@
|
||||||
"Composer"
|
"Composer"
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|
||||||
],
|
],
|
||||||
"languages": [],
|
"languages": [],
|
||||||
"interests": [
|
"interests": [
|
||||||
|
|
File diff suppressed because one or more lines are too long
|
@ -0,0 +1,40 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* This file is part of test.
|
||||||
|
*
|
||||||
|
* @file GithubProfileIcon.php
|
||||||
|
*
|
||||||
|
* R. Eric Wheeler <reric@ee.stanford.edu>
|
||||||
|
*
|
||||||
|
* 7/7/16 / 9:18 AM
|
||||||
|
*
|
||||||
|
* For the full copyright and license information, please view the LICENSE
|
||||||
|
* file that was distributed with this source code.
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace Sikofitt\Image\Profile;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class GithubProfileIcon
|
||||||
|
* @package Sikofitt\Image\Profile
|
||||||
|
*/
|
||||||
|
class GithubProfileIcon implements ProfileIconInterface
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
public function getName() {
|
||||||
|
return 'github';
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getDefaultUrl() {
|
||||||
|
return 'https://github.com';
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
public function getIcon() {
|
||||||
|
return '';
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,40 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* This file is part of test.
|
||||||
|
*
|
||||||
|
* @file GitlabProfileIcon.php
|
||||||
|
*
|
||||||
|
* R. Eric Wheeler <reric@ee.stanford.edu>
|
||||||
|
*
|
||||||
|
* 7/7/16 / 9:36 AM
|
||||||
|
*
|
||||||
|
* For the full copyright and license information, please view the LICENSE
|
||||||
|
* file that was distributed with this source code.
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace Sikofitt\Image\Profile;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class GitlabProfileIcon
|
||||||
|
* @package Sikofitt\Image\Profile
|
||||||
|
*/
|
||||||
|
class GitlabProfileIcon implements ProfileIconInterface {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
public function getName() {
|
||||||
|
return 'gitlab';
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getDefaultUrl() {
|
||||||
|
return 'https://gitlab.com';
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
public function getIcon() {
|
||||||
|
return '';
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,31 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* This file is part of test.
|
||||||
|
*
|
||||||
|
* @file LinkedinProfileIcon.php
|
||||||
|
*
|
||||||
|
* R. Eric Wheeler <reric@ee.stanford.edu>
|
||||||
|
*
|
||||||
|
* 7/7/16 / 10:51 AM
|
||||||
|
*
|
||||||
|
* For the full copyright and license information, please view the LICENSE
|
||||||
|
* file that was distributed with this source code.
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace Sikofitt\Image\Profile;
|
||||||
|
|
||||||
|
|
||||||
|
class LinkedinProfileIcon implements ProfileIconInterface {
|
||||||
|
|
||||||
|
public function getName() {
|
||||||
|
return 'linkedin';
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getDefaultUrl() {
|
||||||
|
return 'https://linkedin.com/in';
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getIcon() {
|
||||||
|
return '';
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,42 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* This file is part of resume.
|
||||||
|
*
|
||||||
|
* @file ProfileIconInterface.php
|
||||||
|
*
|
||||||
|
* R. Eric Wheeler <reric@ee.stanford.edu>
|
||||||
|
*
|
||||||
|
* 7/7/16 / 7:16 AM
|
||||||
|
*
|
||||||
|
* For the full copyright and license information, please view the LICENSE
|
||||||
|
* file that was distributed with this source code.
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace Sikofitt\Image\Profile;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Interface ProfileIconInterface
|
||||||
|
* @package Sikofitt\Image\Profile
|
||||||
|
*/
|
||||||
|
interface ProfileIconInterface {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return string
|
||||||
|
* The name of the network.
|
||||||
|
*/
|
||||||
|
public function getName();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return string
|
||||||
|
* The default url prefix if no url was given.
|
||||||
|
* (e.g. https://twitter.com for twitter, https://facebook.com for facebook.)
|
||||||
|
*/
|
||||||
|
public function getDefaultUrl();
|
||||||
|
/**
|
||||||
|
* @return string
|
||||||
|
* The social icon.
|
||||||
|
* Can be a url, a relative path, or base64 encoded uri.
|
||||||
|
*/
|
||||||
|
public function getIcon();
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,32 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* This file is part of resume.
|
||||||
|
*
|
||||||
|
* @file TwitterProfileIcon.php
|
||||||
|
*
|
||||||
|
* R. Eric Wheeler <reric@ee.stanford.edu>
|
||||||
|
*
|
||||||
|
* 7/7/16 / 7:20 AM
|
||||||
|
*
|
||||||
|
* For the full copyright and license information, please view the LICENSE
|
||||||
|
* file that was distributed with this source code.
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace Sikofitt\Image\Profile;
|
||||||
|
|
||||||
|
|
||||||
|
class TwitterProfileIcon implements ProfileIconInterface {
|
||||||
|
|
||||||
|
public function getName()
|
||||||
|
{
|
||||||
|
return 'twitter';
|
||||||
|
}
|
||||||
|
public function getDefaultUrl() {
|
||||||
|
return 'https://twitter.com';
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getIcon() {
|
||||||
|
return '';
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,50 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* This file is part of resume.
|
||||||
|
*
|
||||||
|
* @file Date.php
|
||||||
|
*
|
||||||
|
* R. Eric Wheeler <reric@ee.stanford.edu>
|
||||||
|
*
|
||||||
|
* 7/7/16 / 6:57 AM
|
||||||
|
*
|
||||||
|
* For the full copyright and license information, please view the LICENSE
|
||||||
|
* file that was distributed with this source code.
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace Sikofitt\Twig;
|
||||||
|
|
||||||
|
|
||||||
|
class Date extends \Twig_Extension {
|
||||||
|
|
||||||
|
public function getName() {
|
||||||
|
return 'date_diff';
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return array
|
||||||
|
* Array of Twig simple filters.
|
||||||
|
*/
|
||||||
|
public function getFilters()
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
new \Twig_SimpleFilter('date_diff', [$this, 'dateDiff']),
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Calculates the difference in time.
|
||||||
|
*
|
||||||
|
* @param $startDate
|
||||||
|
* @param string $endDate
|
||||||
|
*
|
||||||
|
* @return \DateTimeInterface
|
||||||
|
*/
|
||||||
|
public function dateDiff($startDate, $endDate = 'now')
|
||||||
|
{
|
||||||
|
$dt = new \DateTimeImmutable($startDate);
|
||||||
|
$dateDifference = $dt->diff(new \DateTime($endDate));
|
||||||
|
return $dateDifference->format('%y years');
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,54 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* This file is part of test.
|
||||||
|
*
|
||||||
|
* @file Icon.php
|
||||||
|
*
|
||||||
|
* R. Eric Wheeler <reric@ee.stanford.edu>
|
||||||
|
*
|
||||||
|
* 7/7/16 / 9:39 AM
|
||||||
|
*
|
||||||
|
* For the full copyright and license information, please view the LICENSE
|
||||||
|
* file that was distributed with this source code.
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace Sikofitt\Twig;
|
||||||
|
|
||||||
|
|
||||||
|
class RenderProfile extends \Twig_Extension {
|
||||||
|
|
||||||
|
public function getName() {
|
||||||
|
return 'render_profile';
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getFunctions() {
|
||||||
|
return [
|
||||||
|
new \Twig_SimpleFunction('render_profile', [$this, 'renderProfile'], ['needs_context' => true]),
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
public function renderProfile($context, $iconData)
|
||||||
|
{
|
||||||
|
$imageData = '';
|
||||||
|
//network": "Twitter" +"username": "sikofitt" +"url": ""
|
||||||
|
$icons = $context['app']->config('app.icons');
|
||||||
|
|
||||||
|
$network = strtolower($iconData->network);
|
||||||
|
$haveNetwork = isset($icons[$network]);
|
||||||
|
if($haveNetwork) {
|
||||||
|
$imageData = $icons[strtolower($iconData->network)];
|
||||||
|
} else {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if(!isset($iconData->url) || empty($iconData->url))
|
||||||
|
{
|
||||||
|
$iconData->url = $icons[strtolower($iconData->network)]['url'] . '/' . $iconData->username;
|
||||||
|
}
|
||||||
|
$imageUrl = sprintf('<img src="%s" alt="%s" />', $imageData['icon'], $iconData->network);
|
||||||
|
if(isset($iconData->url) && !empty($iconData->url)) {
|
||||||
|
return sprintf('<a class="profile-link" href="%s" title="%s" target="_blank">%s</a>', $iconData->url, $iconData->network,$imageUrl);
|
||||||
|
} else {
|
||||||
|
return $imageUrl;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -2,7 +2,49 @@
|
||||||
@import 'https://fonts.googleapis.com/css?family=Lato:300|Eczar';
|
@import 'https://fonts.googleapis.com/css?family=Lato:300|Eczar';
|
||||||
|
|
||||||
@base-body-font-family : 'Lato';
|
@base-body-font-family : 'Lato';
|
||||||
@base-body-font-size : 26px;
|
@base-body-font-size : 16px;
|
||||||
@base-heading-font-family : 'Eczar';
|
@base-heading-font-family : 'Eczar';
|
||||||
@base-body-line-height : 1.2em;
|
@base-body-line-height : 1.2em;
|
||||||
@thumbnail-mini-width : 100px;
|
@thumbnail-mini-width : 100px;
|
||||||
|
@panel-box-background : #fff;
|
||||||
|
|
||||||
|
|
||||||
|
.uk-panel.uk-panel-box {
|
||||||
|
border: 1px solid @base-hr-border;
|
||||||
|
border-radius:2px;
|
||||||
|
}
|
||||||
|
hr.uk-hr-light {
|
||||||
|
border-top-color:#fafafa;
|
||||||
|
}
|
||||||
|
|
||||||
|
a.profile-link {
|
||||||
|
filter: grayscale(100%);
|
||||||
|
-webkit-transition: filter 500ms;
|
||||||
|
-moz-transition: filter 500ms;
|
||||||
|
-ms-transition: filter 500ms;
|
||||||
|
-o-transition: filter 500ms;
|
||||||
|
transition: filter 500ms;
|
||||||
|
&:hover {
|
||||||
|
filter: grayscale(0%);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.uk-panel-image {
|
||||||
|
position: absolute;
|
||||||
|
top: 10px;
|
||||||
|
right: 16px;
|
||||||
|
> img {
|
||||||
|
width:34px;
|
||||||
|
padding: 2px;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
.uk-text-lead {
|
||||||
|
font-size: 24px;
|
||||||
|
line-height: 38px;
|
||||||
|
font-weight: normal;
|
||||||
|
margin-bottom: 16px;
|
||||||
|
border-bottom: 1px solid #ccc;
|
||||||
|
padding-bottom: 12px;
|
||||||
|
}
|
|
@ -1,37 +1,40 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
use Sikofitt\Json\ResumeBuilder;
|
use Sikofitt\Json\ResumeBuilder;
|
||||||
use Symfony\Component\HttpFoundation\Response;
|
use Symfony\Component\HttpFoundation\Response;
|
||||||
use Silex\Provider\TwigServiceProvider;
|
use Silex\Provider\TwigServiceProvider;
|
||||||
use WhoopsSilex\WhoopsServiceProvider;
|
use WhoopsSilex\WhoopsServiceProvider;
|
||||||
use Symfony\Component\HttpKernel\DataCollector\DumpDataCollector;
|
use Symfony\Component\HttpKernel\DataCollector\DumpDataCollector;
|
||||||
|
|
||||||
require_once __DIR__ . '/../vendor/autoload.php';
|
require_once __DIR__ . '/../vendor/autoload.php';
|
||||||
require_once __DIR__ . '/../app/App.php';
|
require_once __DIR__ . '/../app/App.php';
|
||||||
|
|
||||||
define ('APP_ROOT', __DIR__ . '/../');
|
define('APP_ROOT', __DIR__ . '/../');
|
||||||
define ('SCHEMA_URL', 'https://raw.githubusercontent.com/jsonresume/resume-schema/v1.0.0/schema.json');
|
define('SCHEMA_URL', 'https://raw.githubusercontent.com/jsonresume/resume-schema/v1.0.0/schema.json');
|
||||||
$app = new App();
|
$app = new App();
|
||||||
$app['debug'] = true;
|
$app['debug'] = true;
|
||||||
$app->register(new Sikofitt\Config\ConfigServiceProvider(), [
|
$app->register(new Sikofitt\Config\ConfigServiceProvider(), [
|
||||||
'config.path' => $app->getConfDirectory(),
|
'config.path' => $app->getConfDirectory(),
|
||||||
]);
|
]);
|
||||||
$app->register (new TwigServiceProvider(), [
|
$app->register(new TwigServiceProvider(), [
|
||||||
'twig.path' => [APP_ROOT . 'app/views', APP_ROOT .'vendor/symfony/web-profiler-bundle/Resources/views/Profiler'],
|
'twig.path' => [
|
||||||
|
APP_ROOT . 'app/views',
|
||||||
|
APP_ROOT . 'vendor/symfony/web-profiler-bundle/Resources/views/Profiler'
|
||||||
|
],
|
||||||
]);
|
]);
|
||||||
|
|
||||||
$app->register (new WhoopsServiceProvider());
|
$app->register(new WhoopsServiceProvider());
|
||||||
$app->register (new \Silex\Provider\AssetServiceProvider());
|
$app->register(new \Silex\Provider\AssetServiceProvider());
|
||||||
$app->register (new \Silex\Provider\MonologServiceProvider());
|
$app->register(new \Silex\Provider\MonologServiceProvider());
|
||||||
|
|
||||||
$app->register (new \Silex\Provider\HttpKernelServiceProvider());
|
$app->register(new \Silex\Provider\HttpKernelServiceProvider());
|
||||||
$app->register(new \Silex\Provider\AssetServiceProvider());
|
$app->register(new \Silex\Provider\AssetServiceProvider());
|
||||||
$app->register(new \Silex\Provider\FormServiceProvider());
|
$app->register(new \Silex\Provider\FormServiceProvider());
|
||||||
$app->register(new \Silex\Provider\HttpFragmentServiceProvider());
|
$app->register(new \Silex\Provider\HttpFragmentServiceProvider());
|
||||||
$app->register(new \Silex\Provider\ServiceControllerServiceProvider());
|
$app->register(new \Silex\Provider\ServiceControllerServiceProvider());
|
||||||
$app->register(new \Silex\Provider\RoutingServiceProvider());
|
$app->register(new \Silex\Provider\RoutingServiceProvider());
|
||||||
$app->register (new \Silex\Provider\VarDumperServiceProvider(), array(
|
$app->register(new \Silex\Provider\VarDumperServiceProvider(), array(
|
||||||
'var_dumper.dump_destination' => new \Symfony\Component\VarDumper\Cloner\VarCloner(),
|
'var_dumper.dump_destination' => new \Symfony\Component\VarDumper\Cloner\VarCloner(),
|
||||||
));
|
));
|
||||||
|
|
||||||
|
@ -41,35 +44,39 @@ $app->register(new \Silex\Provider\MonologServiceProvider(), array(
|
||||||
|
|
||||||
$app->register(new \Silex\Provider\SessionServiceProvider());
|
$app->register(new \Silex\Provider\SessionServiceProvider());
|
||||||
$app->register(new \Silex\Provider\WebProfilerServiceProvider(), array(
|
$app->register(new \Silex\Provider\WebProfilerServiceProvider(), array(
|
||||||
'profiler.cache_dir' => $app->getDataDirectory() .'/cache/profiler',
|
'profiler.cache_dir' => $app->getDataDirectory() . '/cache/profiler',
|
||||||
));
|
));
|
||||||
$app->extend('twig', function(\Twig_Environment $twig, $app) {
|
$app->extend('twig', function (\Twig_Environment $twig, $app) {
|
||||||
$twig->enableDebug();
|
$twig->enableDebug();
|
||||||
return $twig;
|
$twig->addExtension(new Twig_Extensions_Extension_Date());
|
||||||
|
$twig->addExtension(new Sikofitt\Twig\Date());
|
||||||
|
$twig->addExtension(new Sikofitt\Twig\RenderProfile());
|
||||||
|
$twig->addGlobal('config', $app['config']->all());
|
||||||
|
return $twig;
|
||||||
});
|
});
|
||||||
$app->error(function (\Exception $e, $code) use($app) {
|
$app->error(function (\Exception $e, $code) use ($app) {
|
||||||
switch ($code) {
|
switch ($code) {
|
||||||
case 404:
|
case 404:
|
||||||
$message = $app['twig']->render('error404.html.twig');
|
$message = $app['twig']->render('error404.html.twig');
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
$message = $app['twig']->render('error500.html.twig');
|
$message = $app['twig']->render('error500.html.twig');
|
||||||
}
|
}
|
||||||
return new Response($message, $code);
|
return new Response($message, $code);
|
||||||
});
|
});
|
||||||
$app['json.decoder'] = function ($app) {
|
$app['json.decoder'] = function ($app) {
|
||||||
return new Webmozart\Json\JsonDecoder();
|
return new Webmozart\Json\JsonDecoder();
|
||||||
};
|
};
|
||||||
$app['json.encoder'] = function ($app) {
|
$app['json.encoder'] = function ($app) {
|
||||||
return new Webmozart\Json\JsonEncoder();
|
return new Webmozart\Json\JsonEncoder();
|
||||||
};
|
};
|
||||||
$app['json.validator'] = function ($app) {
|
$app['json.validator'] = function ($app) {
|
||||||
return new Webmozart\Json\JsonValidator();
|
return new Webmozart\Json\JsonValidator();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
$app->registerIcon(new \Sikofitt\Image\Profile\TwitterProfileIcon());
|
||||||
$app->get ('/', function () use ($app) {
|
$app->get('/', function () use ($app) {
|
||||||
$resumeData = $app['json.decoder']->decodeFile($app->getDataDirectory() .'/resume.json', $app->getDataDirectory() . '/resume.schema.json');
|
$resumeData = $app['json.decoder']->decodeFile($app->getDataDirectory() . '/resume.json', $app->getDataDirectory() . '/resume.schema.json');
|
||||||
$basics = (isset($resumeData->basics) && count($resumeData->basics) > 0) ? $resumeData->basics : null;
|
$basics = (isset($resumeData->basics) && count($resumeData->basics) > 0) ? $resumeData->basics : null;
|
||||||
$work = (isset($resumeData->work) && count($resumeData->work) > 0) ? $resumeData->work : null;
|
$work = (isset($resumeData->work) && count($resumeData->work) > 0) ? $resumeData->work : null;
|
||||||
$volunteer = (isset($resumeData->volunteer) && count($resumeData->volunteer) > 0) ? $resumeData->volunteer : null;
|
$volunteer = (isset($resumeData->volunteer) && count($resumeData->volunteer) > 0) ? $resumeData->volunteer : null;
|
||||||
|
@ -96,4 +103,4 @@ $app->get ('/', function () use ($app) {
|
||||||
]);
|
]);
|
||||||
});
|
});
|
||||||
|
|
||||||
$app->run ();
|
$app->run();
|
||||||
|
|
Loading…
Reference in New Issue