cleared site cache
@ -1,22 +0,0 @@
|
||||
|
||||
|
||||
<style type="text/css" media="screen">
|
||||
.container {
|
||||
margin: 10px auto;
|
||||
max-width: 600px;
|
||||
text-align: center;
|
||||
}
|
||||
h1 {
|
||||
margin: 30px 0;
|
||||
font-size: 4em;
|
||||
line-height: 1;
|
||||
letter-spacing: -1px;
|
||||
}
|
||||
</style>
|
||||
|
||||
<div class="container">
|
||||
<h1>404</h1>
|
||||
|
||||
<p><strong>Page not found :(</strong></p>
|
||||
<p>The requested page could not be found.</p>
|
||||
</div>
|
@ -1 +0,0 @@
|
||||
www.retrylife.ca
|
@ -1 +0,0 @@
|
||||
# retrylife.github.io
|
@ -1,47 +0,0 @@
|
||||
<head>
|
||||
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0-alpha.6/css/bootstrap.min.css" integrity="sha384-rwoIResjU2yc3z8GV/NPeZWAv56rSmLldC3R/AZzGRnGxQQKnKkoFVhFQhNUwEyJ" crossorigin="anonymous">
|
||||
<link href='https://fonts.googleapis.com/css?family=Roboto' rel='stylesheet'>
|
||||
<style>
|
||||
body {
|
||||
font-family: Roboto;
|
||||
margin: 0;
|
||||
padding: 0;
|
||||
}
|
||||
</style>
|
||||
|
||||
</head>
|
||||
<body>
|
||||
<div style="margin-left: 15%">
|
||||
|
||||
|
||||
|
||||
|
||||
<div class="about" style=" width:90%;height:100%;">
|
||||
<div class="card" style="width: 90%;">
|
||||
<div class="card-block">
|
||||
<h4 class="card-title" style="font-size:100px">About Us</h4>
|
||||
<p class="card-text" style="font-size:60px">We are a group of young content creators who have joined together to create cool stuff for you guys to enjoy!</p>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div style="height:5%;"></div>
|
||||
|
||||
|
||||
<div style="height:0.5rem;"></div>
|
||||
<a href="people.html" class="btn btn-primary" style="font-size:75px;margin-left: 13%;">What we do</a>
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
</div>
|
||||
|
||||
|
||||
|
||||
<script src="https://code.jquery.com/jquery-3.1.1.slim.min.js" integrity="sha384-A7FZj7v+d/sdmMqp/nOQwliLvUsJfDHW+k9Omg/a/EheAdgtzNs3hpfag6Ed950n" crossorigin="anonymous"></script>
|
||||
<script src="https://cdnjs.cloudflare.com/ajax/libs/tether/1.4.0/js/tether.min.js" integrity="sha384-DztdAPBWPRXSA/3eYEEUWrWCy7G5KFbe8fFjk5JAIxUYHKkDx6Qin1DkWx51bBrb" crossorigin="anonymous"></script>
|
||||
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0-alpha.6/js/bootstrap.min.js" integrity="sha384-vBWWzlZJ8ea9aCX4pEW3rVHjgjt7zpkNpZk+02D9phzyeVkE+jo0ieGizqPLForn" crossorigin="anonymous"></script>
|
||||
|
||||
</div>
|
||||
</body>
|
@ -1,30 +0,0 @@
|
||||
<html><head>
|
||||
<link href="https://unpkg.com/picnic" rel="stylesheet">
|
||||
<title>RetryLife</title>
|
||||
<style>
|
||||
@font-face{
|
||||
font-family: "8-bit";
|
||||
src: url('./font.txt'),
|
||||
url('./font.txt'); /* IE */
|
||||
}
|
||||
body {
|
||||
font-family: "8-bit";
|
||||
}
|
||||
|
||||
</style>
|
||||
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>
|
||||
</head>
|
||||
<body>
|
||||
<div class="flex one three-600 demo">
|
||||
<div><span></span></div>
|
||||
<div style="text-align:center;" class="lll"><span>
|
||||
<br>
|
||||
<br>
|
||||
<h1>About Me</h1>
|
||||
<p style="text-align:left;font-size:medium;">Hi. I am the human behind this thing called RetryLife. There is a good chance that you have seen me somewhere on the internet. My username is usually <a href="https://twitter.com/ewpratten">@ewpratten</a> but sometimes I prefer to use a diffrent username because, why not? So.. what is RetryLife and why did I decide to invest my time into it? RetryLife is really just a name that I publish my work under. There is no set release schedule, and there is no video series as well. This is because I have to go to school and I also have other side projects that I work on. RetryL:ife is just a fun thing that I use to publish anything that is music / video related (as well as some code here and there). This is all I have to say here for now, but I will probably change the site soon.</p>
|
||||
|
||||
</span></div>
|
||||
<div><span></span></div>
|
||||
</div>
|
||||
|
||||
</body></html>
|
@ -1,40 +0,0 @@
|
||||
<html><head>
|
||||
<link href="https://unpkg.com/picnic" rel="stylesheet">
|
||||
<title>The Button</title>
|
||||
<style>
|
||||
@font-face{
|
||||
font-family: "8-bit";
|
||||
src: url('../font.txt'),
|
||||
url('../font.txt'); /* IE */
|
||||
}
|
||||
body {
|
||||
font-family: "8-bit";
|
||||
}
|
||||
|
||||
</style>
|
||||
</head>
|
||||
<body>
|
||||
<div class="flex one three-600 demo">
|
||||
<div><span></span></div>
|
||||
<div style="text-align:center;" class="lll"><span>
|
||||
<br>
|
||||
<br>
|
||||
<h3>It's a button, click it</h3>
|
||||
|
||||
|
||||
<a href="https://twitter.com/intent/tweet?hashtags=RTLButton&ref_src=twsrc%5Etfw&related=ewpratten&text=I%20pressed%20the%20button!&tw_p=tweetbutton&url=http%3A%2F%2Fwww.retrylife.ca%2Fbutton"><button>Button</button></a>
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
</span></div>
|
||||
<div><span></span></div>
|
||||
</div>
|
||||
|
||||
</body></html>
|
@ -1,80 +0,0 @@
|
||||
|
||||
|
||||
<head>
|
||||
<link href="https://unpkg.com/picnic" rel="stylesheet">
|
||||
<title>ewpratten</title>
|
||||
<link href="https://fonts.googleapis.com/css?family=Roboto" rel="stylesheet">
|
||||
<style>
|
||||
@font-face{
|
||||
font-family: "8-bit";
|
||||
src: url('./font.txt'),
|
||||
url('./font.txt'); /* IE */
|
||||
}
|
||||
body {
|
||||
font-family: 'Roboto', sans-serif;
|
||||
background-color:#2e3440;
|
||||
color:#3b4252;
|
||||
}
|
||||
h1{
|
||||
font-size:230%;
|
||||
padding:1px;
|
||||
}
|
||||
.card{
|
||||
border:none;
|
||||
background-color:#4c566a;
|
||||
}
|
||||
.card-top{
|
||||
width:100%;
|
||||
height:20%;
|
||||
background-color:#4c566a;
|
||||
border:none;
|
||||
}
|
||||
.card-bottem{
|
||||
width:100%;
|
||||
height:80%;
|
||||
background-color:#d8dee9;
|
||||
text-align:center;
|
||||
border-radius:5px;
|
||||
}
|
||||
.pic2 {
|
||||
height:100%;
|
||||
display:flex;
|
||||
margin-left: auto;
|
||||
margin-right:auto;
|
||||
border-radius:100%;
|
||||
}
|
||||
.b1 {
|
||||
background-color:#5e81ac;
|
||||
font-size:190%;
|
||||
width:90%;
|
||||
}
|
||||
h2 {
|
||||
padding:1px;
|
||||
}
|
||||
</style>
|
||||
</head>
|
||||
<body>
|
||||
<div class="flex one three-600 demo">
|
||||
<div><span></span></div>
|
||||
<div style="text-align:center;" class="lll"><span>
|
||||
<div class="card">
|
||||
<div class="card-top">
|
||||
<img class="pic2" src="profile.jpg">
|
||||
</div>
|
||||
<div class="card-bottem">
|
||||
<br>
|
||||
<h1>Evan Pratten</h1>
|
||||
<h2>@ewpratten</h2>
|
||||
<p>I am an average human who likes to make stuff.</p>
|
||||
<br><br>
|
||||
<a href="https://twitter.com/ewpratten"><button class="b1">Twitter</button></a><br>
|
||||
<a href="https://github.com/ewpratten"><button class="b1">GitHub</button></a><br>
|
||||
<a href="https://keybase.io/ewpratten"><button class="b1">Keybase</button></a><br>
|
||||
<a href="https://r.retrylife.ca"><button class="b1">RetryLife</button></a><br>
|
||||
</div>
|
||||
|
||||
</div>
|
||||
</span></div>
|
||||
<div><span></span></div>
|
||||
</div>
|
||||
</body>
|
@ -1,8 +0,0 @@
|
||||
{
|
||||
"title": "The Lost Warrior",
|
||||
"author": "Nathan",
|
||||
"type": "img",
|
||||
"src": "http://art.ngfiles.com/images/477000/477954_glitchop_the-lost-warrior-2.png",
|
||||
"href": "http://www.newgrounds.com/art/view/glitchop/the-lost-warrior-2",
|
||||
"datetime": ""
|
||||
}
|
@ -1,8 +0,0 @@
|
||||
{
|
||||
"title": "Steampunk Girl",
|
||||
"author": "Nathan",
|
||||
"type": "img",
|
||||
"src": "http://art.ngfiles.com/images/478000/478522_glitchop_steampunk-girl.png",
|
||||
"href": "http://www.newgrounds.com/art/view/glitchop/steampunk-girl",
|
||||
"datetime": ""
|
||||
}
|
@ -1,8 +0,0 @@
|
||||
{
|
||||
"title": "",
|
||||
"author": "",
|
||||
"type": "",
|
||||
"src": "",
|
||||
"href": "",
|
||||
"datetime": ""
|
||||
}
|
@ -1,44 +0,0 @@
|
||||
<?php
|
||||
function getContent() {
|
||||
//Thanks to https://davidwalsh.name/php-cache-function for cache idea
|
||||
$file = "./feed-cache.txt";
|
||||
$current_time = time();
|
||||
$expire_time = 5 * 60;
|
||||
$file_time = filemtime($file);
|
||||
if(file_exists($file) && ($current_time - $expire_time < $file_time)) {
|
||||
return file_get_contents($file);
|
||||
}
|
||||
else {
|
||||
$content = getFreshContent();
|
||||
file_put_contents($file, $content);
|
||||
return $content;
|
||||
}
|
||||
}
|
||||
function getFreshContent() {
|
||||
$html = "";
|
||||
$newsSource = array(
|
||||
array(
|
||||
"title" => "RetryLife-all",
|
||||
"url" => "http://www.rssmix.com/u/8252161/rss.xml"
|
||||
)
|
||||
|
||||
);
|
||||
function getFeed($url){
|
||||
$rss = simplexml_load_file($url);
|
||||
$count = 0;
|
||||
$html .= '<ul class="rantlist">';
|
||||
foreach($rss->channel->item as$item) {
|
||||
$count++;
|
||||
if($count > 1000){
|
||||
break;
|
||||
}
|
||||
$html .= '><a href="'.htmlspecialchars($item->link).'"><li class="rant-comment-row-widget" data-id="829770" data-type="rant" style="background-color:#243447;color:white;"><div class="rantlist-title-text" > '.htmlspecialchars($item->description).'</div></li>';
|
||||
|
||||
}
|
||||
$html .= '</ul>';
|
||||
return $html;
|
||||
}
|
||||
return $html;
|
||||
}
|
||||
print getContent();
|
||||
?>
|
@ -1,136 +0,0 @@
|
||||
<html lang="en"><head>
|
||||
<meta charset="utf-8">
|
||||
|
||||
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
|
||||
<meta name="viewport" content="width=device-width, minimumscale=1.0, maximum-scale=1.0">
|
||||
|
||||
|
||||
<title>RetryLife Community</title>
|
||||
|
||||
<style>
|
||||
body {
|
||||
font-family: Roboto;
|
||||
margin: 0;
|
||||
padding: 0;
|
||||
background-image: url("../img/Background.png");
|
||||
background-size: 100% 100%;
|
||||
background-attachment: fixed;
|
||||
|
||||
}
|
||||
.rant-top-bar {
|
||||
background-color:white;
|
||||
}
|
||||
</style>
|
||||
|
||||
|
||||
<link href="https://fonts.googleapis.com/css?family=Comfortaa" rel="stylesheet" type="text/css">
|
||||
|
||||
<link href="./style.css" rel="stylesheet" type="text/css">
|
||||
<link href="https://devrant.io/static/devrant/css/font-style.css?v=5" rel="stylesheet" type="text/css">
|
||||
|
||||
|
||||
|
||||
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.2.2/jquery.min.js"></script>
|
||||
|
||||
|
||||
<script async src="//platform.twitter.com/widgets.js" charset="utf-8"></script>
|
||||
|
||||
</head>
|
||||
<body >
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
<div class="container">
|
||||
|
||||
<div class="interior-centered">
|
||||
<div class="interior-content" style="min-height: 804px;background-color:white;">
|
||||
|
||||
<div class="body-col1">
|
||||
<div class="body-col1-content">
|
||||
|
||||
<div style="background-color:#243447;padding:15px;border-radius:10px;color:white;">
|
||||
<img src="https://pbs.twimg.com/profile_images/884167837891342336/F8JOfFAf_400x400.jpg">
|
||||
<h1>RetryLife</h1>
|
||||
<p>Canada</p>
|
||||
<br>
|
||||
<br>
|
||||
|
||||
<div style="padding:6px; background-color:#1ca2f2; border-radius:8px;">
|
||||
<a href="https://twitter.com/retrylife_music" class="twitter-follow-button" data-show-count="false">Follow @retrylife_music</a>
|
||||
</div>
|
||||
<br>
|
||||
<div style="padding:6px; background-color:#1ca2f2; border-radius:8px;">
|
||||
<a href="https://twitter.com/ewpratten" class="twitter-follow-button" data-show-count="false">Follow @ewpratten</a>
|
||||
</div>
|
||||
<br>
|
||||
<div style="padding:6px; background-color:#1ca2f2; border-radius:8px;">
|
||||
<a href="https://twitter.com/nsdesjardins345" class="twitter-follow-button" data-show-count="false">Follow @nsdesjardins345</a>
|
||||
</div>
|
||||
<br>
|
||||
<div style="padding:6px; background-color:#ff0000; border-radius:8px;">
|
||||
<a href="https://www.youtube.com/channel/UCrHT3Lt0Mg90bspbMHJfTcA?sub_confirmation=1">Subscribe to RetryLife Official</a>
|
||||
</div>
|
||||
<br>
|
||||
<div style="padding:6px; background-color:#ff0000; border-radius:8px;">
|
||||
<a href="https://www.youtube.com/channel/UCxzARKt0_U0sLHbF4pDN1Pw?sub_confirmation=1">Subscribe to Nathan Desjardins</a>
|
||||
</div>
|
||||
<br>
|
||||
|
||||
</div>
|
||||
|
||||
|
||||
|
||||
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="body-col2 page-feed">
|
||||
|
||||
|
||||
|
||||
<div class="rantlist-bg">
|
||||
<ul class="rantlist">
|
||||
|
||||
<?php
|
||||
$i = 0; // counter
|
||||
$url = "http://www.rssmix.com/u/8252161/rss.xml"; // url to parse
|
||||
$rss = simplexml_load_file($url); // XML parser
|
||||
|
||||
// RSS items loop
|
||||
|
||||
print '<h2><img style="vertical-align: middle;" src="'.$rss->channel->image->url.'" /> '.$rss->channel->title.'</h2>'; // channel title + img with src
|
||||
|
||||
foreach($rss->channel->item as $item) {
|
||||
if ($i < 1000) { // parse only 10 items
|
||||
print '<a href="'.$item->link.'"><li class="rant-comment-row-widget" data-id="829770" data-type="rant" style="background-color:#243447;color:white;"><div class="rantlist-title-text" > '.$item->description.'</div></li></a>';
|
||||
}
|
||||
|
||||
$i++;
|
||||
}
|
||||
?>
|
||||
|
||||
|
||||
|
||||
|
||||
</ul>
|
||||
</div>
|
||||
<div class="clearfix"></div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
</div> <!-- end container -->
|
||||
|
||||
|
||||
|
||||
</body></html>
|
@ -1,237 +0,0 @@
|
||||
<html lang="en"><head>
|
||||
<meta charset="utf-8">
|
||||
|
||||
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
|
||||
<meta name="viewport" content="width=device-width, minimumscale=1.0, maximum-scale=1.0">
|
||||
|
||||
|
||||
<title>RetryLife Community</title>
|
||||
|
||||
<style>
|
||||
body {
|
||||
font-family: Roboto;
|
||||
margin: 0;
|
||||
padding: 0;
|
||||
background-image: url("../img/Background.png");
|
||||
background-size: 100% 100%;
|
||||
background-attachment: fixed;
|
||||
|
||||
}
|
||||
.rant-top-bar {
|
||||
background-color:white;
|
||||
}
|
||||
</style>
|
||||
|
||||
|
||||
<link href="https://fonts.googleapis.com/css?family=Comfortaa" rel="stylesheet" type="text/css">
|
||||
|
||||
<link href="./style.css" rel="stylesheet" type="text/css">
|
||||
<link href="https://devrant.io/static/devrant/css/font-style.css?v=5" rel="stylesheet" type="text/css">
|
||||
|
||||
|
||||
|
||||
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.2.2/jquery.min.js"></script>
|
||||
|
||||
|
||||
<script src="/widgets.js" async></script>
|
||||
|
||||
</head>
|
||||
<body >
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
<div class="container">
|
||||
|
||||
<div class="interior-centered">
|
||||
<div class="interior-content" style="min-height: 804px;background-color:white;">
|
||||
|
||||
<div class="body-col1">
|
||||
<div class="body-col1-content">
|
||||
|
||||
<div style="background-color:#243447;padding:15px;border-radius:10px;color:white;">
|
||||
<img src="https://pbs.twimg.com/profile_images/884167837891342336/F8JOfFAf_400x400.jpg">
|
||||
<h1>RetryLife</h1>
|
||||
<p>Canada</p>
|
||||
<br>
|
||||
<br>
|
||||
|
||||
<div style="padding:6px; background-color:#1ca2f2; border-radius:8px;">
|
||||
<a href="https://twitter.com/retrylife_music" class="twitter-follow-button" data-show-count="false">Follow @retrylife_music</a>
|
||||
</div>
|
||||
<br>
|
||||
<div style="padding:6px; background-color:#1ca2f2; border-radius:8px;">
|
||||
<a href="https://twitter.com/ewpratten" class="twitter-follow-button" data-show-count="false">Follow @ewpratten</a>
|
||||
</div>
|
||||
<br>
|
||||
<div style="padding:6px; background-color:#1ca2f2; border-radius:8px;">
|
||||
<a href="https://twitter.com/nsdesjardins345" class="twitter-follow-button" data-show-count="false">Follow @nsdesjardins345</a>
|
||||
</div>
|
||||
<br>
|
||||
<div style="padding:6px; background-color:#ff0000; border-radius:8px;">
|
||||
<a href="https://www.youtube.com/channel/UCrHT3Lt0Mg90bspbMHJfTcA?sub_confirmation=1">Subscribe to RetryLife Official</a>
|
||||
</div>
|
||||
<br>
|
||||
<div style="padding:6px; background-color:#ff0000; border-radius:8px;">
|
||||
<a href="https://www.youtube.com/channel/UCxzARKt0_U0sLHbF4pDN1Pw?sub_confirmation=1">Subscribe to Nathan Desjardins</a>
|
||||
</div>
|
||||
<br>
|
||||
|
||||
</div>
|
||||
<br>
|
||||
|
||||
<div style="background-color:#243447;padding:15px;border-radius:10px;color:white;">
|
||||
<?php
|
||||
require_once('login/twitteroauth/OAuth.php');
|
||||
require_once('login/twitteroauth/twitteroauth.php');
|
||||
// define the consumer key and secet and callback
|
||||
define('CONSUMER_KEY', 'YOUR_CONSUMER_KEY');
|
||||
define('CONSUMER_SECRET', 'YOUR_CONSUMER_SECRET');
|
||||
define('OAUTH_CALLBACK', 'YOUR_CONSUMER_CALLBACK_URL');
|
||||
// start the session
|
||||
session_start();
|
||||
|
||||
/*
|
||||
* PART 2 - PROCESS
|
||||
* 1. check for logout
|
||||
* 2. check for user session
|
||||
* 3. check for callback
|
||||
*/
|
||||
|
||||
// 1. to handle logout request
|
||||
if(isset($_GET['logout'])){
|
||||
//unset the session
|
||||
session_unset();
|
||||
// redirect to same page to remove url paramters
|
||||
$redirect = 'http://' . $_SERVER['HTTP_HOST'] . $_SERVER['PHP_SELF'];
|
||||
header('Location: ' . filter_var($redirect, FILTER_SANITIZE_URL));
|
||||
}
|
||||
|
||||
|
||||
// 2. if user session not enabled get the login url
|
||||
if(!isset($_SESSION['data']) && !isset($_GET['oauth_token'])) {
|
||||
// create a new twitter connection object
|
||||
$connection = new TwitterOAuth(CONSUMER_KEY, CONSUMER_SECRET);
|
||||
// get the token from connection object
|
||||
$request_token = $connection->getRequestToken(OAUTH_CALLBACK);
|
||||
// if request_token exists then get the token and secret and store in the session
|
||||
if($request_token){
|
||||
$token = $request_token['oauth_token'];
|
||||
$_SESSION['request_token'] = $token ;
|
||||
$_SESSION['request_token_secret'] = $request_token['oauth_token_secret'];
|
||||
// get the login url from getauthorizeurl method
|
||||
$login_url = $connection->getAuthorizeURL($token);
|
||||
}
|
||||
}
|
||||
|
||||
// 3. if its a callback url
|
||||
if(isset($_GET['oauth_token'])){
|
||||
// create a new twitter connection object with request token
|
||||
$connection = new TwitterOAuth(CONSUMER_KEY, CONSUMER_SECRET, $_SESSION['request_token'], $_SESSION['request_token_secret']);
|
||||
// get the access token from getAccesToken method
|
||||
$access_token = $connection->getAccessToken($_REQUEST['oauth_verifier']);
|
||||
if($access_token){
|
||||
// create another connection object with access token
|
||||
$connection = new TwitterOAuth(CONSUMER_KEY, CONSUMER_SECRET, $access_token['oauth_token'], $access_token['oauth_token_secret']);
|
||||
// set the parameters array with attributes include_entities false
|
||||
$params =array('include_entities'=>'false');
|
||||
// get the data
|
||||
$data = $connection->get('account/verify_credentials',$params);
|
||||
if($data){
|
||||
// store the data in the session
|
||||
$_SESSION['data']=$data;
|
||||
// redirect to same page to remove url parameters
|
||||
$redirect = 'http://' . $_SERVER['HTTP_HOST'] . $_SERVER['PHP_SELF'];
|
||||
header('Location: ' . filter_var($redirect, FILTER_SANITIZE_URL));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
* PART 3 - FRONT END
|
||||
* - if userdata available then print data
|
||||
* - else display the login url
|
||||
*/
|
||||
|
||||
if(isset($login_url) && !isset($_SESSION['data'])){
|
||||
// echo the login url
|
||||
echo "<a href='$login_url'><button>Login with twitter </button></a>";
|
||||
}
|
||||
else{
|
||||
// get the data stored from the session
|
||||
$data = $_SESSION['data'];
|
||||
// echo the name username and photo
|
||||
echo "Name : ".$data->name."<br>";
|
||||
echo "Username : ".$data->screen_name."<br>";
|
||||
echo "Photo : <img src='".$data->profile_image_url."'/><br><br>";
|
||||
// echo the logout button
|
||||
echo "<a href='?logout=true'><button>Logout</button></a>";
|
||||
// echo content box if user is approved
|
||||
if($data->screen_name == "ewpratten"){
|
||||
echo '<?php
|
||||
if (!empty($_GET[';
|
||||
echo "'act'";
|
||||
echo '])) {
|
||||
|
||||
echo "Hello world!"; //Your code here
|
||||
} else {
|
||||
?>
|
||||
(.. your html ..)
|
||||
<form action="index.php" method="get">
|
||||
<input type="hidden" name="act" value="run">
|
||||
<input type="submit" value="Creator Page">
|
||||
</form>
|
||||
<?php
|
||||
}
|
||||
?>';
|
||||
}
|
||||
}
|
||||
?>
|
||||
</div>
|
||||
|
||||
|
||||
|
||||
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="body-col2 page-feed">
|
||||
|
||||
|
||||
|
||||
<div class="rantlist-bg">
|
||||
<ul class="rantlist">
|
||||
|
||||
|
||||
<a class="twitter-timeline" data-dnt="true" data-theme="dark" href="https://twitter.com/RetryLife_Music">Tweets by RetryLife_Music</a> <script async src="https://platform.twitter.com/widgets.js" charset="utf-8"></script>
|
||||
|
||||
<a class="twitter-timeline" data-dnt="true" data-theme="dark" href="https://twitter.com/nsdesjardins345">Tweets by RetryLife_Music</a> <script async src="https://platform.twitter.com/widgets.js" charset="utf-8"></script>
|
||||
|
||||
|
||||
<a class="twitter-timeline" data-dnt="true" data-theme="dark" href="https://twitter.com/ewpratten">Tweets by RetryLife_Music</a> <script async src="Https://platform.twitter.com/widgets.js" charset="utf-8"></script>
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
</ul>
|
||||
</div>
|
||||
<div class="clearfix"></div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
</div> <!-- end container -->
|
||||
|
||||
|
||||
|
||||
</body></html>
|
@ -1,25 +0,0 @@
|
||||
var txt = '';
|
||||
var xmlhttp = new XMLHttpRequest();
|
||||
xmlhttp.onreadystatechange = function(){
|
||||
if(xmlhttp.status == 200 && xmlhttp.readyState == 4){
|
||||
txt = xmlhttp.responseText;
|
||||
}
|
||||
};
|
||||
xmlhttp.open("GET","./content/test.json",false);
|
||||
xmlhttp.send();
|
||||
console.log(txt)
|
||||
var json = JSON.parse(txt);
|
||||
alert(json.src);
|
||||
|
||||
if (json.type == "img") {
|
||||
var contenttype = "img"
|
||||
} else {
|
||||
var contenttype = "iframe"
|
||||
}
|
||||
|
||||
var options = ' src = "';
|
||||
var options = options.concat(json.src);
|
||||
var options = options.concat('"');
|
||||
var content = document.createElement(contenttype,[options]);
|
||||
|
||||
document.body.appendChild(content)
|
@ -1,27 +0,0 @@
|
||||
<?php
|
||||
|
||||
$files = glob('content/*.{json}', GLOB_BRACE);
|
||||
foreach($files as $file) {
|
||||
//do your work here
|
||||
|
||||
|
||||
$url = $file;
|
||||
$content = file_get_contents($url);
|
||||
$json = json_decode($content, true);
|
||||
echo '<li class="rant-comment-row-widget" data-id="829770" data-type="rant" style="background-color:#243447;color:white;"><div class="rantlist-title-text" >';
|
||||
echo $json{title};
|
||||
echo " - ";
|
||||
echo $json{author};
|
||||
echo '</div> <';
|
||||
echo $json{type};
|
||||
echo ' src="';
|
||||
echo $json{src}; echo '" href="';
|
||||
echo $json{href};
|
||||
echo '" width=100%>';
|
||||
echo $json{body};
|
||||
echo '</';
|
||||
echo $json{type};
|
||||
echo '>';
|
||||
echo '</li>';
|
||||
}
|
||||
?>
|
@ -1 +0,0 @@
|
||||
{}
|
@ -1 +0,0 @@
|
||||
<iframe style="border: 0; width: 99%; height: 95%;" src="https://bandcamp.com/EmbeddedPlayer/album=3082028873/size=large/bgcol=ffffff/linkcol=0687f5/artwork=small/transparent=true/" seamless><a href="http://retrylife.bandcamp.com/album/sir-dankleys-mlg-restaurant">Sir Dankley's MLG Restaurant by RetryLife</a></iframe>
|
@ -1 +0,0 @@
|
||||
<iframe style="border: 0; width: 99%; height: 95%;" src="https://bandcamp.com/EmbeddedPlayer/album=3082028873/size=large/bgcol=ffffff/linkcol=0687f5/artwork=small/transparent=true/" seamless><a href="http://retrylife.bandcamp.com/album/sir-dankleys-mlg-restaurant">Sir Dankley's MLG Restaurant by RetryLife</a></iframe>
|
@ -1 +0,0 @@
|
||||
t
|
@ -1,54 +0,0 @@
|
||||
<head>
|
||||
<title>RetryLife</title>
|
||||
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0-alpha.6/css/bootstrap.min.css" integrity="sha384-rwoIResjU2yc3z8GV/NPeZWAv56rSmLldC3R/AZzGRnGxQQKnKkoFVhFQhNUwEyJ" crossorigin="anonymous">
|
||||
<link href='https://fonts.googleapis.com/css?family=Roboto' rel='stylesheet'>
|
||||
<link rel="shortcut icon" type="image/x-icon" href="../favicon.ico" />
|
||||
<style>
|
||||
body {
|
||||
font-family: Roboto;
|
||||
margin: 0;
|
||||
padding: 0;
|
||||
background-image: url("../img/Background.png");
|
||||
background-size: 100% 100%;
|
||||
|
||||
}
|
||||
</style>
|
||||
|
||||
</head>
|
||||
|
||||
<body >
|
||||
<div class="content">
|
||||
<div style="float:left;width: 38%;height:100%;">
|
||||
<div style="height:30%"></div>
|
||||
<h1 style="float:left;margin-left:26%;font-size:80px;">RetryLife</h1>
|
||||
<div style="height:20%"></div>
|
||||
|
||||
|
||||
|
||||
<div class="btn-group btn-group-lg" role="group" aria-label="..." style="float:left;margin-left:25%;font-size:80px;">
|
||||
|
||||
<a target="main" href="../music/index.html"><button type="button" class="btn btn-info">Music</button></a>
|
||||
<div style="width:10%;color:rgba(255, 255, 255, 0)">-</div>
|
||||
<a target="main" href="../youtube.html"><button type="button" class="btn btn-primary">Youtube</button></a>
|
||||
<div style="width:10%;color:rgba(255, 255, 255, 0);">-</div>
|
||||
<a href="https://www.patreon.com/bePatron?u=7175648"><button type="button" class="btn btn-info">Support Us</button></a>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
|
||||
|
||||
|
||||
<div style="float:right;width: 62%;height:100%;padding:4%;">
|
||||
<iframe name="main" frameBorder="0" style="margin-left:21%;height:100%;width:75%;" src="../about.html" allowtransparency="true"></iframe>
|
||||
</div>
|
||||
|
||||
|
||||
</div>
|
||||
|
||||
|
||||
|
||||
<script src="https://code.jquery.com/jquery-3.1.1.slim.min.js" integrity="sha384-A7FZj7v+d/sdmMqp/nOQwliLvUsJfDHW+k9Omg/a/EheAdgtzNs3hpfag6Ed950n" crossorigin="anonymous"></script>
|
||||
<script src="https://cdnjs.cloudflare.com/ajax/libs/tether/1.4.0/js/tether.min.js" integrity="sha384-DztdAPBWPRXSA/3eYEEUWrWCy7G5KFbe8fFjk5JAIxUYHKkDx6Qin1DkWx51bBrb" crossorigin="anonymous"></script>
|
||||
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0-alpha.6/js/bootstrap.min.js" integrity="sha384-vBWWzlZJ8ea9aCX4pEW3rVHjgjt7zpkNpZk+02D9phzyeVkE+jo0ieGizqPLForn" crossorigin="anonymous"></script>
|
||||
|
||||
</body>
|
@ -1,8 +0,0 @@
|
||||
<div id = "myDiv"><img id = "myImage" src = "../img/load.gif" style="width:100%;"></div><br>
|
||||
|
||||
<script type = "text/javascript">
|
||||
setTimeout(function(){
|
||||
document.getElementById("myDiv").style.display="none";
|
||||
}, 6000);
|
||||
document.location = "./index.html";
|
||||
</script>
|
@ -1,29 +0,0 @@
|
||||
<html><head>
|
||||
<link href="https://unpkg.com/picnic" rel="stylesheet">
|
||||
<title>RetryLife</title>
|
||||
<style>
|
||||
@font-face{
|
||||
font-family: "8-bit";
|
||||
src: url('http://www.retrylife.ca/font.txt'),
|
||||
url('./font.txt'); /* IE */
|
||||
}
|
||||
body {
|
||||
font-family: "8-bit";
|
||||
}
|
||||
|
||||
</style>
|
||||
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>
|
||||
</head>
|
||||
<body>
|
||||
<div class="flex one three-600 demo">
|
||||
<div><span></span></div>
|
||||
<div style="text-align:center;" class="lll"><span>
|
||||
<br>
|
||||
<br>
|
||||
<h1>An Error Occurred</h1>
|
||||
<p>Try checking the spelling of the link you followed. Or <a href="./index.html">Go Back</a></p>
|
||||
</span></div>
|
||||
<div><span></span></div>
|
||||
</div>
|
||||
|
||||
</body></html>
|
Before Width: | Height: | Size: 1.1 KiB |
@ -1,3 +0,0 @@
|
||||
/* Team */
|
||||
Developed by: Evan Pratten
|
||||
Art by: Nathan Desjardins
|
Before Width: | Height: | Size: 3.4 MiB |
@ -1 +0,0 @@
|
||||
Ignore
|
Before Width: | Height: | Size: 125 KiB |
Before Width: | Height: | Size: 82 KiB |
Before Width: | Height: | Size: 68 KiB |
@ -1,69 +0,0 @@
|
||||
|
||||
<head>
|
||||
<link href="https://unpkg.com/picnic" rel="stylesheet">
|
||||
<title>RetryLife</title>
|
||||
<style>
|
||||
@font-face{
|
||||
font-family: "8-bit";
|
||||
src: url('./font.txt'),
|
||||
url('./font.txt'); /* IE */
|
||||
}
|
||||
body {
|
||||
font-family: "8-bit";
|
||||
}
|
||||
|
||||
</style>
|
||||
</head>
|
||||
<body>
|
||||
<div class="flex one three-600 demo">
|
||||
<div><span></span></div>
|
||||
<div style="text-align:center;" class="lll"><span>
|
||||
<br>
|
||||
<br>
|
||||
<h1>RetryLife</h1>
|
||||
<p id="demo">21d 12h 19m 33s </p>
|
||||
<a href="Http://retrylife.bandcamp.com"><h2>Music</h2></a>
|
||||
<a href="https://www.youtube.com/channel/UCrHT3Lt0Mg90bspbMHJfTcA"><h2>YouTube</h2></a>
|
||||
<a href="https://twitch.tv/retrylife/"><h2>Twitch</h2></a>
|
||||
<a href="https://ewpratten.deviantart.com/"><h2>DeviantArt</h2></a>
|
||||
<a href="https://devcredits.herokuapp.com/"><h2>devCredits</h2></a>
|
||||
<a href="http://www.retrylife.ca/button/"><h2>The Button</h2></a>
|
||||
<a href="https://github.com/Ewpratten"><h2>Github</h2></a>
|
||||
<a href="https://keybase.io/ewpratten"><h2>Keybase</h2></a>
|
||||
|
||||
|
||||
|
||||
<script>
|
||||
// Set the date we're counting down to
|
||||
var countDownDate = new Date("Dec 25, 2017 9:0:0").getTime();
|
||||
|
||||
// Update the count down every 1 second
|
||||
var x = setInterval(function() {
|
||||
|
||||
// Get todays date and time
|
||||
var now = new Date().getTime();
|
||||
|
||||
// Find the distance between now an the count down date
|
||||
var distance = countDownDate - now;
|
||||
|
||||
// Time calculations for days, hours, minutes and seconds
|
||||
var days = Math.floor(distance / (1000 * 60 * 60 * 24));
|
||||
var hours = Math.floor((distance % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
|
||||
var minutes = Math.floor((distance % (1000 * 60 * 60)) / (1000 * 60));
|
||||
var seconds = Math.floor((distance % (1000 * 60)) / 1000);
|
||||
|
||||
// Output the result in an element with id="demo"
|
||||
document.getElementById("demo").innerHTML = days + "d " + hours + "h "
|
||||
+ minutes + "m " + seconds + "s ";
|
||||
|
||||
// If the count down is over, write some text
|
||||
if (distance < 0) {
|
||||
clearInterval(x);
|
||||
document.getElementById("demo").innerHTML = "";
|
||||
}
|
||||
}, 1000);
|
||||
</script>
|
||||
</span></div>
|
||||
<div><span></span></div>
|
||||
</div>
|
||||
</body>
|
@ -1,369 +0,0 @@
|
||||
<html class="js flexbox canvas canvastext webgl touch geolocation postmessage websqldatabase indexeddb hashchange history draganddrop websockets rgba hsla multiplebgs backgroundsize borderimage borderradius boxshadow textshadow opacity cssanimations csscolumns cssgradients cssreflections csstransforms csstransforms3d csstransitions fontface generatedcontent video audio localstorage sessionstorage webworkers applicationcache svg inlinesvg smil svgclippaths wf-opensans-i3-active wf-opensans-i8-active wf-opensans-n4-active wf-opensans-n3-active wf-opensans-n6-active wf-opensans-n7-active wf-opensans-n8-active wf-montserrat-n4-active wf-montserrat-n7-active wf-active" lang="en" style=""><head><style type="text/css">.gm-style .gm-style-mtc label,.gm-style .gm-style-mtc div{font-weight:400}
|
||||
</style><link type="text/css" rel="stylesheet" href="https://fonts.googleapis.com/css?family=Roboto:300,400,500,700"><style type="text/css">.gm-style .gm-style-cc span,.gm-style .gm-style-cc a,.gm-style .gm-style-mtc div{font-size:10px}
|
||||
</style><style type="text/css">@media print { .gm-style .gmnoprint, .gmnoprint { display:none }}@media screen { .gm-style .gmnoscreen, .gmnoscreen { display:none }}</style><style type="text/css">.gm-style-pbc{transition:opacity ease-in-out;background-color:rgba(0,0,0,0.45);text-align:center}.gm-style-pbt{font-size:22px;color:white;font-family:Roboto,Arial,sans-serif;position:relative;margin:0;top:50%;-webkit-transform:translateY(-50%);-ms-transform:translateY(-50%);transform:translateY(-50%)}
|
||||
</style>
|
||||
<script type="text/javascript" id="www-widgetapi-script" src="https://s.ytimg.com/yts/jsbin/www-widgetapi-vflxHXqxJ/www-widgetapi.js" async=""></script><script type="text/javascript" id="www-widgetapi-script" src="https://s.ytimg.com/yts/jsbin/www-widgetapi-vflv4EGJj/www-widgetapi.js" async=""></script><script type="text/javascript" id="www-widgetapi-script" src="https://s.ytimg.com/yts/jsbin/www-widgetapi-vflv4EGJj/www-widgetapi.js" async=""></script><script type="text/javascript" id="www-widgetapi-script" src="https://s.ytimg.com/yts/jsbin/www-widgetapi-vflv4EGJj/www-widgetapi.js" async=""></script><script type="text/javascript" id="www-widgetapi-script" src="https://s.ytimg.com/yts/jsbin/www-widgetapi-vflv4EGJj/www-widgetapi.js" async=""></script>
|
||||
<script type="text/javascript" id="www-widgetapi-script" src="https://s.ytimg.com/yts/jsbin/www-widgetapi-vflv4EGJj/www-widgetapi.js" async=""></script><script type="text/javascript" id="www-widgetapi-script" src="https://s.ytimg.com/yts/jsbin/www-widgetapi-vflv4EGJj/www-widgetapi.js" async=""></script><script src="https://www.youtube.com/iframe_api?v=2.9.3" id="YTAPI"></script>
|
||||
<meta charset="utf-8">
|
||||
<meta http-equiv="X-UA-Compatible" content="IE=edge">
|
||||
<title>RetryLife</title>
|
||||
<meta name="description" content="">
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1">
|
||||
|
||||
<!-- Favicon -->
|
||||
<link rel="shortcut icon" href="favicon.ico">
|
||||
<!-- Bootstrap -->
|
||||
<link rel="stylesheet" href="http://themes.89elements.com/definity-html/assets/styles/vendor/bootstrap.min.css">
|
||||
<!-- Fonts -->
|
||||
<link rel="stylesheet" href="http://themes.89elements.com/definity-html/assets/fonts/et-lineicons/css/style.css">
|
||||
<link rel="stylesheet" href="http://themes.89elements.com/definity-html/assets/fonts/linea-font/css/linea-font.css">
|
||||
<link rel="stylesheet" href="http://themes.89elements.com/definity-html/assets/fonts/fontawesome/css/font-awesome.min.css">
|
||||
<!-- Slider -->
|
||||
<link rel="stylesheet" href="http://themes.89elements.com/definity-html/assets/styles/vendor/slick.css">
|
||||
<!-- Lightbox -->
|
||||
<link rel="stylesheet" href="http://themes.89elements.com/definity-html/assets/styles/vendor/magnific-popup.css">
|
||||
<!-- Animate.css -->
|
||||
<link rel="stylesheet" href="http://themes.89elements.com/definity-html/assets/styles/vendor/animate.css">
|
||||
|
||||
|
||||
<!-- Definity CSS -->
|
||||
<link rel="stylesheet" href="http://themes.89elements.com/definity-html/assets/styles/main.css">
|
||||
<link rel="stylesheet" href="http://themes.89elements.com/definity-html/assets/styles/responsive.css">
|
||||
|
||||
<!-- JS -->
|
||||
<script src="http://ajax.googleapis.com/ajax/libs/webfont/1/webfont.js" type="text/javascript" async=""></script><script async="" src="//www.googletagmanager.com/gtm.js?id=GTM-MH7TSF"></script><script src="assets/js/vendor/modernizr-2.8.3.min.js"></script><link rel="stylesheet" href="http://fonts.googleapis.com/css?family=Open+Sans:300italic,800italic,400,300,600,700,800%7CMontserrat:400,700&subset=latin,latin" media="all">
|
||||
<script type="text/javascript" charset="UTF-8" src="https://maps.googleapis.com/maps-api-v3/api/js/30/5/common.js"></script><script type="text/javascript" charset="UTF-8" src="https://maps.googleapis.com/maps-api-v3/api/js/30/5/util.js"></script><script type="text/javascript" charset="UTF-8" src="https://maps.googleapis.com/maps-api-v3/api/js/30/5/stats.js"></script><script type="text/javascript" charset="UTF-8" src="https://maps.googleapis.com/maps-api-v3/api/js/30/5/map.js"></script><script type="text/javascript" charset="UTF-8" src="https://maps.googleapis.com/maps-api-v3/api/js/30/5/marker.js"></script><style type="text/css">.gm-style {
|
||||
font: 400 11px Roboto, Arial, sans-serif;
|
||||
text-decoration: none;
|
||||
}
|
||||
.gm-style img { max-width: none; }</style><script type="text/javascript" charset="UTF-8" src="https://maps.googleapis.com/maps-api-v3/api/js/30/5/onion.js"></script><script type="text/javascript" charset="UTF-8" src="https://maps.googleapis.com/maps-api-v3/api/js/30/5/controls.js"></script><script type="text/javascript" charset="UTF-8" src="https://maps.googleapis.com/maps-api-v3/api/js/30/5/common.js"></script><script type="text/javascript" charset="UTF-8" src="https://maps.googleapis.com/maps-api-v3/api/js/30/5/util.js"></script><script type="text/javascript" charset="UTF-8" src="https://maps.googleapis.com/maps-api-v3/api/js/30/5/stats.js"></script><style id="__web-inspector-hide-shortcut-style__" type="text/css">
|
||||
.__web-inspector-hide-shortcut__, .__web-inspector-hide-shortcut__ *, .__web-inspector-hidebefore-shortcut__::before, .__web-inspector-hideafter-shortcut__::after
|
||||
{
|
||||
visibility: hidden !important;
|
||||
}
|
||||
</style></head>
|
||||
<body id="page-top" data-spy="scroll" data-target=".navbar">
|
||||
<!--[if lt IE 8]>
|
||||
<p class="browserupgrade">You are using an <strong>outdated</strong> browser. Please <a href="http://browsehappy.com/">upgrade your browser</a> to improve your experience.</p>
|
||||
<![endif]-->
|
||||
|
||||
|
||||
<div class="preloader" style="display: none;">
|
||||
<img src="assets/images/loader.svg" alt="Loading..." style="display: none;">
|
||||
</div>
|
||||
|
||||
|
||||
|
||||
<!-- ========== Navigation ========== -->
|
||||
|
||||
<nav class="navbar navbar-default navbar-fixed-top trans-helper navbar-fw navbar-trans navbar-trans-dark" role="navigation">
|
||||
|
||||
|
||||
</nav><!-- / .navbar -->
|
||||
|
||||
|
||||
|
||||
<!-- ========== Hero Cover ========== -->
|
||||
|
||||
<div id="home" class="main-demo-hero">
|
||||
<div class="bg-overlay">
|
||||
|
||||
<!-- Hero Content -->
|
||||
<div class="hero-content-wrapper" style="background-color: rgba(0, 203, 117, 0.18);bacoground-image:url();">
|
||||
<div class="hero-content">
|
||||
|
||||
<h1 class="hero-lead wow fadeInLeft" data-wow-duration="1.5s" style="visibility: visible; animation-duration: 1.5s; animation-name: fadeInLeft;">RetryLife</h1>
|
||||
<h4 class="h-alt hero-subheading wow fadeIn" data-wow-duration="2s" data-wow-delay=".7s" style="visibility: visible; animation-duration: 2s; animation-delay: 0.7s; animation-name: fadeIn;">Video, Music, Animation, Graphic Design</h4>
|
||||
<a href="#welcome" class="btn wow fadeIn" data-wow-duration="2s" data-wow-delay="1s" style="visibility: visible; animation-duration: 2s; animation-delay: 1s; animation-name: fadeIn;">Let's Go</a>
|
||||
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<!-- Scroller -->
|
||||
|
||||
|
||||
</div><!-- / .bg-overlay -->
|
||||
</div><!-- / .main-hero-2 -->
|
||||
|
||||
|
||||
|
||||
<!-- ========== Welcome ========== -->
|
||||
|
||||
<section id="welcome" class="container">
|
||||
<div class="row">
|
||||
|
||||
<div class="ws-l"></div>
|
||||
|
||||
<header class="sec-heading">
|
||||
<h2>Welcome</h2>
|
||||
<span class="subheading">Imagine. Create. Share.</span>
|
||||
</header>
|
||||
|
||||
<div class="col-md-offset-2 col-md-8 text-center ws-m">
|
||||
<p>Welcome to RetryLife, a group of close friends who have a passion for creating interesting content of many diffrent varieties. This website is where you can come to find all of our published work. </p>
|
||||
</div>
|
||||
|
||||
|
||||
|
||||
</div><!-- / .row -->
|
||||
</section><!-- / .section -->
|
||||
|
||||
|
||||
|
||||
<div class="cta-link">
|
||||
<div class="bg-overlay">
|
||||
|
||||
<div class="cta-wrapper">
|
||||
<h3 class="h-alt wow fadeIn" data-wow-delay=".1s" data-wow-duration="1s" style="visibility: visible; animation-duration: 1s; animation-delay: 0.1s; animation-name: fadeIn;">Want to support us?</h3>
|
||||
<a href="https://www.patreon.com/bePatron?u=7175648" class="btn btn-light btn-large wow fadeIn" data-wow-delay=".3s" data-wow-duration="1s" style="visibility: visible; animation-duration: 1s; animation-delay: 0.3s; animation-name: fadeIn;" data-patreon-widget-type="become-patron-button">Become A Patron</a>
|
||||
</div>
|
||||
|
||||
</div>
|
||||
</div><!-- ========== Services ========== -->
|
||||
|
||||
<div class="gray-bg">
|
||||
<section id="services" class="container ft-cards">
|
||||
<div class="row section">
|
||||
|
||||
<header class="sec-heading">
|
||||
<h2>What we do</h2>
|
||||
|
||||
</header>
|
||||
|
||||
<!-- Item 1 -->
|
||||
<div class="col-lg-4 col-md-6 mb-sm-50">
|
||||
<div class="ft-item wow fadeInUp" data-wow-duration="1s" style="visibility: visible; animation-duration: 1s; animation-name: fadeInUp;">
|
||||
|
||||
<h4>Music</h4>
|
||||
<p>We work together to produce cool music and also colaborate with many people.</p>
|
||||
<a href="http://retrylife.bandcamp.com">Learn more </a>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<!-- Item 2 -->
|
||||
<div class="col-lg-4 col-md-6 mb-sm-50">
|
||||
<div class="ft-item wow fadeInUp" data-wow-duration="1s" data-wow-delay=".3s" style="visibility: visible; animation-duration: 1s; animation-delay: 0.3s; animation-name: fadeInUp;">
|
||||
|
||||
<h4>Video</h4>
|
||||
<p>We are constently trying out new video formats to bring content to our fans.</p>
|
||||
<a href="#portfolio">Learn more </a>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<!-- Item 3 -->
|
||||
<div class="col-lg-4 col-md-6 mb-sm-50">
|
||||
<div class="ft-item wow fadeInUp" data-wow-duration="1s" data-wow-delay=".6s" style="visibility: visible; animation-duration: 1s; animation-delay: 0.6s; animation-name: fadeInUp;">
|
||||
|
||||
<h4>Graphic Design</h4>
|
||||
<p>We produce many high quality graphics and digital art peices.</p>
|
||||
<a href="http://glitchop.newgrounds.com">Learn more </a>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
</div><!-- / .row -->
|
||||
</section>
|
||||
</div><!-- / .gray-bg -->
|
||||
|
||||
|
||||
|
||||
<!-- ========== Number Counters - Parallax ========== -->
|
||||
|
||||
<div class="number-counters" style="background-color:#1f2021;background-image: url(">
|
||||
<div class="container">
|
||||
<div id="counters" class="row count-wrapper">
|
||||
|
||||
<!-- Item 1 -->
|
||||
<div class="col-md-3 mb-sm-100 count-item wow fadeIn" data-wow-duration="1s" data-wow-delay=".3s" style="visibility: visible; animation-duration: 1s; animation-delay: 0.3s; animation-name: fadeIn;">
|
||||
<span id="count-1" class="count-nbr">100+</span>
|
||||
<span class="count-text">Songs published</span>
|
||||
</div>
|
||||
|
||||
<!-- Item 2 -->
|
||||
<div class="col-md-3 mb-sm-100 count-item wow fadeIn" data-wow-duration="1s" style="visibility: visible; animation-duration: 1s; animation-name: fadeIn;">
|
||||
<span id="count-2" class="count-nbr">2000+</span>
|
||||
<span class="count-text">Plays</span>
|
||||
</div>
|
||||
|
||||
<!-- Item 3 -->
|
||||
<div class="col-md-3 mb-sm-100 count-item wow fadeIn" data-wow-duration="1s" style="visibility: visible; animation-duration: 1s; animation-name: fadeIn;">
|
||||
<span id="count-3" class="count-nbr">6</span>
|
||||
<span class="count-text">members</span>
|
||||
</div>
|
||||
|
||||
<!-- Item 4 -->
|
||||
<div class="col-md-3 count-item wow fadeIn" data-wow-duration="1s" data-wow-delay=".3s" style="visibility: visible; animation-duration: 1s; animation-delay: 0.3s; animation-name: fadeIn;">
|
||||
<span id="count-4" class="count-nbr">80+</span>
|
||||
<span class="count-text">dedicated viewers</span>
|
||||
</div>
|
||||
|
||||
</div><!-- / .row -->
|
||||
</div><!-- / .container -->
|
||||
</div><!-- / .number-counters -->
|
||||
|
||||
|
||||
|
||||
<div id="portfolio" class="container-fluid ft-hover-item">
|
||||
<div class="row">
|
||||
|
||||
<!-- Item 1 -->
|
||||
<div class="ft-item ft-1 col-md-6" style="background-image: url('/img/rtl.png')">
|
||||
<div class="bg-overlay">
|
||||
|
||||
<div class="content-wrapper">
|
||||
<a><h3>RetryLife Official</h3></a>
|
||||
<p>A mix of music videos, audio visualizers, and general fun</p>
|
||||
<a href="https://www.youtube.com/channel/UCrHT3Lt0Mg90bspbMHJfTcA" class="btn-ghost btn-ghost-light ft-button">Check it out</a>
|
||||
</div>
|
||||
|
||||
</div><!-- / .bg-overlay -->
|
||||
</div><!-- / .ft-item -->
|
||||
|
||||
<!-- Item 2 -->
|
||||
<div class="ft-item ft-2 col-md-6" style="background-image:url('/img/nds.png');background-color:">
|
||||
<div class="bg-overlay">
|
||||
|
||||
<div class="content-wrapper">
|
||||
<a><h3>Nathan Desjardins</h3></a>
|
||||
<p>Timelapses and voiceovers. Here, you can find the arty side of the group</p>
|
||||
<a href="https://www.youtube.com/channel/UCxzARKt0_U0sLHbF4pDN1Pw" class="btn-ghost btn-ghost-light ft-button">Check it out</a>
|
||||
</div>
|
||||
|
||||
</div><!-- / .bg-overlay -->
|
||||
</div><!-- / .ft-item -->
|
||||
|
||||
</div><!-- / .row -->
|
||||
</div><!-- / .container-fluid -->
|
||||
|
||||
|
||||
|
||||
<div class="cta-link">
|
||||
<div class="bg-overlay">
|
||||
|
||||
<div class="cta-wrapper">
|
||||
<h3 class="h-alt wow fadeIn" data-wow-delay=".1s" data-wow-duration="1s" style="visibility: visible; animation-duration: 1s; animation-delay: 0.1s; animation-name: fadeIn;">Already a member of the group?</h3>
|
||||
<a href="http://retrylife.slack.com" class="btn btn-light btn-large wow fadeIn" data-wow-delay=".3s" data-wow-duration="1s" style="visibility: visible; animation-duration: 1s; animation-delay: 0.3s; animation-name: fadeIn;">Go to the hub</a>
|
||||
</div>
|
||||
|
||||
</div>
|
||||
</div><!-- / .dark-bg .cta-link -->
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
<div id="about" class="gray-bg">
|
||||
<section class="container section team-3col">
|
||||
<div class="row">
|
||||
|
||||
<header class="sec-heading">
|
||||
<h2>Meet the team</h2>
|
||||
|
||||
</header>
|
||||
|
||||
|
||||
<!-- Member 1 -->
|
||||
<div class="col-lg-4 col-md-6 mb-sm-50">
|
||||
<div class="t-item wow fadeIn" data-wow-duration="1s" style="visibility: visible; animation-duration: 1s; animation-name: fadeIn;">
|
||||
|
||||
<!-- Image -->
|
||||
|
||||
|
||||
<!-- Info -->
|
||||
<div class="t-info">
|
||||
<h4 class="t-name">Evan Pratten</h4>
|
||||
<span class="t-role">Video Editor & Musician</span>
|
||||
<ul class="social-links">
|
||||
<li><a href="MAILTO:ewpratten@retrylife.ca"><i class="fa fa-facebook"></i></a></li>
|
||||
|
||||
|
||||
|
||||
</ul>
|
||||
</div>
|
||||
|
||||
</div><!-- / .t-item -->
|
||||
</div><!-- / .col-md-4 -->
|
||||
|
||||
|
||||
<!-- Member 2 -->
|
||||
<div class="col-lg-4 col-md-6 mb-sm-50">
|
||||
<div class="t-item wow fadeIn" data-wow-duration="1s" data-wow-delay=".3s" style="visibility: visible; animation-duration: 1s; animation-delay: 0.3s; animation-name: fadeIn;">
|
||||
|
||||
<!-- Image -->
|
||||
|
||||
|
||||
<!-- Info -->
|
||||
<div class="t-info">
|
||||
<h4 class="t-name">russle seck</h4>
|
||||
<span class="t-role">Video editor & Musician</span>
|
||||
<ul class="social-links">
|
||||
<li><a href="MAILTO:russmemusic@retrylife.ca"><i class="fa fa-facebook"></i></a></li>
|
||||
|
||||
|
||||
|
||||
</ul>
|
||||
</div>
|
||||
|
||||
</div><!-- / .t-item -->
|
||||
</div><!-- / .col-md-4 -->
|
||||
|
||||
|
||||
<!-- Member 3 -->
|
||||
<div class="col-lg-4 col-md-6 mb-sm-50">
|
||||
<div class="t-item wow fadeIn" data-wow-duration="1s" data-wow-delay=".6s" style="visibility: visible; animation-duration: 1s; animation-delay: 0.6s; animation-name: fadeIn;">
|
||||
|
||||
<!-- Image -->
|
||||
|
||||
|
||||
<!-- Info -->
|
||||
<div class="t-info">
|
||||
<h4 class="t-name">Nathan Desjardins</h4>
|
||||
<span class="t-role">Graphic Designer</span>
|
||||
<ul class="social-links">
|
||||
<li><a href="MAILTO:nathan@retrylife.ca"><i class="fa fa-facebook"></i></a></li>
|
||||
|
||||
|
||||
|
||||
</ul>
|
||||
</div>
|
||||
|
||||
</div><!-- / .t-item -->
|
||||
</div><!-- / .col-md-4 -->
|
||||
|
||||
|
||||
</div><!-- / .row -->
|
||||
</section><!-- / .contianer -->
|
||||
</div><!-- / .gray-bg -->
|
||||
|
||||
|
||||
<!-- ========== Footer ========== -->
|
||||
|
||||
<footer class="footer-widgets">
|
||||
<div class="container">
|
||||
<div class="row section">
|
||||
|
||||
<!-- About Us -->
|
||||
<div class="col-md-3 col-sm-6 mb-sm-100">
|
||||
<div class="widget about-widget">
|
||||
<h5 class="header-widget">About Us</h5>
|
||||
<p>
|
||||
Welcome to RetryLife, a group of close friends who have a passion for creating interesting content of many diffrent varieties. This website is where you can come to find all of our published work.</p>
|
||||
|
||||
|
||||
</div><!-- / .widget -->
|
||||
</div><!-- / .col-md-3 -->
|
||||
|
||||
|
||||
</div><!-- / .row -->
|
||||
</div><!-- / .container -->
|
||||
|
||||
|
||||
<!-- Copyright -->
|
||||
<!-- / .copyright -->
|
||||
|
||||
</footer><!-- / .footer-widgets -->
|
||||
|
||||
|
||||
|
||||
|
||||
<style>[href^="https://www.googleadservices.com/pagead/aclk?"]
|
||||
{display:none !important;}</style></body></html>
|
@ -1,68 +0,0 @@
|
||||
==================================================================
|
||||
https://keybase.io/ewpratten
|
||||
--------------------------------------------------------------------
|
||||
|
||||
I hereby claim:
|
||||
|
||||
* I am an admin of http://retrylife.ca
|
||||
* I am ewpratten (https://keybase.io/ewpratten) on keybase.
|
||||
* I have a public key with fingerprint DD15 BE72 F652 984A ED9E C033 56F5 A6FB 5A8E EF90
|
||||
|
||||
To do so, I am signing this object:
|
||||
|
||||
{
|
||||
"body": {
|
||||
"key": {
|
||||
"eldest_kid": "010160a7afd6a7099e5079470c930b62e422a3f4b8a0c08482c174e5356f23b7b66f0a",
|
||||
"fingerprint": "dd15be72f652984aed9ec03356f5a6fb5a8eef90",
|
||||
"host": "keybase.io",
|
||||
"key_id": "56f5a6fb5a8eef90",
|
||||
"kid": "010160a7afd6a7099e5079470c930b62e422a3f4b8a0c08482c174e5356f23b7b66f0a",
|
||||
"uid": "bffaefed9cc265096ca9aec784253419",
|
||||
"username": "ewpratten"
|
||||
},
|
||||
"service": {
|
||||
"hostname": "retrylife.ca",
|
||||
"protocol": "http:"
|
||||
},
|
||||
"type": "web_service_binding",
|
||||
"version": 1
|
||||
},
|
||||
"ctime": 1512755987,
|
||||
"expire_in": 157680000,
|
||||
"prev": "5b6fb0129c86651cb820c7769f26d4eec7c254c4263debe5cee933b2a9ddf4c7",
|
||||
"seqno": 8,
|
||||
"tag": "signature"
|
||||
}
|
||||
|
||||
which yields the signature:
|
||||
|
||||
-----BEGIN PGP MESSAGE-----
|
||||
Version: Keybase OpenPGP v2.0.76
|
||||
Comment: https://keybase.io/crypto
|
||||
|
||||
yMIrAnicrVJbSBVRFL3XMssMg6KXPacbkYnOnJlzZuaGkFBJhSRB2sO6nDmzR6fs
|
||||
3mnueE18QYU97B2lfUQPxML8MCKIwMjSiOynzOj1E0YUFZEURkR2Ruyvz87P4eyz
|
||||
1tprL3b3pDGB1OCp9urclClFfcHerqaKwObMvinVghEzq4RwtbADRi4oNyHuRXbY
|
||||
phAWREmUiEhVapmEqqKuAxZVXVFFpsuiQRAoCFHZUgyNikzUFA0xSVUAy5hYSDZU
|
||||
gxBLpEKWYNnRUnAd1456XNY0JWyAiiyCka4pFEwdmCj7LEyJZWCqAVi6yIllsbjP
|
||||
4OYMGodsO8Zr/BEZsfcP/H/2XTEiZ1gWBYu7ZAwRLOqEUZ0CUzUFYVmRdB8YBzdK
|
||||
dwJHQ6XjUs+DqFCbJfBywmbgJ+uPMgpxwXOrym0LspnfxXFjXozFyvlPmec5YZ/o
|
||||
VTk+shKMyKhGxLCjJs+RExLgxu1YVAhLHMk82xeVsIRUjHVNzRJgt2O7ELF9BFaJ
|
||||
JvLjt4GEn5rBIxMlpDONECwxQ0MiU1WiW4iYCvC5GMIKUxCRTTAAMwBdlg1EddO0
|
||||
FKYK/lS7ojEhrHGbtJRLxu3SKPUqXBBq794pGRsIpgbGJSfx/ZoaSJ0w+e/Wxeel
|
||||
DG8KpS+ub5u/7k3ZrWHc+jhpaWZJye3w9rbevVfvZ0RujT8/PWPXtiXLt0Y6a27m
|
||||
fM0ZDDec7Rl809tz7Gf/9NX1b9XnaR/GfOna9rb8/Yac3WUD3ZmS++7o6RV7Dsz5
|
||||
EZyRiOSzWSXXOu4KBSmSnn/o8b7vr546uT2o4fUzEqJH2kIF40I1jU7xdRld+VVU
|
||||
Z/TnPBi49Pna2fffZz5anWit+ja08syNc2sur6qftWpZY1rf5nULag6nL5WGCi60
|
||||
DOQu6txyvEU+kfe6eGHPiy/dye3Be/kZQ4XZv+s6Nm4tdDube6f9vIm25D25cfDk
|
||||
S+tBw/4Xc52i5ov9wY9N62d/fPhpcKK69g97wj+u
|
||||
=VeZ6
|
||||
-----END PGP MESSAGE-----
|
||||
|
||||
And finally, I am proving ownership of this host by posting or
|
||||
appending to this document.
|
||||
|
||||
View my publicly-auditable identity here: https://keybase.io/ewpratten
|
||||
|
||||
==================================================================
|
@ -1,46 +0,0 @@
|
||||
<head>
|
||||
<title>RetryLife</title>
|
||||
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0-alpha.6/css/bootstrap.min.css" integrity="sha384-rwoIResjU2yc3z8GV/NPeZWAv56rSmLldC3R/AZzGRnGxQQKnKkoFVhFQhNUwEyJ" crossorigin="anonymous">
|
||||
<link href='https://fonts.googleapis.com/css?family=Roboto' rel='stylesheet'>
|
||||
<link rel="shortcut icon" type="image/x-icon" href="../favicon.ico" />
|
||||
<style>
|
||||
body {
|
||||
font-family: Roboto;
|
||||
margin: 0;
|
||||
padding: 0;
|
||||
}
|
||||
</style>
|
||||
|
||||
</head>
|
||||
|
||||
<body>
|
||||
<div style="width:100%;height:15%;">
|
||||
<div style="height:30%"></div>
|
||||
<h1 style="float:left;margin-left:24%;font-size:130px;">RetryLife</h1>
|
||||
</div>
|
||||
|
||||
<div style="height:10%;width:100%;">
|
||||
<div class="btn-group btn-group-lg" role="group" aria-label="..." style="float:left;margin-left:8%;font-size:130px;">
|
||||
|
||||
<a target="main" href="../music/index-mobile.html"><button type="button" class="btn btn-info" style="font-size:60px">Music</button></a>
|
||||
<div style="width:10%;color:white;">-</div>
|
||||
<a target="main" href="../youtube.html"><button type="button" class="btn btn-primary" style="font-size:60px">Youtube</button></a>
|
||||
<div style="width:10%;color:white;">-</div>
|
||||
<a href="https://www.patreon.com/bePatron?u=7175648"><button type="button" class="btn btn-info" style="font-size:60px">Support Us</button></a>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
|
||||
<div style="width:100%;height:73.8%;padding:0;margin:0;">
|
||||
<iframe name="main" frameBorder="0" style="height:100%;width:100%;" src="../about-mobile.html"></iframe>
|
||||
</div>
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
<script src="https://code.jquery.com/jquery-3.1.1.slim.min.js" integrity="sha384-A7FZj7v+d/sdmMqp/nOQwliLvUsJfDHW+k9Omg/a/EheAdgtzNs3hpfag6Ed950n" crossorigin="anonymous"></script>
|
||||
<script src="https://cdnjs.cloudflare.com/ajax/libs/tether/1.4.0/js/tether.min.js" integrity="sha384-DztdAPBWPRXSA/3eYEEUWrWCy7G5KFbe8fFjk5JAIxUYHKkDx6Qin1DkWx51bBrb" crossorigin="anonymous"></script>
|
||||
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0-alpha.6/js/bootstrap.min.js" integrity="sha384-vBWWzlZJ8ea9aCX4pEW3rVHjgjt7zpkNpZk+02D9phzyeVkE+jo0ieGizqPLForn" crossorigin="anonymous"></script>
|
||||
|
||||
</body>
|
@ -1,41 +0,0 @@
|
||||
<head>
|
||||
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0-alpha.6/css/bootstrap.min.css" integrity="sha384-rwoIResjU2yc3z8GV/NPeZWAv56rSmLldC3R/AZzGRnGxQQKnKkoFVhFQhNUwEyJ" crossorigin="anonymous">
|
||||
<link href='https://fonts.googleapis.com/css?family=Roboto' rel='stylesheet'>
|
||||
<style>
|
||||
body {
|
||||
font-family: Roboto;
|
||||
margin: 0;
|
||||
padding: 0;
|
||||
}
|
||||
</style>
|
||||
|
||||
</head>
|
||||
<body>
|
||||
|
||||
<div style="height:97%;width:90%;margin-left:6%;">
|
||||
|
||||
<div class="featured" style="height:100%;width:60%;">
|
||||
|
||||
|
||||
<iframe style="border: 0; width: 350px; height: 650px;transform: scale(2.5);transform-origin: 0 0;" src="../content/newrelease.html" seamless><a href="http://retrylife.bandcamp.com/album/sir-dankleys-mlg-restaurant">Sir Dankley's MLG Restaurant by RetryLife</a></iframe>
|
||||
|
||||
<div style="height:80%"></div>
|
||||
|
||||
|
||||
<div style="height:0.5rem;"></div>
|
||||
<a href="https://retryilfe.bandcamp.com" class="btn btn-primary" style="width:95%;font-size:80px;margin-left:26%">More Music!</a>
|
||||
|
||||
|
||||
|
||||
|
||||
</div>
|
||||
|
||||
</div>
|
||||
|
||||
|
||||
|
||||
<script src="https://code.jquery.com/jquery-3.1.1.slim.min.js" integrity="sha384-A7FZj7v+d/sdmMqp/nOQwliLvUsJfDHW+k9Omg/a/EheAdgtzNs3hpfag6Ed950n" crossorigin="anonymous"></script>
|
||||
<script src="https://cdnjs.cloudflare.com/ajax/libs/tether/1.4.0/js/tether.min.js" integrity="sha384-DztdAPBWPRXSA/3eYEEUWrWCy7G5KFbe8fFjk5JAIxUYHKkDx6Qin1DkWx51bBrb" crossorigin="anonymous"></script>
|
||||
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0-alpha.6/js/bootstrap.min.js" integrity="sha384-vBWWzlZJ8ea9aCX4pEW3rVHjgjt7zpkNpZk+02D9phzyeVkE+jo0ieGizqPLForn" crossorigin="anonymous"></script>
|
||||
|
||||
</body>
|
@ -1,59 +0,0 @@
|
||||
<head>
|
||||
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0-alpha.6/css/bootstrap.min.css" integrity="sha384-rwoIResjU2yc3z8GV/NPeZWAv56rSmLldC3R/AZzGRnGxQQKnKkoFVhFQhNUwEyJ" crossorigin="anonymous">
|
||||
<link href='https://fonts.googleapis.com/css?family=Roboto' rel='stylesheet'>
|
||||
<style>
|
||||
body {
|
||||
font-family: Roboto;
|
||||
margin: 0;
|
||||
padding: 0;
|
||||
background:none transparent;
|
||||
}
|
||||
</style>
|
||||
|
||||
</head>
|
||||
<body>
|
||||
|
||||
<div style="height:97%;width:100%;">
|
||||
|
||||
<div class="featured" style="float:left;height:100%;width:60%;">
|
||||
<div class="card" style="width: 98%;margin:0;">
|
||||
<div class="card-block">
|
||||
<h2>Newest Release</h2>
|
||||
|
||||
<iframe style="border: 0; width: 99%; height: 85%;" src="../content/newrelease.html" seamless><a href="http://retrylife.bandcamp.com/album/sir-dankleys-mlg-restaurant">Sir Dankley's MLG Restaurant by RetryLife</a></iframe>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
|
||||
<div class="about" style="float:right; width:40%;height:100%;">
|
||||
<div class="card" style="width: 13rem;">
|
||||
<div class="card-block">
|
||||
<p class="card-text">Hey! this isn't our only release. The rest can be found by clicking on the button below.</p>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div style="height:0.5rem;"></div>
|
||||
<div class="card" style="width: 13rem;">
|
||||
<div class="card-block">
|
||||
<a href="https://retryilfe.bandcamp.com" class="btn btn-primary" style="width:10.2rem;">More Music!</a>
|
||||
|
||||
|
||||
</div>
|
||||
</div>
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
</div>
|
||||
|
||||
</div>
|
||||
|
||||
|
||||
|
||||
<script src="https://code.jquery.com/jquery-3.1.1.slim.min.js" integrity="sha384-A7FZj7v+d/sdmMqp/nOQwliLvUsJfDHW+k9Omg/a/EheAdgtzNs3hpfag6Ed950n" crossorigin="anonymous"></script>
|
||||
<script src="https://cdnjs.cloudflare.com/ajax/libs/tether/1.4.0/js/tether.min.js" integrity="sha384-DztdAPBWPRXSA/3eYEEUWrWCy7G5KFbe8fFjk5JAIxUYHKkDx6Qin1DkWx51bBrb" crossorigin="anonymous"></script>
|
||||
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0-alpha.6/js/bootstrap.min.js" integrity="sha384-vBWWzlZJ8ea9aCX4pEW3rVHjgjt7zpkNpZk+02D9phzyeVkE+jo0ieGizqPLForn" crossorigin="anonymous"></script>
|
||||
|
||||
</body>
|
@ -1,79 +0,0 @@
|
||||
<head>
|
||||
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0-alpha.6/css/bootstrap.min.css" integrity="sha384-rwoIResjU2yc3z8GV/NPeZWAv56rSmLldC3R/AZzGRnGxQQKnKkoFVhFQhNUwEyJ" crossorigin="anonymous">
|
||||
<link href='https://fonts.googleapis.com/css?family=Roboto' rel='stylesheet'>
|
||||
<style>
|
||||
body {
|
||||
font-family: Roboto;
|
||||
margin: 0;
|
||||
padding: 0;
|
||||
background:none transparent;
|
||||
}
|
||||
</style>
|
||||
|
||||
</head>
|
||||
<body>
|
||||
|
||||
|
||||
<div style="width:80%;">
|
||||
<div class="card-block">
|
||||
|
||||
<table>
|
||||
<tr>
|
||||
<th>
|
||||
<div class="card" style="width: 100%;height:100%;">
|
||||
<div class="card-block">
|
||||
<h4 class="card-title">Are-O</h4>
|
||||
<p class="card-text">Front-end Developer, Musician, Video Creator</p>
|
||||
|
||||
</div>
|
||||
</div>
|
||||
</th>
|
||||
<th>
|
||||
<div class="card" style="width: 100%;height:100%;">
|
||||
<div class="card-block">
|
||||
<h4 class="card-title">/\STROBLEME</h4>
|
||||
<p class="card-text">Artist, Musician, Video Creator, Animator</p>
|
||||
|
||||
</div>
|
||||
</div>
|
||||
|
||||
|
||||
</tr>
|
||||
<tr>
|
||||
<th>
|
||||
|
||||
|
||||
|
||||
<div class="card" style="width: 100%;height:100%;">
|
||||
<div class="card-block">
|
||||
<h4 class="card-title">Russme Music</h4>
|
||||
<p class="card-text">Musician, Video Creator, Composer</p>
|
||||
|
||||
</div>
|
||||
</div>
|
||||
</th>
|
||||
<th>
|
||||
|
||||
<div class="card" style="width: 100%;">
|
||||
<div class="card-block">
|
||||
<h4 class="card-title">Low-key Legend</h4>
|
||||
<p class="card-text">Album Name Creator, Musician</p>
|
||||
|
||||
</div>
|
||||
</div>
|
||||
|
||||
|
||||
</th>
|
||||
</tr>
|
||||
</table>
|
||||
|
||||
</div>
|
||||
</div>
|
||||
|
||||
|
||||
|
||||
<script src="https://code.jquery.com/jquery-3.1.1.slim.min.js" integrity="sha384-A7FZj7v+d/sdmMqp/nOQwliLvUsJfDHW+k9Omg/a/EheAdgtzNs3hpfag6Ed950n" crossorigin="anonymous"></script>
|
||||
<script src="https://cdnjs.cloudflare.com/ajax/libs/tether/1.4.0/js/tether.min.js" integrity="sha384-DztdAPBWPRXSA/3eYEEUWrWCy7G5KFbe8fFjk5JAIxUYHKkDx6Qin1DkWx51bBrb" crossorigin="anonymous"></script>
|
||||
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0-alpha.6/js/bootstrap.min.js" integrity="sha384-vBWWzlZJ8ea9aCX4pEW3rVHjgjt7zpkNpZk+02D9phzyeVkE+jo0ieGizqPLForn" crossorigin="anonymous"></script>
|
||||
|
||||
</body>
|
@ -1 +0,0 @@
|
||||
<iframe style="border: 0; width: 400px; height: 836px;" src="https://bandcamp.com/EmbeddedPlayer/album=3953554787/size=large/bgcol=ffffff/linkcol=0687f5/transparent=true/tracklist=true/tracks=365066597,2765021553,3634496643,101379180,3147738507,1751976331,4065347594,3030955851,2307618914,3876725018/esig=162a28fcee20edb977b47b0b9681a15a/" seamless><a href="http://retrylife.bandcamp.com/album/x-mas-02">X-MAS 02 by RetryLife</a></iframe>
|
Before Width: | Height: | Size: 24 KiB |
@ -1 +0,0 @@
|
||||
https://rtlcommunity.herokuapp.com/projects/projectZERO
|
Before Width: | Height: | Size: 772 KiB |
Before Width: | Height: | Size: 2.0 MiB |
Before Width: | Height: | Size: 353 KiB |
Before Width: | Height: | Size: 318 B |
Before Width: | Height: | Size: 6.9 MiB |
Before Width: | Height: | Size: 2.7 MiB |
Before Width: | Height: | Size: 2.9 MiB |
Before Width: | Height: | Size: 2.1 MiB |
Before Width: | Height: | Size: 1.1 MiB |
@ -1,729 +0,0 @@
|
||||
<!--
|
||||
|
||||
_____ _ _ ____________ _____ ____
|
||||
| __ \ (_) | | |___ / ____| __ \ / __ \
|
||||
| |__) | __ ___ _ ___ ___| |_ / /| |__ | |__) | | | |
|
||||
| ___/ '__/ _ \| |/ _ \/ __| __| / / | __| | _ /| | | |
|
||||
| | | | | (_) | | __/ (__| |_ / /__| |____| | \ \| |__| |
|
||||
|_| |_| \___/| |\___|\___|\__/_____|______|_| \_\\____/
|
||||
_/ |
|
||||
|__/
|
||||
|
||||
|---------------------------------------------------------|
|
||||
| Website Credits |
|
||||
| Front / Back end: Evan Pratten |
|
||||
| Artwork: Nathan Desjardins |
|
||||
|---------------------------------------------------------|
|
||||
|
||||
Check out my main website:
|
||||
|
||||
Http://retrylife.ca
|
||||
|
||||
|
||||
Links:
|
||||
|
||||
Ewpratten:
|
||||
|
||||
Github: https://github.com/Ewpratten/
|
||||
Devrant: https://devrant.com/users/ewpratten
|
||||
|
||||
Nds:
|
||||
|
||||
Devrant: https://devrant.com/users/desjna
|
||||
|
||||
-----
|
||||
NOTES:
|
||||
|
||||
There is a lot of half working code here.. so sory if you cant figure it out.
|
||||
|
||||
I also was too lazy to comment the code.
|
||||
|
||||
-->
|
||||
|
||||
|
||||
|
||||
<!-- php link processing -->
|
||||
<?php
|
||||
if($_GET['redirect'] == "donate"){
|
||||
echo "<script>window.location = 'http://retrylife.ca/donate';</script>";
|
||||
}
|
||||
|
||||
// easter eggs
|
||||
|
||||
if($_GET['tgif'] == "true"){
|
||||
$TGIF = 1;
|
||||
}
|
||||
|
||||
// setcookie("name","value",time()+$int);
|
||||
|
||||
|
||||
|
||||
?>
|
||||
|
||||
<head>
|
||||
<title>ProjectZERO</title>
|
||||
<link rel="icon" type="image/png" href="./img/favicon.ico">
|
||||
<link href="./<?php if($_GET['theme'] == "dark"){echo "css/picnic.dark.css";}else{ echo "css/picnic.min.css";} ?>" rel="stylesheet" media="all">
|
||||
<link href="https://fonts.googleapis.com/css?family=Anton" rel="stylesheet">
|
||||
<meta name="viewport" content="width=device-width, inital-scale=1">
|
||||
<link href="css/hover.css" rel="stylesheet" media="all">
|
||||
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/2.0.2/jquery.min.js"></script>
|
||||
<!-- <link href="./css/main.css" rel="stylesheet" media="all"> -->
|
||||
<!-- Global site tag (gtag.js) - Google Analytics -->
|
||||
<script async src="https://www.googletagmanager.com/gtag/js?id=UA-61008630-1"></script>
|
||||
<script>
|
||||
window.dataLayer = window.dataLayer || [];
|
||||
function gtag(){dataLayer.push(arguments);}
|
||||
gtag('js', new Date());
|
||||
|
||||
gtag('config', 'UA-61008630-1');
|
||||
</script>
|
||||
|
||||
<style>
|
||||
#floater {
|
||||
float: left;
|
||||
height: 50%;
|
||||
width: 100%;
|
||||
margin-bottom: -110px;
|
||||
}
|
||||
#child {
|
||||
clear: both;
|
||||
height: 100px;
|
||||
text-align: center
|
||||
}
|
||||
.spacer {
|
||||
background-color: #2f3136;
|
||||
width: 100%;
|
||||
height: 10;
|
||||
}
|
||||
.front {
|
||||
width: auto;
|
||||
background-color: rgba(25, 29, 25, 0.7);
|
||||
color: #fff;
|
||||
}
|
||||
.coverimg {
|
||||
filter: blur(5px);
|
||||
// Browser Specific
|
||||
-webkit-filter: blur(5px);
|
||||
-moz-filter: blur(5px);
|
||||
-o-filter: blur(5px);
|
||||
-ms-filter: blur(5px);
|
||||
}
|
||||
footer {
|
||||
color: rgb(255, 255, 255);
|
||||
}
|
||||
#gradient {
|
||||
width: 100%;
|
||||
height: 100%;
|
||||
padding: 0px;
|
||||
margin: 0px;
|
||||
}
|
||||
.border {
|
||||
border-color: white;
|
||||
border-style: solid;
|
||||
width: fit-content;
|
||||
border-radius: 100%;
|
||||
}
|
||||
.ewp {
|
||||
border-radius: 100%;
|
||||
}
|
||||
a.button.hvr-bob {
|
||||
border-radius: 100%;
|
||||
background-color: rgba(255, 255, 255, 0);
|
||||
}
|
||||
img.dri {
|
||||
height: 20%;
|
||||
}
|
||||
a.abc {
|
||||
color: #405c7d;
|
||||
}
|
||||
.line .linev {
|
||||
background-color: black;
|
||||
}
|
||||
.line {
|
||||
height: 1;
|
||||
width: 100%;
|
||||
}
|
||||
.linev {
|
||||
height: 100%;
|
||||
width: 1;
|
||||
}
|
||||
.aptprice {
|
||||
background-color: #3d414a;
|
||||
color: whitesmoke;
|
||||
}
|
||||
#ring {
|
||||
background-color: #3d414a;
|
||||
color: whitesmoke;
|
||||
}
|
||||
.darkbox {
|
||||
border-color: white;
|
||||
border-width: 10px;
|
||||
}
|
||||
.darkbox {
|
||||
border-radius: .2em;
|
||||
border: 1px solid rgba(204, 204, 204, 0.14);
|
||||
}
|
||||
a.button {
|
||||
background-color: #b6bab6;
|
||||
}
|
||||
label.burger.button {
|
||||
background-color: #b6bab6;
|
||||
}
|
||||
button {
|
||||
background-color: #b6bab6;
|
||||
}
|
||||
|
||||
|
||||
</style>
|
||||
</head>
|
||||
<body>
|
||||
|
||||
<script>
|
||||
var colors = new Array(
|
||||
[62,35,255],
|
||||
[60,255,60],
|
||||
[255,35,98],
|
||||
[45,175,230],
|
||||
[255,0,255],
|
||||
[255,128,0]);
|
||||
|
||||
var step = 0;
|
||||
//color table indices for:
|
||||
// current color left
|
||||
// next color left
|
||||
// current color right
|
||||
// next color right
|
||||
var colorIndices = [0,1,2,3];
|
||||
|
||||
//transition speed
|
||||
var gradientSpeed = 0.002;
|
||||
|
||||
function updateGradient()
|
||||
{
|
||||
|
||||
if ( $===undefined ) return;
|
||||
|
||||
var c0_0 = colors[colorIndices[0]];
|
||||
var c0_1 = colors[colorIndices[1]];
|
||||
var c1_0 = colors[colorIndices[2]];
|
||||
var c1_1 = colors[colorIndices[3]];
|
||||
|
||||
var istep = 1 - step;
|
||||
var r1 = Math.round(istep * c0_0[0] + step * c0_1[0]);
|
||||
var g1 = Math.round(istep * c0_0[1] + step * c0_1[1]);
|
||||
var b1 = Math.round(istep * c0_0[2] + step * c0_1[2]);
|
||||
var color1 = "rgb("+r1+","+g1+","+b1+")";
|
||||
|
||||
var r2 = Math.round(istep * c1_0[0] + step * c1_1[0]);
|
||||
var g2 = Math.round(istep * c1_0[1] + step * c1_1[1]);
|
||||
var b2 = Math.round(istep * c1_0[2] + step * c1_1[2]);
|
||||
var color2 = "rgb("+r2+","+g2+","+b2+")";
|
||||
|
||||
$('#gradient').css({
|
||||
background: "-webkit-gradient(linear, left top, right top, from("+color1+"), to("+color2+"))"}).css({
|
||||
background: "-moz-linear-gradient(left, "+color1+" 0%, "+color2+" 100%)"});
|
||||
|
||||
step += gradientSpeed;
|
||||
if ( step >= 1 )
|
||||
{
|
||||
step %= 1;
|
||||
colorIndices[0] = colorIndices[1];
|
||||
colorIndices[2] = colorIndices[3];
|
||||
|
||||
//pick two new target color indices
|
||||
//do not pick the same as the current one
|
||||
colorIndices[1] = ( colorIndices[1] + Math.floor( 1 + Math.random() * (colors.length - 1))) % colors.length;
|
||||
colorIndices[3] = ( colorIndices[3] + Math.floor( 1 + Math.random() * (colors.length - 1))) % colors.length;
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
setInterval(updateGradient,10);
|
||||
</script>
|
||||
<div>
|
||||
<nav class="demo imponent">
|
||||
<a href="" class="brand">
|
||||
<span>
|
||||
<?php
|
||||
|
||||
// this is temp
|
||||
if($TGIF == 1){
|
||||
echo "ITS FRIDAY!";
|
||||
}
|
||||
else{
|
||||
if($_GET['scoreboard'] == "show"){
|
||||
echo "Your Score: ", $_GET['score'];
|
||||
}
|
||||
else{
|
||||
echo "Project ZERO";
|
||||
}}
|
||||
|
||||
?>
|
||||
</span>
|
||||
</a>
|
||||
<input id="bmenub" type="checkbox" class="show">
|
||||
<label for="bmenub" class="success burger button">menu</label>
|
||||
|
||||
<div class="menu">
|
||||
|
||||
|
||||
|
||||
<a href="https://twitter.com/ProjectZERO_nr?ref_src=twsrc%5Etfw" class="button">Twitter</a>
|
||||
|
||||
<a href="https://www.instagram.com/projectzero_nr/" class="button">Instagram</a>
|
||||
|
||||
<a href="/#office" class="button">Office Space</a>
|
||||
<a href="#housing" class="button">Housing</a>
|
||||
<a href="#design" class="button">Design</a>
|
||||
<?php
|
||||
$pagestate = $_GET['page'];
|
||||
if($pagestate == "")
|
||||
$currentPage = "home";
|
||||
if($currentPage != "home"){
|
||||
echo '<a href="./index.html" class="button">Home</a>';
|
||||
}
|
||||
?>
|
||||
</div>
|
||||
</nav>
|
||||
</div>
|
||||
|
||||
|
||||
|
||||
<br>
|
||||
<br>
|
||||
|
||||
<div class="frontpage" >
|
||||
|
||||
<img src="./img/cover.png" width="100%">
|
||||
</div>
|
||||
|
||||
|
||||
<!--
|
||||
<div style="height:300">
|
||||
<?php
|
||||
// if($_GET['lagmode'] != "reduce"){
|
||||
// echo '<div id="gradient" />';
|
||||
// }
|
||||
?>
|
||||
<!-- im a spacer -->
|
||||
|
||||
|
||||
<!--
|
||||
<div id="floater"></div>
|
||||
<div id="child">
|
||||
<div class="front">
|
||||
<h1>
|
||||
-->
|
||||
<?php
|
||||
|
||||
//$text = array("P", "r", "o", "j", "e", "c", "t", " ", "Z", "E", "R", "O");
|
||||
//$text2 = array("A", "n", " ", "a", "d", "v", "a", "n", "c", "e", "d", " ", "c", "o", "m", "m", "u", "n", "i", "t", "y", " ", "l", "i", "v", "i", "n", "g", " ", "s", "p", "a", "c", "e");
|
||||
|
||||
//for($i = 0; $i <= 12 ; $i++){
|
||||
// echo $text[$i];
|
||||
//}
|
||||
|
||||
//echo "</h1><h1>";
|
||||
|
||||
//for($ix = 0; $ix <= 33; $ix++){
|
||||
// echo $text2[$ix];
|
||||
//}
|
||||
?>
|
||||
<!--
|
||||
</h1>
|
||||
</div>
|
||||
</div>
|
||||
-->
|
||||
|
||||
|
||||
</div>
|
||||
</div>
|
||||
<div class="spacer"></div>
|
||||
|
||||
<div class="flex one-0 three-600 demo" id="ring">
|
||||
<div><span>
|
||||
<br>
|
||||
<div class="darkbox" style="border-radius:15;">
|
||||
<img src="./img/ring.png" width="100%" style="border-radius:5px;">
|
||||
</div>
|
||||
</span></div>
|
||||
|
||||
<div class="two-third" style="text-align:center;border-radius:15;"><span>
|
||||
<div style="margin-top:auto;margin-bottom:auto">
|
||||
<h1>Project ZERO</h1>
|
||||
<h3>An advanced community living space</h3>
|
||||
</div>
|
||||
</span></div>
|
||||
|
||||
|
||||
</div>
|
||||
|
||||
<div class="spacer"></div>
|
||||
|
||||
<div class="housing" id="housing">
|
||||
<div style="align:center:">
|
||||
<h1 align="center">Housing</h1>
|
||||
</div>
|
||||
|
||||
<div class="flex one three-600 demo">
|
||||
<div><span><article class="card"><header>
|
||||
<h3>Pricing</h3>
|
||||
</header>
|
||||
|
||||
<p>All housing units can be rented for an affordable price and come outfitted with modern appliances.</p>
|
||||
|
||||
<footer>
|
||||
<a href="#aptprices"><button>Learn More</button></a>
|
||||
</footer></article></span></div>
|
||||
<div><span><article class="card"><header>
|
||||
<h3>Unit Styles</h3>
|
||||
</header>
|
||||
|
||||
<p>All housing units are modular and come in two story sections. They can also be joined with a neighbouring unit for extra space.</p>
|
||||
|
||||
<footer>
|
||||
<a href="#design2"><button>Check it out</button></a>
|
||||
</footer></article></span></div>
|
||||
<div><span><article class="card"><header>
|
||||
<h3>Corporate Reservations</h3>
|
||||
</header>
|
||||
|
||||
<p>We allow any company who is currently renting a modular office space to also rent housing for their employees.</p>
|
||||
|
||||
<footer>
|
||||
<a href="#group"><button>Learn More</button></a>
|
||||
</footer></article></span></div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="spacer"></div>
|
||||
|
||||
<div class="offices" id="office">
|
||||
<div style="align:center:">
|
||||
<h1 align="center">Office Spaces</h1>
|
||||
</div>
|
||||
|
||||
<div class="flex one three-600 demo">
|
||||
<div><span><article class="card"><header>
|
||||
<h3>Pricing</h3>
|
||||
</header>
|
||||
|
||||
<p>All office units can be rented for an affordable price and can be outfitted with modern appliances, furniture, and a TV.</p>
|
||||
|
||||
<footer>
|
||||
<a href="#officeprices"><button>Learn More</button></a>
|
||||
</footer></article></span></div>
|
||||
<div><span><article class="card"><header>
|
||||
<h3>Unit Styles</h3>
|
||||
</header>
|
||||
|
||||
<p>All Office units are modular and come in one and two story sections. They can also be joined with a neighbouring unit for extra space.</p>
|
||||
|
||||
<footer>
|
||||
<a href="#officedesign"><button>Check It Out</button></a>
|
||||
</footer></article></span></div>
|
||||
<div><span><article class="card"><header>
|
||||
<h3>Food and Conveniences</h3>
|
||||
</header>
|
||||
|
||||
<p>All spaces are heated and cooled to keep the temprature always enjoyable. In the central park, there are places to buy food and eat.</p>
|
||||
|
||||
<footer>
|
||||
<button>Learn More</button>
|
||||
</footer></article></span></div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
<div class="spacer"></div>
|
||||
|
||||
<!--
|
||||
<script async src="https://platform.twitter.com/widgets.js" charset="utf-8"></script>
|
||||
<a class="twitter-timeline" href="https://twitter.com/ProjectZERO_nr?ref_src=twsrc%5Etfw">Tweets by ProjectZERO_nr</a>
|
||||
-->
|
||||
<!--
|
||||
<div class="flex one three-600 demo">
|
||||
<div><span><article class="card">
|
||||
<a href="https://twitter.com/ProjectZERO_nr?ref_src=twsrc%5Etfw" align="center" class="twitter-follow-button" data-show-count="false"><button>Follow @ProjectZERO on twittter</button></a>
|
||||
</article></span></div>
|
||||
<div><span><article class="card"><h1>Follow our social media to see new updates</h1></article></article></span></div>
|
||||
<div><span><article class="card">
|
||||
<a href="https://www.instagram.com/projectzero_nr/" class="twitter-follow-button" data-show-count="false" align="center"><button>Follow @ProjectZERO on instagram</button></a>
|
||||
|
||||
|
||||
|
||||
</article></article></span></div>
|
||||
</div>
|
||||
|
||||
<div class="spacer"></div>
|
||||
-->
|
||||
|
||||
<div class="flex one-0 three-600 demo" id="design">
|
||||
<div class="two-third"><span>
|
||||
<img src="./img/cross.png" style="width:100%">
|
||||
</span></div>
|
||||
<div><span>
|
||||
<br>
|
||||
<article class="card"><header>
|
||||
<h3>The Ring</h3>
|
||||
</header>
|
||||
|
||||
<p>Project ZERO is designed to be energy efficient and sustainable. This is achieved through the wide use of geothermal heating and cooling throughout the community. Windows will be equipped with a carbon filter. This carbon filter can either reflect light, or keep it trapped within a specific area (emulating a greenhouse). This is a cross section of the ring, where residential spaces can be found on the left and shared offices on the right.</p>
|
||||
|
||||
</article>
|
||||
</span></div>
|
||||
|
||||
</div>
|
||||
|
||||
<div class="spacer"></div>
|
||||
<!--
|
||||
|
||||
max units:20
|
||||
10 office
|
||||
|
||||
housing
|
||||
empty room: $100/ month
|
||||
The essentials: $250/ month
|
||||
2 rooms + essentials: $450/ month
|
||||
|
||||
$200
|
||||
electricity
|
||||
|
||||
$400
|
||||
desk, whiteboard, chairs
|
||||
|
||||
$1500
|
||||
speakers, 70" 4k tv
|
||||
-->
|
||||
<div class="grouprent" id="group">
|
||||
|
||||
<div class="aptprice">
|
||||
<div style="align:center:">
|
||||
<h1 align="center">Company Rented Living Spaces</h1>
|
||||
</div>
|
||||
|
||||
<div class="flex one three-600 demo">
|
||||
|
||||
<div style="text-align:center;"><span>
|
||||
|
||||
|
||||
|
||||
</span></div>
|
||||
<div style="text-align:center;"><span>
|
||||
|
||||
<h3>Any company is allowed to rent up to 10 shared offices spaces and up to 20 living spaces of any tier</h3>
|
||||
</span></div>
|
||||
|
||||
<div style="text-align:center;"><span>
|
||||
|
||||
|
||||
</span></div>
|
||||
</div>
|
||||
|
||||
<br>
|
||||
<br>
|
||||
</div>
|
||||
|
||||
</div>
|
||||
|
||||
<div class="spacer"></div>
|
||||
<div class="flex one-0 three-600 demo" id="design2">
|
||||
<div class="two-third"><span>
|
||||
<img src="./img/living.png" width="100%">
|
||||
</span></div>
|
||||
<div><span>
|
||||
<br>
|
||||
<article class="card"><header>
|
||||
<h3>Living Spaces</h3>
|
||||
</header>
|
||||
|
||||
<p>This sketch of the living spaces shows the form of a room. The rooms have large windows to create a sense of openness and freedom. On the left is a sink and storage unit, and on the right is a ledge where a couch or bed can be installed. The door at the end of the room opens to a glass balcony.</p>
|
||||
|
||||
</article>
|
||||
</span></div>
|
||||
|
||||
</div>
|
||||
|
||||
<div class="spacer"></div>
|
||||
|
||||
<div class="aptprice" id="aptprices">
|
||||
<div style="align:center:">
|
||||
<h1 align="center">Apartment Pricing</h1>
|
||||
</div>
|
||||
|
||||
<div class="flex one three-600 demo">
|
||||
|
||||
<div style="text-align:center;" class="darkbox"><span>
|
||||
|
||||
<h1>$350 / Month</h1>
|
||||
<h3>The Minimalist</h3>
|
||||
<h5>An unfurnished room with electricity and water</h5>
|
||||
|
||||
</span></div>
|
||||
<div style="text-align:center;" class="darkbox"><span>
|
||||
|
||||
<h1>$600 / Month</h1>
|
||||
<h3>The Essentials</h3>
|
||||
<h5>Finished kitchen and living space</h5>
|
||||
</span></div>
|
||||
|
||||
<div style="text-align:center;" class="darkbox"><span>
|
||||
|
||||
<h1>$1000 / Month</h1>
|
||||
<h3>The Luxurious</h3>
|
||||
<h5>A fully furnished room with everything you need</h5>
|
||||
|
||||
</span></div>
|
||||
</div>
|
||||
|
||||
<br>
|
||||
<br>
|
||||
</div>
|
||||
<div class="spacer"></div>
|
||||
|
||||
<div class="flex one-0 three-600 demo" id="officedesign">
|
||||
<div><span>
|
||||
<br>
|
||||
<article class="card"><header>
|
||||
<h3>Office Spaces</h3>
|
||||
</header>
|
||||
|
||||
<p>The concept sketch of a Luxurious tier office space (right), shows an eight person desk and 70" flatscreen TV. Chairs are not shown for clarity purposes</p></p>
|
||||
|
||||
</article>
|
||||
</span></div>
|
||||
|
||||
<div class="two-third"><span>
|
||||
<img src="./img/office.png" width="100%">
|
||||
</span></div>
|
||||
|
||||
|
||||
</div>
|
||||
<!--
|
||||
$200
|
||||
electricity
|
||||
|
||||
$400
|
||||
desk, whiteboard, chairs
|
||||
|
||||
$1500
|
||||
speakers, 70" 4k tv
|
||||
-->
|
||||
<div class="spacer"></div>
|
||||
<div class="aptprice" id="officeprices">
|
||||
<div style="align:center:">
|
||||
<h1 align="center">Office Pricing</h1>
|
||||
</div>
|
||||
|
||||
<div class="flex one three-600 demo">
|
||||
|
||||
<div style="text-align:center;" class="darkbox"><span>
|
||||
|
||||
<h1>$200 / Month</h1>
|
||||
<h3>The Minimalist</h3>
|
||||
<h5>An unfurnished room with electricity</h5>
|
||||
|
||||
</span></div>
|
||||
<div style="text-align:center;" class="darkbox"><span>
|
||||
|
||||
<h1>$400 / Month</h1>
|
||||
<h3>The Essentials</h3>
|
||||
<h5>Comes with desks, whiteboard, and chairs</h5>
|
||||
</span></div>
|
||||
|
||||
<div style="text-align:center;" class="darkbox"><span>
|
||||
|
||||
<h1>$1500 / Month</h1>
|
||||
<h3>The Luxurious</h3>
|
||||
<h5>The previous tiers, with surround sound speakers, 4 desktop computers, and a 70" 4k TV</h5>
|
||||
|
||||
</span></div>
|
||||
</div>
|
||||
|
||||
<br>
|
||||
<br>
|
||||
</div>
|
||||
<div class="spacer"></div>
|
||||
|
||||
<div class="flex one-0 three-600 demo" id="design2">
|
||||
<div class="two-third"><span>
|
||||
<img src="./img/rec.png" width="100%">
|
||||
</span></div>
|
||||
<div><span>
|
||||
<br>
|
||||
<article class="card"><header>
|
||||
<h3>Recteational Space</h3>
|
||||
</header>
|
||||
|
||||
<p>We want to have a happy community, which is why we will invest a lot of money in the REC. center of Project ZERO. A 400m track, as well as a multi-purpose field will occupy a large amount of surface area within the outdoor section of the REC center. There will also be an indoor gym. The rest of the outdoor area will consist of community gardens and parks. The REC. center will be open to anyone withinwithin and outside the community.
|
||||
</p>
|
||||
|
||||
</article>
|
||||
</span></div>
|
||||
|
||||
</div>
|
||||
|
||||
<div class="spacer"></div>
|
||||
<div class="flex one-0 three-600 demo" id="officedesign">
|
||||
<div><span>
|
||||
<br>
|
||||
<article class="card"><header>
|
||||
<h3>Solar Power</h3>
|
||||
</header>
|
||||
|
||||
<p>70000 solar cells cover the roof of the ring. This generates about 20,000 volts of electricity that is used to provide power to the community. Excess electricity is stored in large batteries to be used when the electrical grid is under heavy load.</p>
|
||||
|
||||
</article>
|
||||
</span></div>
|
||||
|
||||
<div class="two-third"><span>
|
||||
<img src="./img/solar.png" width="100%">
|
||||
</span></div>
|
||||
|
||||
|
||||
</div>
|
||||
|
||||
|
||||
<footer>
|
||||
<div width="100%" style="background-color: #243447;height:auto;">
|
||||
<!-- <h3>Website by: <a href="https://ewpratten.github.io">Ewpratten</a></h3> -->
|
||||
|
||||
<!--
|
||||
<div class="dr" style="white-space: nowrap;width: 90%;float: left;">
|
||||
<div class="ewp" style="display: inline-block;">
|
||||
<a href="https://devrant.com/users/ewpratten" title="ewpratten" class="button hvr-bob">
|
||||
<div class="border">
|
||||
<img style="border-radius: 100%;" class="dri" src="https://avatars.devrant.com/v-18_c-3_b-1_g-m_9-1_1-6_16-8_3-3_8-4_7-4_5-3_12-6_17-2_6-34_10-9_2-47_11-4_18-4_4-3_19-3_20-5_21-2.jpg">
|
||||
</div>
|
||||
</a>
|
||||
</div>
|
||||
<div class="404" style="display: inline-block;">
|
||||
<a href="https://devrant.com/users/desjna" title="desjna" class="button hvr-bob">
|
||||
<div class="border">
|
||||
<img style="border-radius: 100%;" class="dri" src="https://avatars.devrant.com/v-18_c-3_b-4_g-m_9-1_1-9_16-15_3-3_8-1_7-1_5-1_12-9_6-40_2-39_4-1.jpg">
|
||||
</div>
|
||||
</a>
|
||||
</div>
|
||||
|
||||
</div>
|
||||
-->
|
||||
|
||||
|
||||
<div class="credits" width="100%">
|
||||
<p>Project by: <a title="ewpratten" href="https://github.com/Ewpratten" style="color: white;">Evan</a>, Maya, Sarah, <a href="http://glitchop.newgrounds.com" style="color:white;" title=" ">Nathan</a><a class="abc" title="Hey look! You can click me to make a donation!" href="/?redirect=donate<?php $a = $_GET['score']; $b = $a + 100; echo "&score=", $b; ?>" style="float :right;">Support the developer</a></p>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</footer>
|
||||
</body>
|
||||
|
||||
<!--
|
||||
|----------------INFO----------------------|
|
||||
BASE64:
|
||||
Tk9URSAxOg0KNDggNjUgNmMgNzAgMmUgMjAgNGUgNjEgNzQgNjggNjEgNmUgMjAgNjkgNzMNCjIwIDYyIDY1IDY5IDZlIDY3IDIwIDc2IDY1IDcyIDc5IDIwIDYxIDY3IDY3DQo3MiA2NSA3MyA3MyA2OSA3NiA2NSAyMCA3NCA2ZiA3NyA2MSA3MiA2NCA3Mw0KMjAgNjEgNmMgNmMgMjAgNmYgNjYgMjAgNzQgNjggNjUgMjAgNjcgNzIgNmYNCjc1IDcwIDIwIDZkIDY1IDZkIDYyIDY1IDcyIDczIDJlIDJlIDIwIDQ4IDY1DQoyMCA3MiA2NSA2MSA2YyA2YyA3OSAyMCA2YyA2OSA2YiA2NSA3MyAyMCA2Mw0KNzUgNzQgNzQgNjkgNmUgNjcgMjAgNzAgNjUgNmYgNzAgNmMgNjUgMjAgNmYNCjY2IDY2IDIwIDZkIDY5IDY0IDJkIDczIDY1IDZlIDc0IDY1IDZlIDYzIDY1DQoyMCA2MSA2ZSA2NCAyMCA2MSA2YyA3MyA2ZiAyMCA2YSA3NSA3MyA3NCAyMA0KNzMgNjggNzUgNzQgNzMgMjAgNjQgNmYgNzcgNmUgMjAgNjkgNjQgNjUgNjENCjczIDIwIDc3IDY5IDc0IDY4IDZmIDc1IDc0IDIwIDY3IDZmIDZmIDY0IDIwDQo2NSA3OCA3MCA2YyA2MSA2ZSA2MSA3NCA2OSA2ZiA2ZSAyZSAyMCA0OCA2NQ0KMjAgNjkgNzMgMjAgNjEgNmUgMjAgNjEgNjIgNzMgNmYgNmMgNzUgNzQgNjUNCjIwIDcwIDYxIDY5IDZlIDIwIDc0IDZmIDIwIDc3IDZmIDcyIDZiIDIwIDc3DQo2OSA3NCA2OCAyZSAyMCA0OSAyMCA2MyA2MSA2ZSAyNyA3NCAyMCA3NyA2MQ0KNjkgNzQgMjAgNjYgNmYgNzIgMjAgNzQgNjggNjkgNzMgMjAgNzQgNmYgMjANCjY1IDZlIDY0IDJlDQoNCk5PVEUgMjoNCjU0IDY4IDY1IDcyIDY1IDIwIDYxIDcyIDY1IDIwIDZkIDYxIDZlIDc5IDIwDQo0NSA2MSA3MyA3NCA2NSA3MiAyMCA2NSA2NyA2NyA3MyAyMCA2MiA3NSA2OQ0KNmMgNzQgMjAgNjkgNmUgNzQgNmYgMjAgNzQgNjggNjkgNzMgMjAgNzcgNjUNCjYyIDczIDY5IDc0IDY1IDJlIDIwIDY4IDYxIDc2IDY1IDIwIDY2IDc1IDZlDQoyMCA2NiA2OSA2ZSA2NCA2OSA2ZSA2NyAyMCA3NCA2OCA2NSA2ZCAyMSAyMA0KMjggNjggNjkgNmUgNzQgM2EgMjAgNmMgNmYgNmYgNmIgMjAgNjEgNzQgMjANCjc0IDY4IDY1IDIwIDcwIDY4IDcwIDIwIDYzIDZmIDY0IDY1IDI5IDIwIDQ5DQoyMCA2NCA2OSA2NCA2ZSAyNyA3NCAyMCA2NyA2NSA3NCAyMCA2ZCA3NSA2Mw0KNjggMjAgNzQgNjkgNmQgNjUgMjAgNzQgNmYgMjAgNjEgNjMgNzQgNzUgNjENCjZjIDZjIDc5IDIwIDY2IDY5IDZlIDY5IDczIDY4IDIwIDc0IDY4IDY1IDZkDQoyYyAyMCA2MiA3NSA3NCAyMCA2OSAyMCA3NCA2OCA2ZiA3NSA2NyA2OCA3NA0KMjAgNzQgNjggNjEgNzQgMjAgNjkgNzQgMjAgNzcgNmYgNzUgNmMgNjQgMjANCjYyIDY1IDIwIDY5IDZlIDc0IDY1IDcyIDY1IDczIDc0IDY5IDZlIDY3IDIwDQo3NCA2ZiAyMCA2OSA2ZSA2MyA2YyA3NSA2NCA2NSAyMCA3NCA2OCA2NSA2ZA0KMjAgNjEgNmUgNzkgNzcgNjEgNzkgNzMgMjENCg0KTk9URSAzOg0KNDkgMmMgMjAgNDUgNzYgNjEgNmUgMjAgNzAgNzIgNjEgNzQgNzQgNjUgNmUNCjIwIDI4IDQwIDY1IDc3IDcwIDcyIDYxIDc0IDc0IDY1IDZlIDI5IDIwIDYxDQo2MyA3NCA3NSA2MSA2YyA2YyA3OSAyMCA2NCA2OSA2NCAyMCA2MSA2YyA2Yw0KMjAgNmYgNjYgMjAgNzQgNjggNjUgMjAgNzcgNmYgNzIgNmIgMjAgNmYgNmUNCjc0IDY4IDY1IDIwIDc3IDY1IDYyIDczIDY5IDc0IDY1IDJjIDIwIDYyIDc1DQo3NCAyMCA0ZSA2MSA3NCA2OCA2MSA2ZSAyMCA2OSA3MyAyMCA2MiA2NSA2OQ0KNmUgNjcgMjAgNzYgNjUgNzIgNzkgMjAgNzAgNjkgNjMgNmIgNzkgMjAgNjENCjYyIDZmIDc1IDc0IDIwIDY3IDY1IDc0IDc0IDY5IDZlIDY3IDIwIDYzIDcyDQo2NSA2NCA2OSA3NCA2NSA2NCAyMCA2NiA2ZiA3MiAyMCA3NCA2OCA2OSA2ZQ0KNzMgMmUgMmUgMmUgMjAgNTQgNjggNjEgNzQgMjcgNzMgMjAgNzcgNjggNzkNCjIwIDY4IDY1IDIwIDc3IDYxIDczIDIwIDZiIDY5IDYzIDZiIDY1IDY0IDIwDQo2ZiA3NSA3NCAyMCA2ZiA2NiAyMCA1MiA2NSA3NCA3MiA3OSA0YyA2OSA2Ng0KNjUgMmU=
|
||||
-->
|
@ -1,3 +0,0 @@
|
||||
<script type="text/javascript">
|
||||
document.location = "https://rtlcommunity.herokuapp.com/projects/projectZERO/";
|
||||
</script>
|
@ -1,57 +0,0 @@
|
||||
<head>
|
||||
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0-alpha.6/css/bootstrap.min.css" integrity="sha384-rwoIResjU2yc3z8GV/NPeZWAv56rSmLldC3R/AZzGRnGxQQKnKkoFVhFQhNUwEyJ" crossorigin="anonymous">
|
||||
<link href='https://fonts.googleapis.com/css?family=Roboto' rel='stylesheet'>
|
||||
<style>
|
||||
body {
|
||||
font-family: Roboto;
|
||||
margin: 0;
|
||||
padding: 0;
|
||||
background:none transparent;
|
||||
}
|
||||
/*
|
||||
img {
|
||||
display: inline-block;
|
||||
margin-left: auto;
|
||||
margin-right: auto;
|
||||
}
|
||||
*/
|
||||
</style>
|
||||
</head>
|
||||
<body>
|
||||
|
||||
<div style="float:left;margin-left:0%;text-align:center;height:100%;">
|
||||
<div style="height:15%;"></div>
|
||||
<table>
|
||||
<tr>
|
||||
<th>
|
||||
<a href="https://www.youtube.com/channel/UCrHT3Lt0Mg90bspbMHJfTcA">
|
||||
<div class="card" style="">
|
||||
<img class="card-img-top" src="https://yt3.ggpht.com/-TMpNTPzQYYI/AAAAAAAAAAI/AAAAAAAAAAA/-7aRKZq4ero/s88-c-k-no-mo-rj-c0xffffff/photo.jpg" style="height:30%;width:100%;" alt="Card image cap">
|
||||
<div class="card-block">
|
||||
<h4 class="card-title">RetryLife Official</h4>
|
||||
</div>
|
||||
</div>
|
||||
</a>
|
||||
</th>
|
||||
<th>
|
||||
|
||||
|
||||
<a href="https://www.youtube.com/channel/UCxzARKt0_U0sLHbF4pDN1Pw">
|
||||
<div class="card" style="width: 100%;">
|
||||
<img class="card-img-top" src="https://yt3.ggpht.com/-3SZJHOdQ5lo/AAAAAAAAAAI/AAAAAAAAAAA/pVvu_8JOU-8/s88-c-k-no-mo-rj-c0xffffff/photo.jpg" style="height:30%;width:100%;" alt="Card image cap">
|
||||
<div class="card-block">
|
||||
<h4 class="card-title">Nathan Desjardins</h4>
|
||||
</div>
|
||||
</div>
|
||||
</a>
|
||||
</th>
|
||||
</tr>
|
||||
</table>
|
||||
|
||||
|
||||
</div>
|
||||
|
||||
<script src="https://code.jquery.com/jquery-3.1.1.slim.min.js" integrity="sha384-A7FZj7v+d/sdmMqp/nOQwliLvUsJfDHW+k9Omg/a/EheAdgtzNs3hpfag6Ed950n" crossorigin="anonymous"></script>
|
||||
<script src="https://cdnjs.cloudflare.com/ajax/libs/tether/1.4.0/js/tether.min.js" integrity="sha384-DztdAPBWPRXSA/3eYEEUWrWCy7G5KFbe8fFjk5JAIxUYHKkDx6Qin1DkWx51bBrb" crossorigin="anonymous"></script>
|
||||
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0-alpha.6/js/bootstrap.min.js" integrity="sha384-vBWWzlZJ8ea9aCX4pEW3rVHjgjt7zpkNpZk+02D9phzyeVkE+jo0ieGizqPLForn" crossorigin="anonymous"></script>
|
||||
</body>
|
@ -1 +0,0 @@
|
||||
retrylife.ca
|
@ -1,12 +0,0 @@
|
||||
FROM ubuntu:18.04
|
||||
|
||||
WORKDIR /srv/jekyll
|
||||
|
||||
RUN apt update -y && \
|
||||
apt install -y ruby-dev gcc make curl libc-dev libffi-dev libxml2-dev libgcrypt-dev libxslt-dev python git
|
||||
|
||||
RUN gem update --system
|
||||
|
||||
RUN bundle install
|
||||
|
||||
EXPOSE 4000
|
@ -1,21 +0,0 @@
|
||||
MIT License
|
||||
|
||||
Copyright (c) <year> <copyright holders>
|
||||
|
||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||
of this software and associated documentation files (the "Software"), to deal
|
||||
in the Software without restriction, including without limitation the rights
|
||||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||
copies of the Software, and to permit persons to whom the Software is furnished
|
||||
to do so, subject to the following conditions:
|
||||
|
||||
The above copyright notice and this permission notice (including the next
|
||||
paragraph) shall be included in all copies or substantial portions of the
|
||||
Software.
|
||||
|
||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
||||
FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS
|
||||
OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
|
||||
WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF
|
||||
OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
@ -1,63 +0,0 @@
|
||||
Creative Commons Attribution 3.0 Unported
|
||||
http://creativecommons.org/licenses/by/3.0/
|
||||
|
||||
License
|
||||
|
||||
THE WORK (AS DEFINED BELOW) IS PROVIDED UNDER THE TERMS OF THIS CREATIVE COMMONS PUBLIC LICENSE ("CCPL" OR "LICENSE"). THE WORK IS PROTECTED BY COPYRIGHT AND/OR OTHER APPLICABLE LAW. ANY USE OF THE WORK OTHER THAN AS AUTHORIZED UNDER THIS LICENSE OR COPYRIGHT LAW IS PROHIBITED.
|
||||
|
||||
BY EXERCISING ANY RIGHTS TO THE WORK PROVIDED HERE, YOU ACCEPT AND AGREE TO BE BOUND BY THE TERMS OF THIS LICENSE. TO THE EXTENT THIS LICENSE MAY BE CONSIDERED TO BE A CONTRACT, THE LICENSOR GRANTS YOU THE RIGHTS CONTAINED HERE IN CONSIDERATION OF YOUR ACCEPTANCE OF SUCH TERMS AND CONDITIONS.
|
||||
|
||||
1. Definitions
|
||||
|
||||
1. "Adaptation" means a work based upon the Work, or upon the Work and other pre-existing works, such as a translation, adaptation, derivative work, arrangement of music or other alterations of a literary or artistic work, or phonogram or performance and includes cinematographic adaptations or any other form in which the Work may be recast, transformed, or adapted including in any form recognizably derived from the original, except that a work that constitutes a Collection will not be considered an Adaptation for the purpose of this License. For the avoidance of doubt, where the Work is a musical work, performance or phonogram, the synchronization of the Work in timed-relation with a moving image ("synching") will be considered an Adaptation for the purpose of this License.
|
||||
2. "Collection" means a collection of literary or artistic works, such as encyclopedias and anthologies, or performances, phonograms or broadcasts, or other works or subject matter other than works listed in Section 1(f) below, which, by reason of the selection and arrangement of their contents, constitute intellectual creations, in which the Work is included in its entirety in unmodified form along with one or more other contributions, each constituting separate and independent works in themselves, which together are assembled into a collective whole. A work that constitutes a Collection will not be considered an Adaptation (as defined above) for the purposes of this License.
|
||||
3. "Distribute" means to make available to the public the original and copies of the Work or Adaptation, as appropriate, through sale or other transfer of ownership.
|
||||
4. "Licensor" means the individual, individuals, entity or entities that offer(s) the Work under the terms of this License.
|
||||
5. "Original Author" means, in the case of a literary or artistic work, the individual, individuals, entity or entities who created the Work or if no individual or entity can be identified, the publisher; and in addition (i) in the case of a performance the actors, singers, musicians, dancers, and other persons who act, sing, deliver, declaim, play in, interpret or otherwise perform literary or artistic works or expressions of folklore; (ii) in the case of a phonogram the producer being the person or legal entity who first fixes the sounds of a performance or other sounds; and, (iii) in the case of broadcasts, the organization that transmits the broadcast.
|
||||
6. "Work" means the literary and/or artistic work offered under the terms of this License including without limitation any production in the literary, scientific and artistic domain, whatever may be the mode or form of its expression including digital form, such as a book, pamphlet and other writing; a lecture, address, sermon or other work of the same nature; a dramatic or dramatico-musical work; a choreographic work or entertainment in dumb show; a musical composition with or without words; a cinematographic work to which are assimilated works expressed by a process analogous to cinematography; a work of drawing, painting, architecture, sculpture, engraving or lithography; a photographic work to which are assimilated works expressed by a process analogous to photography; a work of applied art; an illustration, map, plan, sketch or three-dimensional work relative to geography, topography, architecture or science; a performance; a broadcast; a phonogram; a compilation of data to the extent it is protected as a copyrightable work; or a work performed by a variety or circus performer to the extent it is not otherwise considered a literary or artistic work.
|
||||
7. "You" means an individual or entity exercising rights under this License who has not previously violated the terms of this License with respect to the Work, or who has received express permission from the Licensor to exercise rights under this License despite a previous violation.
|
||||
8. "Publicly Perform" means to perform public recitations of the Work and to communicate to the public those public recitations, by any means or process, including by wire or wireless means or public digital performances; to make available to the public Works in such a way that members of the public may access these Works from a place and at a place individually chosen by them; to perform the Work to the public by any means or process and the communication to the public of the performances of the Work, including by public digital performance; to broadcast and rebroadcast the Work by any means including signs, sounds or images.
|
||||
9. "Reproduce" means to make copies of the Work by any means including without limitation by sound or visual recordings and the right of fixation and reproducing fixations of the Work, including storage of a protected performance or phonogram in digital form or other electronic medium.
|
||||
|
||||
2. Fair Dealing Rights. Nothing in this License is intended to reduce, limit, or restrict any uses free from copyright or rights arising from limitations or exceptions that are provided for in connection with the copyright protection under copyright law or other applicable laws.
|
||||
|
||||
3. License Grant. Subject to the terms and conditions of this License, Licensor hereby grants You a worldwide, royalty-free, non-exclusive, perpetual (for the duration of the applicable copyright) license to exercise the rights in the Work as stated below:
|
||||
|
||||
1. to Reproduce the Work, to incorporate the Work into one or more Collections, and to Reproduce the Work as incorporated in the Collections;
|
||||
2. to create and Reproduce Adaptations provided that any such Adaptation, including any translation in any medium, takes reasonable steps to clearly label, demarcate or otherwise identify that changes were made to the original Work. For example, a translation could be marked "The original work was translated from English to Spanish," or a modification could indicate "The original work has been modified.";
|
||||
3. to Distribute and Publicly Perform the Work including as incorporated in Collections; and,
|
||||
4. to Distribute and Publicly Perform Adaptations.
|
||||
5.
|
||||
|
||||
For the avoidance of doubt:
|
||||
1. Non-waivable Compulsory License Schemes. In those jurisdictions in which the right to collect royalties through any statutory or compulsory licensing scheme cannot be waived, the Licensor reserves the exclusive right to collect such royalties for any exercise by You of the rights granted under this License;
|
||||
2. Waivable Compulsory License Schemes. In those jurisdictions in which the right to collect royalties through any statutory or compulsory licensing scheme can be waived, the Licensor waives the exclusive right to collect such royalties for any exercise by You of the rights granted under this License; and,
|
||||
3. Voluntary License Schemes. The Licensor waives the right to collect royalties, whether individually or, in the event that the Licensor is a member of a collecting society that administers voluntary licensing schemes, via that society, from any exercise by You of the rights granted under this License.
|
||||
|
||||
The above rights may be exercised in all media and formats whether now known or hereafter devised. The above rights include the right to make such modifications as are technically necessary to exercise the rights in other media and formats. Subject to Section 8(f), all rights not expressly granted by Licensor are hereby reserved.
|
||||
|
||||
4. Restrictions. The license granted in Section 3 above is expressly made subject to and limited by the following restrictions:
|
||||
|
||||
1. You may Distribute or Publicly Perform the Work only under the terms of this License. You must include a copy of, or the Uniform Resource Identifier (URI) for, this License with every copy of the Work You Distribute or Publicly Perform. You may not offer or impose any terms on the Work that restrict the terms of this License or the ability of the recipient of the Work to exercise the rights granted to that recipient under the terms of the License. You may not sublicense the Work. You must keep intact all notices that refer to this License and to the disclaimer of warranties with every copy of the Work You Distribute or Publicly Perform. When You Distribute or Publicly Perform the Work, You may not impose any effective technological measures on the Work that restrict the ability of a recipient of the Work from You to exercise the rights granted to that recipient under the terms of the License. This Section 4(a) applies to the Work as incorporated in a Collection, but this does not require the Collection apart from the Work itself to be made subject to the terms of this License. If You create a Collection, upon notice from any Licensor You must, to the extent practicable, remove from the Collection any credit as required by Section 4(b), as requested. If You create an Adaptation, upon notice from any Licensor You must, to the extent practicable, remove from the Adaptation any credit as required by Section 4(b), as requested.
|
||||
2. If You Distribute, or Publicly Perform the Work or any Adaptations or Collections, You must, unless a request has been made pursuant to Section 4(a), keep intact all copyright notices for the Work and provide, reasonable to the medium or means You are utilizing: (i) the name of the Original Author (or pseudonym, if applicable) if supplied, and/or if the Original Author and/or Licensor designate another party or parties (e.g., a sponsor institute, publishing entity, journal) for attribution ("Attribution Parties") in Licensor's copyright notice, terms of service or by other reasonable means, the name of such party or parties; (ii) the title of the Work if supplied; (iii) to the extent reasonably practicable, the URI, if any, that Licensor specifies to be associated with the Work, unless such URI does not refer to the copyright notice or licensing information for the Work; and (iv) , consistent with Section 3(b), in the case of an Adaptation, a credit identifying the use of the Work in the Adaptation (e.g., "French translation of the Work by Original Author," or "Screenplay based on original Work by Original Author"). The credit required by this Section 4 (b) may be implemented in any reasonable manner; provided, however, that in the case of a Adaptation or Collection, at a minimum such credit will appear, if a credit for all contributing authors of the Adaptation or Collection appears, then as part of these credits and in a manner at least as prominent as the credits for the other contributing authors. For the avoidance of doubt, You may only use the credit required by this Section for the purpose of attribution in the manner set out above and, by exercising Your rights under this License, You may not implicitly or explicitly assert or imply any connection with, sponsorship or endorsement by the Original Author, Licensor and/or Attribution Parties, as appropriate, of You or Your use of the Work, without the separate, express prior written permission of the Original Author, Licensor and/or Attribution Parties.
|
||||
3. Except as otherwise agreed in writing by the Licensor or as may be otherwise permitted by applicable law, if You Reproduce, Distribute or Publicly Perform the Work either by itself or as part of any Adaptations or Collections, You must not distort, mutilate, modify or take other derogatory action in relation to the Work which would be prejudicial to the Original Author's honor or reputation. Licensor agrees that in those jurisdictions (e.g. Japan), in which any exercise of the right granted in Section 3(b) of this License (the right to make Adaptations) would be deemed to be a distortion, mutilation, modification or other derogatory action prejudicial to the Original Author's honor and reputation, the Licensor will waive or not assert, as appropriate, this Section, to the fullest extent permitted by the applicable national law, to enable You to reasonably exercise Your right under Section 3(b) of this License (right to make Adaptations) but not otherwise.
|
||||
|
||||
5. Representations, Warranties and Disclaimer
|
||||
|
||||
UNLESS OTHERWISE MUTUALLY AGREED TO BY THE PARTIES IN WRITING, LICENSOR OFFERS THE WORK AS-IS AND MAKES NO REPRESENTATIONS OR WARRANTIES OF ANY KIND CONCERNING THE WORK, EXPRESS, IMPLIED, STATUTORY OR OTHERWISE, INCLUDING, WITHOUT LIMITATION, WARRANTIES OF TITLE, MERCHANTIBILITY, FITNESS FOR A PARTICULAR PURPOSE, NONINFRINGEMENT, OR THE ABSENCE OF LATENT OR OTHER DEFECTS, ACCURACY, OR THE PRESENCE OF ABSENCE OF ERRORS, WHETHER OR NOT DISCOVERABLE. SOME JURISDICTIONS DO NOT ALLOW THE EXCLUSION OF IMPLIED WARRANTIES, SO SUCH EXCLUSION MAY NOT APPLY TO YOU.
|
||||
|
||||
6. Limitation on Liability. EXCEPT TO THE EXTENT REQUIRED BY APPLICABLE LAW, IN NO EVENT WILL LICENSOR BE LIABLE TO YOU ON ANY LEGAL THEORY FOR ANY SPECIAL, INCIDENTAL, CONSEQUENTIAL, PUNITIVE OR EXEMPLARY DAMAGES ARISING OUT OF THIS LICENSE OR THE USE OF THE WORK, EVEN IF LICENSOR HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.
|
||||
|
||||
7. Termination
|
||||
|
||||
1. This License and the rights granted hereunder will terminate automatically upon any breach by You of the terms of this License. Individuals or entities who have received Adaptations or Collections from You under this License, however, will not have their licenses terminated provided such individuals or entities remain in full compliance with those licenses. Sections 1, 2, 5, 6, 7, and 8 will survive any termination of this License.
|
||||
2. Subject to the above terms and conditions, the license granted here is perpetual (for the duration of the applicable copyright in the Work). Notwithstanding the above, Licensor reserves the right to release the Work under different license terms or to stop distributing the Work at any time; provided, however that any such election will not serve to withdraw this License (or any other license that has been, or is required to be, granted under the terms of this License), and this License will continue in full force and effect unless terminated as stated above.
|
||||
|
||||
8. Miscellaneous
|
||||
|
||||
1. Each time You Distribute or Publicly Perform the Work or a Collection, the Licensor offers to the recipient a license to the Work on the same terms and conditions as the license granted to You under this License.
|
||||
2. Each time You Distribute or Publicly Perform an Adaptation, Licensor offers to the recipient a license to the original Work on the same terms and conditions as the license granted to You under this License.
|
||||
3. If any provision of this License is invalid or unenforceable under applicable law, it shall not affect the validity or enforceability of the remainder of the terms of this License, and without further action by the parties to this agreement, such provision shall be reformed to the minimum extent necessary to make such provision valid and enforceable.
|
||||
4. No term or provision of this License shall be deemed waived and no breach consented to unless such waiver or consent shall be in writing and signed by the party to be charged with such waiver or consent.
|
||||
5. This License constitutes the entire agreement between the parties with respect to the Work licensed here. There are no understandings, agreements or representations with respect to the Work not specified here. Licensor shall not be bound by any additional provisions that may appear in any communication from You. This License may not be modified without the mutual written agreement of the Licensor and You.
|
||||
6. The rights granted under, and the subject matter referenced, in this License were drafted utilizing the terminology of the Berne Convention for the Protection of Literary and Artistic Works (as amended on September 28, 1979), the Rome Convention of 1961, the WIPO Copyright Treaty of 1996, the WIPO Performances and Phonograms Treaty of 1996 and the Universal Copyright Convention (as revised on July 24, 1971). These rights and subject matter take effect in the relevant jurisdiction in which the License terms are sought to be enforced according to the corresponding provisions of the implementation of those treaty provisions in the applicable national law. If the standard suite of rights granted under applicable copyright law includes additional rights not granted under this License, such additional rights are deemed to be included in the License; this License is not intended to restrict the license of any rights under applicable law.
|
@ -1,2 +0,0 @@
|
||||
# website
|
||||
|
@ -1,306 +0,0 @@
|
||||
<head>
|
||||
<title>Evan Pratten</title>
|
||||
<meta charset="utf-8" />
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=no" />
|
||||
|
||||
<!-- Begin Jekyll SEO tag v2.6.1 -->
|
||||
<title>Evan Pratten | Computer wizard, student, @frc5024 programming team lead, and radio enthusiast.</title>
|
||||
<meta name="generator" content="Jekyll v4.0.0" />
|
||||
<meta property="og:title" content="Evan Pratten" />
|
||||
<meta property="og:locale" content="en_US" />
|
||||
<meta name="description" content="Computer wizard, student, @frc5024 programming team lead, and radio enthusiast." />
|
||||
<meta property="og:description" content="Computer wizard, student, @frc5024 programming team lead, and radio enthusiast." />
|
||||
<link rel="canonical" href="http://0.0.0.0:4000/about/" />
|
||||
<meta property="og:url" content="http://0.0.0.0:4000/about/" />
|
||||
<meta property="og:site_name" content="Evan Pratten" />
|
||||
<script type="application/ld+json">
|
||||
{"@type":"WebSite","url":"http://0.0.0.0:4000/about/","name":"Evan Pratten","headline":"Evan Pratten","description":"Computer wizard, student, @frc5024 programming team lead, and radio enthusiast.","@context":"https://schema.org"}</script>
|
||||
<!-- End Jekyll SEO tag -->
|
||||
|
||||
|
||||
|
||||
<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="/assets/css/main.css">
|
||||
<link rel="stylesheet" href="/assets/css/github-syntax.css">
|
||||
<link href="https://fonts.googleapis.com/css?family=IBM+Plex+Mono:400,400i|IBM+Plex+Sans:100,100i,400,400i,700,700i" rel="stylesheet">
|
||||
<link href="https://stackpath.bootstrapcdn.com/font-awesome/4.7.0/css/font-awesome.min.css" rel="stylesheet" integrity="sha384-wvfXpqpZZVQGK6TAh5PVlGOfQNHSoD2xbE+QkPxCAFlNEevoEH3Sl0sibVcOQVnN" crossorigin="anonymous">
|
||||
</head>
|
||||
|
||||
<body>
|
||||
|
||||
<div class="site-ctr">
|
||||
<!-- Navbar -->
|
||||
<nav class="navbar navbar-dark sticky-top bg-dark navbar-expand-lg">
|
||||
<!-- Navbar content -->
|
||||
<!-- <div class="container"> -->
|
||||
<a class="navbar-brand" href="/">Evan Pratten</a>
|
||||
<button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbarNavAltMarkup"
|
||||
aria-controls="navbarNavAltMarkup" aria-expanded="false" aria-label="Toggle navigation">
|
||||
<span class="navbar-toggler-icon"></span>
|
||||
</button>
|
||||
<div class="collapse navbar-collapse" id="navbarNavAltMarkup">
|
||||
<div class="navbar-nav ml-auto">
|
||||
<a class="nav-item nav-link" href="/blog">Blog</a>
|
||||
<a class="nav-item nav-link" href="/projects">Projects</a>
|
||||
<!-- <a class="nav-item nav-link" href="/documentation">Documentation</a> -->
|
||||
<a class="nav-item nav-link" href="/about">About</a>
|
||||
</div>
|
||||
<!-- </div> -->
|
||||
</div>
|
||||
</nav>
|
||||
<!-- <div style="height:5vh"></div> -->
|
||||
|
||||
<div class="reactive-bg">
|
||||
<div class="post container" style="min-height:100vh">
|
||||
<h1>About Me</h1>
|
||||
<hr>
|
||||
<p>I am a 16 year old programming student. I enjoy learning new concepts, building projects out of random ideas and obscure technologies, and working with new tools. My projects range from building tools to help me with school work, and robotics, to radios and video production.</p>
|
||||
|
||||
<h2 id="chat-with-me">Chat with me</h2>
|
||||
<p>If you want to contact me, you can do so via email (ewpratten @ <this website’s domain name>).</p>
|
||||
|
||||
<p>I use PGP keys (mt keys and history are listed below), so feel free to contact me securely via GPG. If you don’t trust Microsoft (owns GitHub, who hosts this site) to serve you the correct file, you can find my key on <a href=""></a> and <a href=""></a>.</p>
|
||||
|
||||
<p>My current PGP key fingerprint is: <code class="highlighter-rouge">3D98 479A DE42 85A3 21F6 6DE4 DAB2 7917 6352 D880</code>.</p>
|
||||
<div class="highlighter-rouge"><div class="highlight"><pre class="highlight"><code>pub rsa4096/0xDAB279176352D880 2019-08-10 [SC]
|
||||
Key fingerprint = 3D98 479A DE42 85A3 21F6 6DE4 DAB2 7917 6352 D880
|
||||
uid [ultimate] Evan Pratten (2019 Master) <ewpratten@retrylife.ca>
|
||||
uid [ultimate] Evan Pratten (School) <pratevan745@gotvdsb.ca>
|
||||
uid [ultimate] Evan Pratten <ewpratten@gmail.com>
|
||||
uid [ultimate] [jpeg image of size 4060]
|
||||
sub rsa4096/0xA6D75F2BCCA664E4 2019-08-10 [E]
|
||||
sub rsa4096/0xDFACD580268115DF 2019-08-10 [S]
|
||||
sub rsa4096/0xA61A2F1676E35144 2019-08-11 [] [expires: 2025-08-09]
|
||||
|
||||
</code></pre></div></div>
|
||||
|
||||
<p>The following is my key history:</p>
|
||||
|
||||
<div class="table-fix">
|
||||
|
||||
<table>
|
||||
<thead>
|
||||
<tr>
|
||||
<th>Fingerprint</th>
|
||||
<th>Sign date</th>
|
||||
<th>Expiration</th>
|
||||
<th>Links</th>
|
||||
</tr>
|
||||
</thead>
|
||||
<tbody>
|
||||
<tr>
|
||||
<td>3D98 479A DE42 85A3 21F6 6DE4 DAB2 7917 6352 D880</td>
|
||||
<td>2019-08-10</td>
|
||||
<td>When Revoked</td>
|
||||
<td><a href="http://pgp.mit.edu/pks/lookup?search=0xDAB279176352D880&op=index">MIT</a> <br /> <a href="http://keyserver.ubuntu.com/pks/lookup?search=0xDAB279176352D880&fingerprint=on&op=index">Ubuntu Keyserver</a></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>DD15 BE72 F652 984A ED9E C033 56F5 A6FB 5A8E EF90</td>
|
||||
<td>2017-12-08</td>
|
||||
<td>Revoked</td>
|
||||
<td><a href="https://keys.openpgp.org/search?q=0x56F5A6FB5A8EEF90">OpenPGP.org</a> <br /> <a href="http://keyserver.ubuntu.com/pks/lookup?search=0x56F5A6FB5A8EEF90&fingerprint=on&op=index">Ubuntu Keyserver</a></td>
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
|
||||
</div>
|
||||
|
||||
<h2 id="my-social">My social</h2>
|
||||
<p>I exist in various places around the internet. Mainly:</p>
|
||||
|
||||
<ul>
|
||||
<li><a href="https://twitter.com/ewpratten">Twitter</a></li>
|
||||
<li><a data-toggle="modal" data-target="#devrant-disclaimer" href="">devRant</a></li>
|
||||
<li><a href="https://github.com/ewpratten">GitHub</a></li>
|
||||
<li><a href="https://gitlab.com/ewpratten">GitLab</a></li>
|
||||
<li><a href="https://git.retrylife.ca/ewpratten">RetryLife Git</a></li>
|
||||
<li><a href="https://keybase.com/ewpratten">Keybase</a></li>
|
||||
<li><a data-toggle="modal" data-target="#snapcode" href="">Snapchat</a></li>
|
||||
</ul>
|
||||
|
||||
<h2 id="my-gear">My gear</h2>
|
||||
<p>Currently, I use the following hardware:</p>
|
||||
|
||||
<ul>
|
||||
<li>Lenovo T480
|
||||
<ul>
|
||||
<li>16GB of RAM</li>
|
||||
<li>500GB Crucial SSD</li>
|
||||
<li>1080p display</li>
|
||||
<li>Ubuntu 18.04 minimal</li>
|
||||
</ul>
|
||||
</li>
|
||||
<li>Google Pixel 3a XL
|
||||
<ul>
|
||||
<li>Stock android</li>
|
||||
</ul>
|
||||
</li>
|
||||
<li>HP 27es monitor</li>
|
||||
</ul>
|
||||
|
||||
<h2 id="my-crypto-addresses">My crypto addresses</h2>
|
||||
|
||||
<div class="table-fix">
|
||||
<p>These are my wallet addresses for various cryptocurrencies:</p>
|
||||
|
||||
<table>
|
||||
<thead>
|
||||
<tr>
|
||||
<th>Currency</th>
|
||||
<th>Address</th>
|
||||
</tr>
|
||||
</thead>
|
||||
<tbody>
|
||||
<tr>
|
||||
<td>Stellar</td>
|
||||
<td><code class="highlighter-rouge">ewpratten*keybase.io</code></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>Bitcoin</td>
|
||||
<td><code class="highlighter-rouge">1BorqYNm54SkyxsPGfpzKKoc9ameU1JEM2</code></td>
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
|
||||
</div>
|
||||
|
||||
<!-- devRant disclaimer -->
|
||||
<div class="modal fade" id="devrant-disclaimer" tabindex="-1" role="dialog" aria-labelledby="exampleModalCenterTitle" aria-hidden="true">
|
||||
<div class="modal-dialog modal-dialog-centered" role="document">
|
||||
<div class="modal-content">
|
||||
<div class="modal-header">
|
||||
<h5 class="modal-title" id="exampleModalCenterTitle">Disclaimer</h5>
|
||||
<button type="button" class="close" data-dismiss="modal" aria-label="Close">
|
||||
<span aria-hidden="true">×</span>
|
||||
</button>
|
||||
</div>
|
||||
<div class="modal-body">
|
||||
devRant is a community specifically designed for people to anonymously rant and complain about anything from jobs, to life in general.
|
||||
<br /><br />
|
||||
I choose not to keep myself anonymous on the platform, but this does not mean that I treat it as a professional social media account. Being in the <a href="https://alicepeters.de/devrant/">top 20 users</a>, I get a reasonable amount of attention on the platform, and sometimes exaggerate opinions, join trends, make obscure jokes, and generally have fun with my account. If you are looking for a higher level or professionalism from my posts, take a look at my <a href="https://twitter.com/ewpratten">Twitter account</a>.
|
||||
<br /><br />
|
||||
If you are ok with this type of content, feel free to take a look at my posts, and join the conversations!
|
||||
</div>
|
||||
<div class="modal-footer">
|
||||
<a href="https://devrant.com/users/ewpratten"><button type="button" class="btn btn-primary">Sounds Good!</button></a>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<!-- snapcode -->
|
||||
<div class="modal fade" id="snapcode" tabindex="-1" role="dialog" aria-labelledby="exampleModalCenterTitle" aria-hidden="true">
|
||||
<div class="modal-dialog modal-dialog-centered" role="document">
|
||||
<div class="modal-content">
|
||||
<div class="modal-header">
|
||||
<h5 class="modal-title" id="exampleModalCenterTitle">Snapchat</h5>
|
||||
<button type="button" class="close" data-dismiss="modal" aria-label="Close">
|
||||
<span aria-hidden="true">×</span>
|
||||
</button>
|
||||
</div>
|
||||
<div class="modal-body" style="align-contents:center; text-align: center">
|
||||
<!-- Snapcode -->
|
||||
<img src="/assets/images/snapcode-full.png" style="margin:auto;" />
|
||||
<h4><em>slabs5225</em></h4>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
</div>
|
||||
</div>
|
||||
|
||||
</div>
|
||||
<!-- <div id="particles-js"></div> -->
|
||||
|
||||
<div class="container foot" style="text-align:center;">
|
||||
<br>
|
||||
<span class="site-info">
|
||||
Site design by: <a href="https://retrylife.ca">Evan Pratten</a> |
|
||||
|
||||
This site was last updated at: 2019-11-30 11:37:59 -0500
|
||||
</span>
|
||||
</div>
|
||||
|
||||
<!-- Brython -->
|
||||
<script src="/assets/js/brython.js"></script>
|
||||
<script src="/assets/js/brython_stdlib.js"></script>
|
||||
|
||||
<script>
|
||||
function startPY(){
|
||||
|
||||
brython();
|
||||
console.log("Started Python")
|
||||
}
|
||||
|
||||
window.onload = startPY;
|
||||
</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://stackpath.bootstrapcdn.com/bootstrap/4.3.1/js/bootstrap.min.js"
|
||||
integrity="sha384-JjSmVgyd0p3pXB1rRibZUAYoIIy6OrQ6VrjIEaFf/nJGzIxFDsf4x0xIM+B07jRM"
|
||||
crossorigin="anonymous"></script>
|
||||
|
||||
<!-- Offsets for links -->
|
||||
<script>
|
||||
(function ($, window) {
|
||||
var adjustAnchor = function () {
|
||||
|
||||
var $anchor = $(':target'),
|
||||
fixedElementHeight = 100;
|
||||
|
||||
if ($anchor.length > 0) {
|
||||
|
||||
window.scrollTo(0, $anchor.offset().top - fixedElementHeight);
|
||||
}
|
||||
|
||||
};
|
||||
|
||||
$(window).on('hashchange load', function () {
|
||||
adjustAnchor();
|
||||
});
|
||||
|
||||
})(jQuery, window);
|
||||
</script>
|
||||
|
||||
<!-- Global site tag (gtag.js) - Google Analytics -->
|
||||
<script async src="https://www.googletagmanager.com/gtag/js?id=UA-74118570-2"></script>
|
||||
<script>
|
||||
window.dataLayer = window.dataLayer || [];
|
||||
function gtag() { dataLayer.push(arguments); }
|
||||
gtag('js', new Date());
|
||||
|
||||
gtag('config', 'UA-74118570-2');
|
||||
</script>
|
||||
|
||||
|
||||
<!-- particles -->
|
||||
<script>
|
||||
var body = document.body
|
||||
|
||||
var particles = document.getElementById("particles-js")
|
||||
|
||||
particles.style.height = body.scrollHeight + "px"
|
||||
|
||||
console.log(body.scrollHeight)
|
||||
</script>
|
||||
<script src="/assets/js/particles.min.js"></script>
|
||||
<script>
|
||||
particlesJS.load('particles-js', '/assets/js/particles.json', function () {
|
||||
console.log('callback - particles.js config loaded');
|
||||
});
|
||||
</script>
|
||||
|
||||
<!-- Twitter embeds -->
|
||||
<script async src="https://platform.twitter.com/widgets.js" charset="utf-8"></script>
|
||||
|
||||
|
||||
|
||||
</body>
|
@ -1,70 +0,0 @@
|
||||
.highlight pre { background-color: #333; }
|
||||
.highlight .hll { background-color: #333333 }
|
||||
.highlight .c { color: #008800; font-style: italic; background-color: #0f140f } /* Comment */
|
||||
.highlight .err { color: #ffffff } /* Error */
|
||||
.highlight .g { color: #ffffff } /* Generic */
|
||||
.highlight .k { color: #fb660a; font-weight: bold } /* Keyword */
|
||||
.highlight .l { color: #ffffff } /* Literal */
|
||||
.highlight .n { color: #ffffff } /* Name */
|
||||
.highlight .o { color: #ffffff } /* Operator */
|
||||
.highlight .x { color: #ffffff } /* Other */
|
||||
.highlight .p { color: #ffffff } /* Punctuation */
|
||||
.highlight .cm { color: #008800; font-style: italic; background-color: #0f140f } /* Comment.Multiline */
|
||||
.highlight .cp { color: #ff0007; font-weight: bold; font-style: italic; background-color: #0f140f } /* Comment.Preproc */
|
||||
.highlight .c1 { color: #008800; font-style: italic; background-color: #0f140f } /* Comment.Single */
|
||||
.highlight .cs { color: #008800; font-style: italic; background-color: #0f140f } /* Comment.Special */
|
||||
.highlight .gd { color: #ffffff } /* Generic.Deleted */
|
||||
.highlight .ge { color: #ffffff } /* Generic.Emph */
|
||||
.highlight .gr { color: #ffffff } /* Generic.Error */
|
||||
.highlight .gh { color: #ffffff; font-weight: bold } /* Generic.Heading */
|
||||
.highlight .gi { color: #ffffff } /* Generic.Inserted */
|
||||
.highlight .go { color: #444444; background-color: #222222 } /* Generic.Output */
|
||||
.highlight .gp { color: #ffffff } /* Generic.Prompt */
|
||||
.highlight .gs { color: #ffffff } /* Generic.Strong */
|
||||
.highlight .gu { color: #ffffff; font-weight: bold } /* Generic.Subheading */
|
||||
.highlight .gt { color: #ffffff } /* Generic.Traceback */
|
||||
.highlight .kc { color: #fb660a; font-weight: bold } /* Keyword.Constant */
|
||||
.highlight .kd { color: #fb660a; font-weight: bold } /* Keyword.Declaration */
|
||||
.highlight .kn { color: #fb660a; font-weight: bold } /* Keyword.Namespace */
|
||||
.highlight .kp { color: #fb660a } /* Keyword.Pseudo */
|
||||
.highlight .kr { color: #fb660a; font-weight: bold } /* Keyword.Reserved */
|
||||
.highlight .kt { color: #cdcaa9; font-weight: bold } /* Keyword.Type */
|
||||
.highlight .ld { color: #ffffff } /* Literal.Date */
|
||||
.highlight .m { color: #0086f7; font-weight: bold } /* Literal.Number */
|
||||
.highlight .s { color: #0086d2 } /* Literal.String */
|
||||
.highlight .na { color: #ff0086; font-weight: bold } /* Name.Attribute */
|
||||
.highlight .nb { color: #ffffff } /* Name.Builtin */
|
||||
.highlight .nc { color: #ffffff } /* Name.Class */
|
||||
.highlight .no { color: #0086d2 } /* Name.Constant */
|
||||
.highlight .nd { color: #ffffff } /* Name.Decorator */
|
||||
.highlight .ni { color: #ffffff } /* Name.Entity */
|
||||
.highlight .ne { color: #ffffff } /* Name.Exception */
|
||||
.highlight .nf { color: #ff0086; font-weight: bold } /* Name.Function */
|
||||
.highlight .nl { color: #ffffff } /* Name.Label */
|
||||
.highlight .nn { color: #ffffff } /* Name.Namespace */
|
||||
.highlight .nx { color: #ffffff } /* Name.Other */
|
||||
.highlight .py { color: #ffffff } /* Name.Property */
|
||||
.highlight .nt { color: #fb660a; font-weight: bold } /* Name.Tag */
|
||||
.highlight .nv { color: #fb660a } /* Name.Variable */
|
||||
.highlight .ow { color: #ffffff } /* Operator.Word */
|
||||
.highlight .w { color: #888888 } /* Text.Whitespace */
|
||||
.highlight .mf { color: #0086f7; font-weight: bold } /* Literal.Number.Float */
|
||||
.highlight .mh { color: #0086f7; font-weight: bold } /* Literal.Number.Hex */
|
||||
.highlight .mi { color: #0086f7; font-weight: bold } /* Literal.Number.Integer */
|
||||
.highlight .mo { color: #0086f7; font-weight: bold } /* Literal.Number.Oct */
|
||||
.highlight .sb { color: #0086d2 } /* Literal.String.Backtick */
|
||||
.highlight .sc { color: #0086d2 } /* Literal.String.Char */
|
||||
.highlight .sd { color: #0086d2 } /* Literal.String.Doc */
|
||||
.highlight .s2 { color: #0086d2 } /* Literal.String.Double */
|
||||
.highlight .se { color: #0086d2 } /* Literal.String.Escape */
|
||||
.highlight .sh { color: #0086d2 } /* Literal.String.Heredoc */
|
||||
.highlight .si { color: #0086d2 } /* Literal.String.Interpol */
|
||||
.highlight .sx { color: #0086d2 } /* Literal.String.Other */
|
||||
.highlight .sr { color: #0086d2 } /* Literal.String.Regex */
|
||||
.highlight .s1 { color: #0086d2 } /* Literal.String.Single */
|
||||
.highlight .ss { color: #0086d2 } /* Literal.String.Symbol */
|
||||
.highlight .bp { color: #ffffff } /* Name.Builtin.Pseudo */
|
||||
.highlight .vc { color: #fb660a } /* Name.Variable.Class */
|
||||
.highlight .vg { color: #fb660a } /* Name.Variable.Global */
|
||||
.highlight .vi { color: #fb660a } /* Name.Variable.Instance */
|
||||
.highlight .il { color: #0086f7; font-weight: bold } /* Literal.Number.Integer.Long */
|
@ -1,61 +0,0 @@
|
||||
.highlight .hll { background-color: #ffffcc }
|
||||
.highlight .c { color: #999988; font-style: italic } /* Comment */
|
||||
.highlight .err { color: #a61717; background-color: #e3d2d2 } /* Error */
|
||||
.highlight .k { color: #000000; font-weight: bold } /* Keyword */
|
||||
.highlight .o { color: #000000; font-weight: bold } /* Operator */
|
||||
.highlight .cm { color: #999988; font-style: italic } /* Comment.Multiline */
|
||||
.highlight .cp { color: #999999; font-weight: bold; font-style: italic } /* Comment.Preproc */
|
||||
.highlight .c1 { color: #999988; font-style: italic } /* Comment.Single */
|
||||
.highlight .cs { color: #999999; font-weight: bold; font-style: italic } /* Comment.Special */
|
||||
.highlight .gd { color: #000000; background-color: #ffdddd } /* Generic.Deleted */
|
||||
.highlight .ge { color: #000000; font-style: italic } /* Generic.Emph */
|
||||
.highlight .gr { color: #aa0000 } /* Generic.Error */
|
||||
.highlight .gh { color: #999999 } /* Generic.Heading */
|
||||
.highlight .gi { color: #000000; background-color: #ddffdd } /* Generic.Inserted */
|
||||
.highlight .go { color: #888888 } /* Generic.Output */
|
||||
.highlight .gp { color: #555555 } /* Generic.Prompt */
|
||||
.highlight .gs { font-weight: bold } /* Generic.Strong */
|
||||
.highlight .gu { color: #aaaaaa } /* Generic.Subheading */
|
||||
.highlight .gt { color: #aa0000 } /* Generic.Traceback */
|
||||
.highlight .kc { color: #000000; font-weight: bold } /* Keyword.Constant */
|
||||
.highlight .kd { color: #000000; font-weight: bold } /* Keyword.Declaration */
|
||||
.highlight .kn { color: #000000; font-weight: bold } /* Keyword.Namespace */
|
||||
.highlight .kp { color: #000000; font-weight: bold } /* Keyword.Pseudo */
|
||||
.highlight .kr { color: #000000; font-weight: bold } /* Keyword.Reserved */
|
||||
.highlight .kt { color: #445588; font-weight: bold } /* Keyword.Type */
|
||||
.highlight .m { color: #009999 } /* Literal.Number */
|
||||
.highlight .s { color: #d01040 } /* Literal.String */
|
||||
.highlight .na { color: #008080 } /* Name.Attribute */
|
||||
.highlight .nb { color: #0086B3 } /* Name.Builtin */
|
||||
.highlight .nc { color: #445588; font-weight: bold } /* Name.Class */
|
||||
.highlight .no { color: #008080 } /* Name.Constant */
|
||||
.highlight .nd { color: #3c5d5d; font-weight: bold } /* Name.Decorator */
|
||||
.highlight .ni { color: #800080 } /* Name.Entity */
|
||||
.highlight .ne { color: #990000; font-weight: bold } /* Name.Exception */
|
||||
.highlight .nf { color: #990000; font-weight: bold } /* Name.Function */
|
||||
.highlight .nl { color: #990000; font-weight: bold } /* Name.Label */
|
||||
.highlight .nn { color: #555555 } /* Name.Namespace */
|
||||
.highlight .nt { color: #000080 } /* Name.Tag */
|
||||
.highlight .nv { color: #008080 } /* Name.Variable */
|
||||
.highlight .ow { color: #000000; font-weight: bold } /* Operator.Word */
|
||||
.highlight .w { color: #bbbbbb } /* Text.Whitespace */
|
||||
.highlight .mf { color: #009999 } /* Literal.Number.Float */
|
||||
.highlight .mh { color: #009999 } /* Literal.Number.Hex */
|
||||
.highlight .mi { color: #009999 } /* Literal.Number.Integer */
|
||||
.highlight .mo { color: #009999 } /* Literal.Number.Oct */
|
||||
.highlight .sb { color: #d01040 } /* Literal.String.Backtick */
|
||||
.highlight .sc { color: #d01040 } /* Literal.String.Char */
|
||||
.highlight .sd { color: #d01040 } /* Literal.String.Doc */
|
||||
.highlight .s2 { color: #d01040 } /* Literal.String.Double */
|
||||
.highlight .se { color: #d01040 } /* Literal.String.Escape */
|
||||
.highlight .sh { color: #d01040 } /* Literal.String.Heredoc */
|
||||
.highlight .si { color: #d01040 } /* Literal.String.Interpol */
|
||||
.highlight .sx { color: #d01040 } /* Literal.String.Other */
|
||||
.highlight .sr { color: #009926 } /* Literal.String.Regex */
|
||||
.highlight .s1 { color: #d01040 } /* Literal.String.Single */
|
||||
.highlight .ss { color: #990073 } /* Literal.String.Symbol */
|
||||
.highlight .bp { color: #999999 } /* Name.Builtin.Pseudo */
|
||||
.highlight .vc { color: #008080 } /* Name.Variable.Class */
|
||||
.highlight .vg { color: #008080 } /* Name.Variable.Global */
|
||||
.highlight .vi { color: #008080 } /* Name.Variable.Instance */
|
||||
.highlight .il { color: #009999 } /* Literal.Number.Integer.Long */
|
@ -1,224 +0,0 @@
|
||||
body {
|
||||
margin: 0;
|
||||
padding: 0;
|
||||
font-family: 'IBM Plex Mono', monospace;
|
||||
font-family: 'IBM Plex Sans', sans-serif;
|
||||
}
|
||||
|
||||
.foot {}
|
||||
|
||||
.site-info {
|
||||
color: rgb(199, 195, 195);
|
||||
background-color: #FFF;
|
||||
}
|
||||
|
||||
.header-gap {
|
||||
/* height: 30px;
|
||||
background-color: #ebeef1; */
|
||||
}
|
||||
|
||||
.header {
|
||||
height: 35vh;
|
||||
background-color: #ebeef1;
|
||||
background-image: url('/assets/images/banner.jpg');
|
||||
background-repeat: no-repeat;
|
||||
background-size: cover;
|
||||
background-position: center;
|
||||
}
|
||||
|
||||
.table-fix {
|
||||
overflow: auto;
|
||||
}
|
||||
|
||||
table {
|
||||
width: 100%;
|
||||
margin-bottom: 1rem;
|
||||
color: #212529;
|
||||
vertical-align: top;
|
||||
}
|
||||
|
||||
table th, table td {
|
||||
padding: 0.5rem;
|
||||
border-bottom: 1px solid #dee2e6;
|
||||
}
|
||||
|
||||
table tbody {
|
||||
vertical-align: inherit;
|
||||
}
|
||||
|
||||
table td {
|
||||
border-bottom: 1px solid #dee2e6;
|
||||
}
|
||||
|
||||
thead th {
|
||||
color: #495057;
|
||||
background-color: #e9ecef;
|
||||
border-color: #dee2e6;
|
||||
}
|
||||
|
||||
.shadow {
|
||||
box-shadow: 0 4px 8px 0 rgba(0, 0, 0, 0.2), 0 6px 20px 0 rgba(0, 0, 0, 0.19);
|
||||
}
|
||||
|
||||
.header .container {
|
||||
height: 100%;
|
||||
display: flex;
|
||||
align-items: center;
|
||||
/* align vertical */
|
||||
}
|
||||
|
||||
.hidden {
|
||||
display: none !important;
|
||||
}
|
||||
|
||||
img {
|
||||
max-width: 100%;
|
||||
}
|
||||
|
||||
.centre {
|
||||
text-align: center;
|
||||
}
|
||||
|
||||
h1, h2, h3, h4, h5, h6 {
|
||||
font-family: 'IBM Plex Mono', monospace;
|
||||
}
|
||||
|
||||
a h5 {
|
||||
color: #105edd;
|
||||
}
|
||||
|
||||
.post.container {
|
||||
padding: 20px;
|
||||
font-family: 'IBM Plex Sans', sans-serif;
|
||||
box-shadow: 0 4px 8px 0 rgba(0, 0, 0, 0.2), 0 6px 20px 0 rgba(0, 0, 0, 0.19);
|
||||
/* border-radius: 15px;
|
||||
transform: translateY(-30px); */
|
||||
background-color: #fff;
|
||||
}
|
||||
|
||||
.home.container {
|
||||
padding: 20px;
|
||||
font-family: 'Noto Sans TC', sans-serif;
|
||||
box-shadow: 0 4px 8px 0 rgba(0, 0, 0, 0.2), 0 6px 20px 0 rgba(0, 0, 0, 0.19);
|
||||
background-color: #fff;
|
||||
}
|
||||
|
||||
.container .profile {
|
||||
width: 30vw;
|
||||
max-width: 242px;
|
||||
transform: translateY(calc(10vh * -1));
|
||||
border-color: #fff;
|
||||
border-width: 10px;
|
||||
border-radius: 10%;
|
||||
border-style: solid;
|
||||
margin: 20px;
|
||||
}
|
||||
|
||||
.profile img {
|
||||
border-radius: 5%;
|
||||
}
|
||||
|
||||
.home-header {
|
||||
height: 100%;
|
||||
background-image: url('/assets/images/banner.jpg');
|
||||
background-repeat: no-repeat;
|
||||
background-size: cover;
|
||||
background-position: center;
|
||||
}
|
||||
|
||||
.site-ctr {
|
||||
min-height: 100vh;
|
||||
}
|
||||
|
||||
.tagline {
|
||||
text-align: center;
|
||||
max-width: 600px;
|
||||
margin: auto;
|
||||
}
|
||||
|
||||
.container .info {
|
||||
transform: translateY(calc(13vh * -1));
|
||||
padding: 20px;
|
||||
}
|
||||
|
||||
.info h1 {
|
||||
/* padding: 20px; */
|
||||
text-align: left;
|
||||
}
|
||||
|
||||
/* #particles-js{
|
||||
position: absolute;
|
||||
} */
|
||||
|
||||
/*
|
||||
.reactive-bg{
|
||||
position:relative
|
||||
} */
|
||||
|
||||
#particles-js canvas {
|
||||
display: block;
|
||||
vertical-align: bottom;
|
||||
-webkit-transform: scale(1);
|
||||
-ms-transform: scale(1);
|
||||
transform: scale(1);
|
||||
opacity: 1;
|
||||
-webkit-transition: opacity .8s ease, -webkit-transform 1.4s ease;
|
||||
transition: opacity .8s ease, transform 1.4s ease
|
||||
}
|
||||
|
||||
#particles-js {
|
||||
width: 100%;
|
||||
position: absolute;
|
||||
z-index: -10;
|
||||
top: 0;
|
||||
left: 0
|
||||
}
|
||||
|
||||
blockquote {
|
||||
background: #f9f9f9;
|
||||
border-left: 10px solid #ccc;
|
||||
margin: 1.5em 10px;
|
||||
padding: 0.5em 10px;
|
||||
/* quotes: "\201C""\201D""\2018""\2019"; */
|
||||
}
|
||||
|
||||
blockquote:before {
|
||||
color: #ccc;
|
||||
/* content: open-quote; */
|
||||
font-size: 4em;
|
||||
line-height: 0.1em;
|
||||
margin-right: 0.25em;
|
||||
vertical-align: -0.4em;
|
||||
}
|
||||
|
||||
blockquote p {
|
||||
display: inline;
|
||||
}
|
||||
|
||||
kbd {
|
||||
margin: 0px 0.1em;
|
||||
padding: 0.1em 0.6em;
|
||||
border-radius: 3px;
|
||||
border: 1px solid rgb(204, 204, 204);
|
||||
color: rgb(51, 51, 51);
|
||||
line-height: 1.4;
|
||||
font-size: 10px;
|
||||
display: inline-block;
|
||||
box-shadow: 0px 1px 0px rgba(0,0,0,0.2), inset 0px 0px 0px 2px #ffffff;
|
||||
background-color: rgb(247, 247, 247);
|
||||
-moz-box-shadow: 0 1px 0px rgba(0, 0, 0, 0.2), 0 0 0 2px #ffffff inset;
|
||||
-webkit-box-shadow: 0 1px 0px rgba(0, 0, 0, 0.2), 0 0 0 2px #ffffff inset;
|
||||
-moz-border-radius: 3px;
|
||||
-webkit-border-radius: 3px;
|
||||
text-shadow: 0 1px 0 #fff;
|
||||
}
|
||||
|
||||
.highlight {
|
||||
background-color: #faf9f9;
|
||||
border-radius:5px;
|
||||
}
|
||||
|
||||
pre {
|
||||
padding:3px;
|
||||
}
|
||||
}
|
Before Width: | Height: | Size: 229 KiB |
Before Width: | Height: | Size: 346 KiB |
Before Width: | Height: | Size: 32 KiB |
Before Width: | Height: | Size: 575 KiB |
Before Width: | Height: | Size: 194 KiB |
Before Width: | Height: | Size: 32 KiB |
Before Width: | Height: | Size: 24 KiB |
Before Width: | Height: | Size: 65 KiB |
Before Width: | Height: | Size: 53 KiB |
Before Width: | Height: | Size: 25 KiB |
Before Width: | Height: | Size: 5.1 KiB |
Before Width: | Height: | Size: 29 KiB |
Before Width: | Height: | Size: 48 KiB |
Before Width: | Height: | Size: 13 KiB |
Before Width: | Height: | Size: 30 KiB |
Before Width: | Height: | Size: 14 KiB |
Before Width: | Height: | Size: 35 KiB |
3
_site/assets/js/p5.min.js
vendored
@ -1,110 +0,0 @@
|
||||
{
|
||||
"particles": {
|
||||
"number": {
|
||||
"value": 33,
|
||||
"density": {
|
||||
"enable": true,
|
||||
"value_area": 800
|
||||
}
|
||||
},
|
||||
"color": {
|
||||
"value": "#6c757d"
|
||||
},
|
||||
"shape": {
|
||||
"type": "circle",
|
||||
"stroke": {
|
||||
"width": 0,
|
||||
"color": "#000000"
|
||||
},
|
||||
"polygon": {
|
||||
"nb_sides": 5
|
||||
},
|
||||
"image": {
|
||||
"src": "img/github.svg",
|
||||
"width": 100,
|
||||
"height": 100
|
||||
}
|
||||
},
|
||||
"opacity": {
|
||||
"value": 0.5,
|
||||
"random": false,
|
||||
"anim": {
|
||||
"enable": false,
|
||||
"speed": 1,
|
||||
"opacity_min": 0.1,
|
||||
"sync": false
|
||||
}
|
||||
},
|
||||
"size": {
|
||||
"value": 3.9458004845442964,
|
||||
"random": false,
|
||||
"anim": {
|
||||
"enable": false,
|
||||
"speed": 40,
|
||||
"size_min": 0.1,
|
||||
"sync": false
|
||||
}
|
||||
},
|
||||
"line_linked": {
|
||||
"enable": true,
|
||||
"distance": 110.4824135672403,
|
||||
"color": "#17a2b8",
|
||||
"opacity": 1,
|
||||
"width": 4.419296542689612
|
||||
},
|
||||
"move": {
|
||||
"enable": false,
|
||||
"speed": 6,
|
||||
"direction": "none",
|
||||
"random": false,
|
||||
"straight": false,
|
||||
"out_mode": "out",
|
||||
"bounce": false,
|
||||
"attract": {
|
||||
"enable": false,
|
||||
"rotateX": 600,
|
||||
"rotateY": 1200
|
||||
}
|
||||
}
|
||||
},
|
||||
"interactivity": {
|
||||
"detect_on": "canvas",
|
||||
"events": {
|
||||
"onhover": {
|
||||
"enable": false,
|
||||
"mode": "repulse"
|
||||
},
|
||||
"onclick": {
|
||||
"enable": true,
|
||||
"mode": "remove"
|
||||
},
|
||||
"resize": true
|
||||
},
|
||||
"modes": {
|
||||
"grab": {
|
||||
"distance": 400,
|
||||
"line_linked": {
|
||||
"opacity": 1
|
||||
}
|
||||
},
|
||||
"bubble": {
|
||||
"distance": 400,
|
||||
"size": 40,
|
||||
"duration": 2,
|
||||
"opacity": 8,
|
||||
"speed": 3
|
||||
},
|
||||
"repulse": {
|
||||
"distance": 200,
|
||||
"duration": 0.4
|
||||
},
|
||||
"push": {
|
||||
"particles_nb": 4
|
||||
},
|
||||
"remove": {
|
||||
"particles_nb": 2
|
||||
}
|
||||
}
|
||||
},
|
||||
"retina_detect": true
|
||||
}
|
9
_site/assets/js/particles.min.js
vendored
@ -1,159 +0,0 @@
|
||||
from browser import document, alert
|
||||
|
||||
|
||||
import base64
|
||||
import hashlib
|
||||
|
||||
_version = 2
|
||||
|
||||
def execLayerSeq(layers, msg, key, decode=False):
|
||||
# Make sure to reverse layers for decoding
|
||||
if decode:
|
||||
for layer in layers[::-1]:
|
||||
msg, key = layer.decode(msg, key)
|
||||
else:
|
||||
for layer in layers:
|
||||
msg, key = layer.encode(msg, key)
|
||||
|
||||
return msg
|
||||
|
||||
class BitshiftLayer(object):
|
||||
|
||||
def encode(self, file, key):
|
||||
# Encode once to allow for binary data
|
||||
file = base64.b85encode(file.encode())
|
||||
output = ""
|
||||
|
||||
# Iterate and shift
|
||||
for i, byte in enumerate(file):
|
||||
# Mod the current bit
|
||||
output += chr(byte ^ key[i%len(key) - 1])
|
||||
|
||||
# Mod the key
|
||||
key.append(i%key[0])
|
||||
|
||||
# Final encoding
|
||||
output = base64.b85encode(output.encode())
|
||||
|
||||
# Return as string
|
||||
return (output.decode(), key)
|
||||
|
||||
def decode(self, file, key):
|
||||
# Decode the file to shifted bytes
|
||||
try:
|
||||
file = base64.b85decode(file.strip().encode())
|
||||
except:
|
||||
return ("INVALID DATA", key)
|
||||
output = ""
|
||||
|
||||
for i, byte in enumerate(file):
|
||||
# Unmod the current byte
|
||||
mod = byte ^ key[i%len(key) - 1]
|
||||
if mod not in range(0x110000):
|
||||
mod = 0
|
||||
output += chr(mod)
|
||||
|
||||
# Mod the current key
|
||||
key.append(i%key[0])
|
||||
|
||||
# Pull the resulting b64 back to binary if needed
|
||||
# This may fail due to "incorrect padding" from a wrong key
|
||||
# Just return some random text in this case for now
|
||||
try:
|
||||
output = base64.b85decode(output.encode()).decode()
|
||||
except:
|
||||
output = output
|
||||
|
||||
# Return as bytes
|
||||
return (output, key)
|
||||
|
||||
class DataHeaderLayer(object):
|
||||
|
||||
def encode(self, file, key):
|
||||
version = _version
|
||||
fdl = len(file)
|
||||
base = 85
|
||||
|
||||
# Construct header
|
||||
header = []
|
||||
header.append(version)
|
||||
header += list((fdl & 0xFFFFFFFF).to_bytes(4, 'big'))
|
||||
header += list((base & 0xFFFFFFFF).to_bytes(2, 'big'))
|
||||
|
||||
header = base64.b64encode(bytes(header)).decode()
|
||||
|
||||
return (header + file, key)
|
||||
|
||||
def decode(self, file, key):
|
||||
# Header is the first 12 chars
|
||||
header = file[:12]
|
||||
file = file[12:]
|
||||
try:
|
||||
header = base64.b64decode(header.encode())
|
||||
except:
|
||||
return ("INVALID DATA", key)
|
||||
header = bytes(header)
|
||||
|
||||
version = header[0]
|
||||
|
||||
# Conversion failed if the version is incorrect
|
||||
if version != _version:
|
||||
return ("INVALID DATA", key)
|
||||
|
||||
fdl = header[:5][1:]
|
||||
fdl = int.from_bytes(fdl, byteorder='big')
|
||||
|
||||
# Chop off possible extra data
|
||||
file = file[:fdl]
|
||||
|
||||
return (file, key)
|
||||
|
||||
def key2shifts(key: str) -> list:
|
||||
output = []
|
||||
|
||||
for char in key:
|
||||
output.append(ord(char))
|
||||
|
||||
return output
|
||||
|
||||
|
||||
crypt_layers = [
|
||||
DataHeaderLayer(),
|
||||
BitshiftLayer()
|
||||
|
||||
]
|
||||
|
||||
def encode(file, key):
|
||||
return execLayerSeq(crypt_layers, file, key)
|
||||
|
||||
def decode(file, key):
|
||||
return execLayerSeq(crypt_layers, file, key, decode=True)
|
||||
|
||||
|
||||
tx = encode("Hello", key2shifts("123"))
|
||||
# alert("test:" + tx)
|
||||
|
||||
def doShiftDemo(_):
|
||||
do_encode = bool(document["encode"].checked)
|
||||
|
||||
if do_encode:
|
||||
key = document["key"].value
|
||||
msg = document["msg"].value
|
||||
|
||||
new_msg = encode(msg, key2shifts(key))
|
||||
|
||||
document["msg"].value = new_msg
|
||||
else:
|
||||
key = document["key"].value
|
||||
msg = document["msg"].value
|
||||
|
||||
new_msg = decode(msg, key2shifts(key))
|
||||
|
||||
document["msg"].value = new_msg
|
||||
|
||||
|
||||
document["shift-button"].bind("click", doShiftDemo)
|
||||
|
||||
# Set the button
|
||||
document["shift-button"].innerHTML = "Run Shift2"
|
||||
document["shift-button"].disabled = False
|
@ -1,127 +0,0 @@
|
||||
import base64
|
||||
import hashlib
|
||||
|
||||
_version = 2
|
||||
|
||||
def execLayerSeq(layers, msg, key, decode=False):
|
||||
# Make sure to reverse layers for decoding
|
||||
if decode:
|
||||
for layer in layers[::-1]:
|
||||
msg, key = layer.decode(msg, key)
|
||||
else:
|
||||
for layer in layers:
|
||||
msg, key = layer.encode(msg, key)
|
||||
|
||||
return msg
|
||||
|
||||
class BitshiftLayer(object):
|
||||
|
||||
def encode(self, file, key):
|
||||
# Encode once to allow for binary data
|
||||
file = base64.b85encode(file.encode())
|
||||
output = ""
|
||||
|
||||
# Iterate and shift
|
||||
for i, byte in enumerate(file):
|
||||
# Mod the current bit
|
||||
output += chr(byte ^ key[i%len(key) - 1])
|
||||
|
||||
# Mod the key
|
||||
key.append(i%key[0])
|
||||
|
||||
# Final encoding
|
||||
output = base64.b85encode(output.encode())
|
||||
|
||||
# Return as string
|
||||
return (output.decode(), key)
|
||||
|
||||
def decode(self, file, key):
|
||||
# Decode the file to shifted bytes
|
||||
try:
|
||||
file = base64.b85decode(file.strip().encode())
|
||||
except:
|
||||
return ("INVALID DATA", key)
|
||||
output = ""
|
||||
|
||||
for i, byte in enumerate(file):
|
||||
# Unmod the current byte
|
||||
mod = byte ^ key[i%len(key) - 1]
|
||||
if mod not in range(0x110000):
|
||||
mod = 0
|
||||
output += chr(mod)
|
||||
|
||||
# Mod the current key
|
||||
key.append(i%key[0])
|
||||
|
||||
# Pull the resulting b64 back to binary if needed
|
||||
# This may fail due to "incorrect padding" from a wrong key
|
||||
# Just return some random text in this case for now
|
||||
try:
|
||||
output = base64.b85decode(output.encode()).decode()
|
||||
except:
|
||||
output = output
|
||||
|
||||
# Return as bytes
|
||||
return (output, key)
|
||||
|
||||
class DataHeaderLayer(object):
|
||||
|
||||
def encode(self, file, key):
|
||||
version = _version
|
||||
fdl = len(file)
|
||||
base = 85
|
||||
|
||||
# Construct header
|
||||
header = []
|
||||
header.append(version)
|
||||
header += list((fdl & 0xFFFFFFFF).to_bytes(4, 'big'))
|
||||
header += list((base & 0xFFFFFFFF).to_bytes(2, 'big'))
|
||||
|
||||
header = base64.b64encode(bytes(header)).decode()
|
||||
|
||||
return (header + file, key)
|
||||
|
||||
def decode(self, file, key):
|
||||
# Header is the first 12 chars
|
||||
header = file[:12]
|
||||
file = file[12:]
|
||||
try:
|
||||
header = base64.b64decode(header.encode())
|
||||
except:
|
||||
return ("INVALID DATA", key)
|
||||
header = bytes(header)
|
||||
|
||||
version = header[0]
|
||||
|
||||
# Conversion failed if the version is incorrect
|
||||
if version != _version:
|
||||
return ("INVALID DATA", key)
|
||||
|
||||
fdl = header[:5][1:]
|
||||
fdl = int.from_bytes(fdl, byteorder='big')
|
||||
|
||||
# Chop off possible extra data
|
||||
file = file[:fdl]
|
||||
|
||||
return (file, key)
|
||||
|
||||
def key2shifts(key: str) -> list:
|
||||
output = []
|
||||
|
||||
for char in key:
|
||||
output.append(ord(char))
|
||||
|
||||
return output
|
||||
|
||||
|
||||
crypt_layers = [
|
||||
DataHeaderLayer(),
|
||||
BitshiftLayer()
|
||||
|
||||
]
|
||||
|
||||
def encode(file, key):
|
||||
return execLayerSeq(crypt_layers, file, key)
|
||||
|
||||
def decode(file, key):
|
||||
return execLayerSeq(crypt_layers, file, key, decode=True)
|
@ -1,226 +0,0 @@
|
||||
<head>
|
||||
<title>Evan Pratten</title>
|
||||
<meta charset="utf-8" />
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=no" />
|
||||
|
||||
<!-- Begin Jekyll SEO tag v2.6.1 -->
|
||||
<title>Using a python script to create devRant posts based on the style and content of another user | Evan Pratten</title>
|
||||
<meta name="generator" content="Jekyll v4.0.0" />
|
||||
<meta property="og:title" content="Using a python script to create devRant posts based on the style and content of another user" />
|
||||
<meta property="og:locale" content="en_US" />
|
||||
<meta name="description" content="if/else ++" />
|
||||
<meta property="og:description" content="if/else ++" />
|
||||
<link rel="canonical" href="http://0.0.0.0:4000/blog/2018/06/27/becomeranter" />
|
||||
<meta property="og:url" content="http://0.0.0.0:4000/blog/2018/06/27/becomeranter" />
|
||||
<meta property="og:site_name" content="Evan Pratten" />
|
||||
<meta property="og:type" content="article" />
|
||||
<meta property="article:published_time" content="2018-06-27T14:32:00-04:00" />
|
||||
<script type="application/ld+json">
|
||||
{"datePublished":"2018-06-27T14:32:00-04:00","mainEntityOfPage":{"@type":"WebPage","@id":"http://0.0.0.0:4000/blog/2018/06/27/becomeranter"},"@type":"BlogPosting","url":"http://0.0.0.0:4000/blog/2018/06/27/becomeranter","headline":"Using a python script to create devRant posts based on the style and content of another user","description":"if/else ++","dateModified":"2018-06-27T14:32:00-04:00","@context":"https://schema.org"}</script>
|
||||
<!-- End Jekyll SEO tag -->
|
||||
|
||||
|
||||
|
||||
<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="/assets/css/main.css">
|
||||
<link rel="stylesheet" href="/assets/css/github-syntax.css">
|
||||
<link href="https://fonts.googleapis.com/css?family=IBM+Plex+Mono:400,400i|IBM+Plex+Sans:100,100i,400,400i,700,700i" rel="stylesheet">
|
||||
<link href="https://stackpath.bootstrapcdn.com/font-awesome/4.7.0/css/font-awesome.min.css" rel="stylesheet" integrity="sha384-wvfXpqpZZVQGK6TAh5PVlGOfQNHSoD2xbE+QkPxCAFlNEevoEH3Sl0sibVcOQVnN" crossorigin="anonymous">
|
||||
</head>
|
||||
|
||||
<body>
|
||||
|
||||
<div class="site-ctr">
|
||||
<!-- Navbar -->
|
||||
<nav class="navbar navbar-dark sticky-top bg-dark navbar-expand-lg">
|
||||
<!-- Navbar content -->
|
||||
<!-- <div class="container"> -->
|
||||
<a class="navbar-brand" href="/">Evan Pratten</a>
|
||||
<button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbarNavAltMarkup"
|
||||
aria-controls="navbarNavAltMarkup" aria-expanded="false" aria-label="Toggle navigation">
|
||||
<span class="navbar-toggler-icon"></span>
|
||||
</button>
|
||||
<div class="collapse navbar-collapse" id="navbarNavAltMarkup">
|
||||
<div class="navbar-nav ml-auto">
|
||||
<a class="nav-item nav-link" href="/blog">Blog</a>
|
||||
<a class="nav-item nav-link" href="/projects">Projects</a>
|
||||
<!-- <a class="nav-item nav-link" href="/documentation">Documentation</a> -->
|
||||
<a class="nav-item nav-link" href="/about">About</a>
|
||||
</div>
|
||||
<!-- </div> -->
|
||||
</div>
|
||||
</nav>
|
||||
<!-- <div style="height:5vh"></div> -->
|
||||
|
||||
<!-- Header -->
|
||||
<!-- <div class="header">
|
||||
<div class="container">
|
||||
<div class="content">
|
||||
</div>
|
||||
</div>
|
||||
<div class="header-gap"></div>
|
||||
</div> -->
|
||||
|
||||
<div class="reactive-bg">
|
||||
<div class="post container">
|
||||
<h1>Using a python script to create devRant posts based on the style and content of another user
|
||||
|
||||
</h1>
|
||||
<h4>if/else ++
|
||||
|
||||
</h4>
|
||||
<hr>
|
||||
<p><em>2018-06-27 14:32:00 -0400
|
||||
|
||||
</em></p>
|
||||
|
||||
<br>
|
||||
|
||||
<p>Ok… The title is slightly wrong. There are actually 2 scripts.. Sorry about that.</p>
|
||||
|
||||
<p>This is a guide on installing and using the <a href="https://github.com/Ewpratten/BecomeRanter">BecomeRanter</a> script.</p>
|
||||
|
||||
<h2 id="getting-dependancies">Getting dependancies</h2>
|
||||
<p>The scripts use Google’s tensorflow library to do its “magic”. So first, we should install Tensorflow’s dependencies.</p>
|
||||
|
||||
<div class="highlighter-rouge"><div class="highlight"><pre class="highlight"><code>sudo apt install python3 python3-pip #change this command to fit your distro
|
||||
pip3 install numpy
|
||||
</code></pre></div></div>
|
||||
<p>Then install Tensorflow</p>
|
||||
<div class="highlighter-rouge"><div class="highlight"><pre class="highlight"><code>pip3 install tensorflow #for cpu processing
|
||||
pip3 install tensorflow-gpu #for gpu processing
|
||||
</code></pre></div></div>
|
||||
|
||||
<p>Next up, install the rest of the stuff:</p>
|
||||
<div class="highlighter-rouge"><div class="highlight"><pre class="highlight"><code>pip3 install textgenrnn pandas keras
|
||||
</code></pre></div></div>
|
||||
|
||||
<h2 id="clone-the-repo">Clone the repo</h2>
|
||||
<p>This is pretty simple. just make sure you have <code class="highlighter-rouge">git</code> installed and run</p>
|
||||
<div class="highlighter-rouge"><div class="highlight"><pre class="highlight"><code>git clone https://github.com/Ewpratten/BecomeRanter.git
|
||||
</code></pre></div></div>
|
||||
|
||||
<h2 id="generate-some-rants-with-a-hdf5-file">Generate some rants with a .hdf5 file</h2>
|
||||
<p>As of the time of writing this, I have pre-generated some files for the two most popular ranters. These files can be found in <code class="highlighter-rouge">BecomeRanter/Checkpoint\ Files</code>.</p>
|
||||
|
||||
<p>Higher epoch numbers mean that they have had more time to train. The files with lower numbers are generally funnier.</p>
|
||||
|
||||
<p>To change the .hdf5 file you would like to use, open the file called <code class="highlighter-rouge">createsomerants.py</code> and change the variable called <code class="highlighter-rouge">input_file</code> to the path of your file. By default, the script generates from the <code class="highlighter-rouge">Linuxxx-epoch-90.hdf5</code> file.</p>
|
||||
|
||||
<p>Next, save that file and run the following in your terminal:</p>
|
||||
<div class="highlighter-rouge"><div class="highlight"><pre class="highlight"><code>python3 createsomerants.py >> output.txt
|
||||
</code></pre></div></div>
|
||||
<p>It will not print the results out to the screen and put them in the file instead.</p>
|
||||
|
||||
<p>To stop the script, press CTRL + C</p>
|
||||
|
||||
<h2 id="create-your-own-hdf5-file">Create your own .hdf5 file</h2>
|
||||
<p>If you want to make your own hdf5 file, you just have to use the other script in the repo.</p>
|
||||
|
||||
<p>By default, you can just put all your text to train on in the <code class="highlighter-rouge">input.txt</code> file.</p>
|
||||
|
||||
<p>If you want to use a different file, or change the number of epochs, those variables can be found at the top of the <code class="highlighter-rouge">createhfd5frominput.py</code> file.</p>
|
||||
|
||||
<p>To start training, run:</p>
|
||||
<div class="highlighter-rouge"><div class="highlight"><pre class="highlight"><code>python3 createhfd5frominput.py
|
||||
</code></pre></div></div>
|
||||
|
||||
<p>A new hdf5 file will be generated in the same folder as the script</p>
|
||||
|
||||
|
||||
</div>
|
||||
</div>
|
||||
|
||||
</div>
|
||||
<!-- <div id="particles-js"></div> -->
|
||||
|
||||
<div class="container foot" style="text-align:center;">
|
||||
<br>
|
||||
<span class="site-info">
|
||||
Site design by: <a href="https://retrylife.ca">Evan Pratten</a> |
|
||||
|
||||
This site was last updated at: 2019-11-30 11:37:59 -0500
|
||||
</span>
|
||||
</div>
|
||||
|
||||
<!-- Brython -->
|
||||
<script src="/assets/js/brython.js"></script>
|
||||
<script src="/assets/js/brython_stdlib.js"></script>
|
||||
|
||||
<script>
|
||||
function startPY(){
|
||||
|
||||
brython();
|
||||
console.log("Started Python")
|
||||
}
|
||||
|
||||
window.onload = startPY;
|
||||
</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://stackpath.bootstrapcdn.com/bootstrap/4.3.1/js/bootstrap.min.js"
|
||||
integrity="sha384-JjSmVgyd0p3pXB1rRibZUAYoIIy6OrQ6VrjIEaFf/nJGzIxFDsf4x0xIM+B07jRM"
|
||||
crossorigin="anonymous"></script>
|
||||
|
||||
<!-- Offsets for links -->
|
||||
<script>
|
||||
(function ($, window) {
|
||||
var adjustAnchor = function () {
|
||||
|
||||
var $anchor = $(':target'),
|
||||
fixedElementHeight = 100;
|
||||
|
||||
if ($anchor.length > 0) {
|
||||
|
||||
window.scrollTo(0, $anchor.offset().top - fixedElementHeight);
|
||||
}
|
||||
|
||||
};
|
||||
|
||||
$(window).on('hashchange load', function () {
|
||||
adjustAnchor();
|
||||
});
|
||||
|
||||
})(jQuery, window);
|
||||
</script>
|
||||
|
||||
<!-- Global site tag (gtag.js) - Google Analytics -->
|
||||
<script async src="https://www.googletagmanager.com/gtag/js?id=UA-74118570-2"></script>
|
||||
<script>
|
||||
window.dataLayer = window.dataLayer || [];
|
||||
function gtag() { dataLayer.push(arguments); }
|
||||
gtag('js', new Date());
|
||||
|
||||
gtag('config', 'UA-74118570-2');
|
||||
</script>
|
||||
|
||||
|
||||
<!-- particles -->
|
||||
<script>
|
||||
var body = document.body
|
||||
|
||||
var particles = document.getElementById("particles-js")
|
||||
|
||||
particles.style.height = body.scrollHeight + "px"
|
||||
|
||||
console.log(body.scrollHeight)
|
||||
</script>
|
||||
<script src="/assets/js/particles.min.js"></script>
|
||||
<script>
|
||||
particlesJS.load('particles-js', '/assets/js/particles.json', function () {
|
||||
console.log('callback - particles.js config loaded');
|
||||
});
|
||||
</script>
|
||||
|
||||
<!-- Twitter embeds -->
|
||||
<script async src="https://platform.twitter.com/widgets.js" charset="utf-8"></script>
|
||||
|
||||
|
||||
</body>
|
@ -1,190 +0,0 @@
|
||||
<head>
|
||||
<title>Evan Pratten</title>
|
||||
<meta charset="utf-8" />
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=no" />
|
||||
|
||||
<!-- Begin Jekyll SEO tag v2.6.1 -->
|
||||
<title>The language hunt | Evan Pratten</title>
|
||||
<meta name="generator" content="Jekyll v4.0.0" />
|
||||
<meta property="og:title" content="The language hunt" />
|
||||
<meta property="og:locale" content="en_US" />
|
||||
<meta name="description" content="Our programming team is looking to switch languages in the 2020 season. Here is the what, why, and how." />
|
||||
<meta property="og:description" content="Our programming team is looking to switch languages in the 2020 season. Here is the what, why, and how." />
|
||||
<link rel="canonical" href="http://0.0.0.0:4000/blog/2019/04/30/frc-languages" />
|
||||
<meta property="og:url" content="http://0.0.0.0:4000/blog/2019/04/30/frc-languages" />
|
||||
<meta property="og:site_name" content="Evan Pratten" />
|
||||
<meta property="og:type" content="article" />
|
||||
<meta property="article:published_time" content="2019-04-30T14:32:00-04:00" />
|
||||
<script type="application/ld+json">
|
||||
{"datePublished":"2019-04-30T14:32:00-04:00","mainEntityOfPage":{"@type":"WebPage","@id":"http://0.0.0.0:4000/blog/2019/04/30/frc-languages"},"@type":"BlogPosting","url":"http://0.0.0.0:4000/blog/2019/04/30/frc-languages","headline":"The language hunt","description":"Our programming team is looking to switch languages in the 2020 season. Here is the what, why, and how.","dateModified":"2019-04-30T14:32:00-04:00","@context":"https://schema.org"}</script>
|
||||
<!-- End Jekyll SEO tag -->
|
||||
|
||||
|
||||
|
||||
<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="/assets/css/main.css">
|
||||
<link rel="stylesheet" href="/assets/css/github-syntax.css">
|
||||
<link href="https://fonts.googleapis.com/css?family=IBM+Plex+Mono:400,400i|IBM+Plex+Sans:100,100i,400,400i,700,700i" rel="stylesheet">
|
||||
<link href="https://stackpath.bootstrapcdn.com/font-awesome/4.7.0/css/font-awesome.min.css" rel="stylesheet" integrity="sha384-wvfXpqpZZVQGK6TAh5PVlGOfQNHSoD2xbE+QkPxCAFlNEevoEH3Sl0sibVcOQVnN" crossorigin="anonymous">
|
||||
</head>
|
||||
|
||||
<body>
|
||||
|
||||
<div class="site-ctr">
|
||||
<!-- Navbar -->
|
||||
<nav class="navbar navbar-dark sticky-top bg-dark navbar-expand-lg">
|
||||
<!-- Navbar content -->
|
||||
<!-- <div class="container"> -->
|
||||
<a class="navbar-brand" href="/">Evan Pratten</a>
|
||||
<button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbarNavAltMarkup"
|
||||
aria-controls="navbarNavAltMarkup" aria-expanded="false" aria-label="Toggle navigation">
|
||||
<span class="navbar-toggler-icon"></span>
|
||||
</button>
|
||||
<div class="collapse navbar-collapse" id="navbarNavAltMarkup">
|
||||
<div class="navbar-nav ml-auto">
|
||||
<a class="nav-item nav-link" href="/blog">Blog</a>
|
||||
<a class="nav-item nav-link" href="/projects">Projects</a>
|
||||
<!-- <a class="nav-item nav-link" href="/documentation">Documentation</a> -->
|
||||
<a class="nav-item nav-link" href="/about">About</a>
|
||||
</div>
|
||||
<!-- </div> -->
|
||||
</div>
|
||||
</nav>
|
||||
<!-- <div style="height:5vh"></div> -->
|
||||
|
||||
<!-- Header -->
|
||||
<!-- <div class="header">
|
||||
<div class="container">
|
||||
<div class="content">
|
||||
</div>
|
||||
</div>
|
||||
<div class="header-gap"></div>
|
||||
</div> -->
|
||||
|
||||
<div class="reactive-bg">
|
||||
<div class="post container">
|
||||
<h1>The language hunt
|
||||
|
||||
</h1>
|
||||
<h4>
|
||||
|
||||
</h4>
|
||||
<hr>
|
||||
<p><em>2019-04-30 14:32:00 -0400
|
||||
|
||||
</em></p>
|
||||
|
||||
<br>
|
||||
|
||||
<p>Our programming team is looking to switch languages in the 2020 season. Here is the what, why, and how.</p>
|
||||
|
||||
<h2 id="our-history">Our history</h2>
|
||||
<p>We started out as a java team back in 2014 because java was (and still is) the language being taught in our programming classes. Honestly, our code sucked, as many rookie team’s do. There where no fancy features, or sensor-assisted autonomous. Direct input into talons was our way to roll.</p>
|
||||
|
||||
<p>A few years later, we had a change in team organization and switched to C++. Up until the 2019 / 2020 season, this was our language and we where getting pretty good at using it.</p>
|
||||
|
||||
<h2 id="the-problem">The Problem</h2>
|
||||
<p>We, as a team are looking to bring our programming and robots to the next level in 2020. Because of this, we ran into a problem. While C++ is an amazing language for embedded and robotics programming, some of it’s “features” where starting to act as a bottleneck to our design. Less time was being spent on polishing our new vision system or autonomous climb, and more on that crazy linker error that came out of nowhere.</p>
|
||||
|
||||
<p>It’s time for a change, but what do we change to?</p>
|
||||
|
||||
<h2 id="part-2">Part 2</h2>
|
||||
<p>The followup can be found <a href="/frc/2019/06/24/LanguageHunt2.html">HERE</a>.</p>
|
||||
|
||||
|
||||
</div>
|
||||
</div>
|
||||
|
||||
</div>
|
||||
<!-- <div id="particles-js"></div> -->
|
||||
|
||||
<div class="container foot" style="text-align:center;">
|
||||
<br>
|
||||
<span class="site-info">
|
||||
Site design by: <a href="https://retrylife.ca">Evan Pratten</a> |
|
||||
|
||||
This site was last updated at: 2019-11-30 11:37:59 -0500
|
||||
</span>
|
||||
</div>
|
||||
|
||||
<!-- Brython -->
|
||||
<script src="/assets/js/brython.js"></script>
|
||||
<script src="/assets/js/brython_stdlib.js"></script>
|
||||
|
||||
<script>
|
||||
function startPY(){
|
||||
|
||||
brython();
|
||||
console.log("Started Python")
|
||||
}
|
||||
|
||||
window.onload = startPY;
|
||||
</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://stackpath.bootstrapcdn.com/bootstrap/4.3.1/js/bootstrap.min.js"
|
||||
integrity="sha384-JjSmVgyd0p3pXB1rRibZUAYoIIy6OrQ6VrjIEaFf/nJGzIxFDsf4x0xIM+B07jRM"
|
||||
crossorigin="anonymous"></script>
|
||||
|
||||
<!-- Offsets for links -->
|
||||
<script>
|
||||
(function ($, window) {
|
||||
var adjustAnchor = function () {
|
||||
|
||||
var $anchor = $(':target'),
|
||||
fixedElementHeight = 100;
|
||||
|
||||
if ($anchor.length > 0) {
|
||||
|
||||
window.scrollTo(0, $anchor.offset().top - fixedElementHeight);
|
||||
}
|
||||
|
||||
};
|
||||
|
||||
$(window).on('hashchange load', function () {
|
||||
adjustAnchor();
|
||||
});
|
||||
|
||||
})(jQuery, window);
|
||||
</script>
|
||||
|
||||
<!-- Global site tag (gtag.js) - Google Analytics -->
|
||||
<script async src="https://www.googletagmanager.com/gtag/js?id=UA-74118570-2"></script>
|
||||
<script>
|
||||
window.dataLayer = window.dataLayer || [];
|
||||
function gtag() { dataLayer.push(arguments); }
|
||||
gtag('js', new Date());
|
||||
|
||||
gtag('config', 'UA-74118570-2');
|
||||
</script>
|
||||
|
||||
|
||||
<!-- particles -->
|
||||
<script>
|
||||
var body = document.body
|
||||
|
||||
var particles = document.getElementById("particles-js")
|
||||
|
||||
particles.style.height = body.scrollHeight + "px"
|
||||
|
||||
console.log(body.scrollHeight)
|
||||
</script>
|
||||
<script src="/assets/js/particles.min.js"></script>
|
||||
<script>
|
||||
particlesJS.load('particles-js', '/assets/js/particles.json', function () {
|
||||
console.log('callback - particles.js config loaded');
|
||||
});
|
||||
</script>
|
||||
|
||||
<!-- Twitter embeds -->
|
||||
<script async src="https://platform.twitter.com/widgets.js" charset="utf-8"></script>
|
||||
|
||||
|
||||
</body>
|
@ -1,203 +0,0 @@
|
||||
<head>
|
||||
<title>Evan Pratten</title>
|
||||
<meta charset="utf-8" />
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=no" />
|
||||
|
||||
<!-- Begin Jekyll SEO tag v2.6.1 -->
|
||||
<title>Building a safe and easy system for sending computer vision data from a raspberry pi to a roborio | Evan Pratten</title>
|
||||
<meta name="generator" content="Jekyll v4.0.0" />
|
||||
<meta property="og:title" content="Building a safe and easy system for sending computer vision data from a raspberry pi to a roborio" />
|
||||
<meta property="og:locale" content="en_US" />
|
||||
<meta name="description" content="Computer vision on an FRC robot has some problems. RoboRIO is not powerfull enough NetworkTables is not fast enough A TCP connection is great until you lose connection mDNS discovery is not reliable on the field UDP can skip frames" />
|
||||
<meta property="og:description" content="Computer vision on an FRC robot has some problems. RoboRIO is not powerfull enough NetworkTables is not fast enough A TCP connection is great until you lose connection mDNS discovery is not reliable on the field UDP can skip frames" />
|
||||
<link rel="canonical" href="http://0.0.0.0:4000/blog/2019/05/27/building-safe-vision-comms" />
|
||||
<meta property="og:url" content="http://0.0.0.0:4000/blog/2019/05/27/building-safe-vision-comms" />
|
||||
<meta property="og:site_name" content="Evan Pratten" />
|
||||
<meta property="og:type" content="article" />
|
||||
<meta property="article:published_time" content="2019-05-27T05:22:00-04:00" />
|
||||
<script type="application/ld+json">
|
||||
{"datePublished":"2019-05-27T05:22:00-04:00","mainEntityOfPage":{"@type":"WebPage","@id":"http://0.0.0.0:4000/blog/2019/05/27/building-safe-vision-comms"},"@type":"BlogPosting","url":"http://0.0.0.0:4000/blog/2019/05/27/building-safe-vision-comms","headline":"Building a safe and easy system for sending computer vision data from a raspberry pi to a roborio","description":"Computer vision on an FRC robot has some problems. RoboRIO is not powerfull enough NetworkTables is not fast enough A TCP connection is great until you lose connection mDNS discovery is not reliable on the field UDP can skip frames","dateModified":"2019-05-27T05:22:00-04:00","@context":"https://schema.org"}</script>
|
||||
<!-- End Jekyll SEO tag -->
|
||||
|
||||
|
||||
|
||||
<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="/assets/css/main.css">
|
||||
<link rel="stylesheet" href="/assets/css/github-syntax.css">
|
||||
<link href="https://fonts.googleapis.com/css?family=IBM+Plex+Mono:400,400i|IBM+Plex+Sans:100,100i,400,400i,700,700i" rel="stylesheet">
|
||||
<link href="https://stackpath.bootstrapcdn.com/font-awesome/4.7.0/css/font-awesome.min.css" rel="stylesheet" integrity="sha384-wvfXpqpZZVQGK6TAh5PVlGOfQNHSoD2xbE+QkPxCAFlNEevoEH3Sl0sibVcOQVnN" crossorigin="anonymous">
|
||||
</head>
|
||||
|
||||
<body>
|
||||
|
||||
<div class="site-ctr">
|
||||
<!-- Navbar -->
|
||||
<nav class="navbar navbar-dark sticky-top bg-dark navbar-expand-lg">
|
||||
<!-- Navbar content -->
|
||||
<!-- <div class="container"> -->
|
||||
<a class="navbar-brand" href="/">Evan Pratten</a>
|
||||
<button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbarNavAltMarkup"
|
||||
aria-controls="navbarNavAltMarkup" aria-expanded="false" aria-label="Toggle navigation">
|
||||
<span class="navbar-toggler-icon"></span>
|
||||
</button>
|
||||
<div class="collapse navbar-collapse" id="navbarNavAltMarkup">
|
||||
<div class="navbar-nav ml-auto">
|
||||
<a class="nav-item nav-link" href="/blog">Blog</a>
|
||||
<a class="nav-item nav-link" href="/projects">Projects</a>
|
||||
<!-- <a class="nav-item nav-link" href="/documentation">Documentation</a> -->
|
||||
<a class="nav-item nav-link" href="/about">About</a>
|
||||
</div>
|
||||
<!-- </div> -->
|
||||
</div>
|
||||
</nav>
|
||||
<!-- <div style="height:5vh"></div> -->
|
||||
|
||||
<!-- Header -->
|
||||
<!-- <div class="header">
|
||||
<div class="container">
|
||||
<div class="content">
|
||||
</div>
|
||||
</div>
|
||||
<div class="header-gap"></div>
|
||||
</div> -->
|
||||
|
||||
<div class="reactive-bg">
|
||||
<div class="post container">
|
||||
<h1>Building a safe and easy system for sending computer vision data from a raspberry pi to a roborio
|
||||
|
||||
</h1>
|
||||
<h4>
|
||||
|
||||
</h4>
|
||||
<hr>
|
||||
<p><em>2019-05-27 05:22:00 -0400
|
||||
|
||||
</em></p>
|
||||
|
||||
<br>
|
||||
|
||||
<p>Computer vision on an FRC robot has some problems.</p>
|
||||
<ul>
|
||||
<li>RoboRIO is not powerfull enough</li>
|
||||
<li>NetworkTables is not fast enough</li>
|
||||
<li>A TCP connection is great until you lose connection</li>
|
||||
<li>mDNS discovery is not reliable on the field</li>
|
||||
<li>UDP can skip frames</li>
|
||||
</ul>
|
||||
|
||||
<h2 id="needs">Needs</h2>
|
||||
<p>These are the things I need to have.</p>
|
||||
<ul>
|
||||
<li>Send data from any device</li>
|
||||
<li>Recive data on RoboRIO at any time</li>
|
||||
<li>Data rate faster than period time</li>
|
||||
</ul>
|
||||
|
||||
<h2 id="wants">Wants</h2>
|
||||
<p>These are the things I would like to have.</p>
|
||||
<ul>
|
||||
<li>Easy discovery</li>
|
||||
<li>Threaded</li>
|
||||
<li>Simple interface for new programmers</li>
|
||||
<li>Fallback in case of UDP issues</li>
|
||||
<li>FMS network firewall compliant</li>
|
||||
</ul>
|
||||
|
||||
<p>I am currently working on a protocol for solving this problem, nad will post an update here once it has been tested. Feel free to let me know your thoughts and ideas.</p>
|
||||
|
||||
</div>
|
||||
</div>
|
||||
|
||||
</div>
|
||||
<!-- <div id="particles-js"></div> -->
|
||||
|
||||
<div class="container foot" style="text-align:center;">
|
||||
<br>
|
||||
<span class="site-info">
|
||||
Site design by: <a href="https://retrylife.ca">Evan Pratten</a> |
|
||||
|
||||
This site was last updated at: 2019-11-30 11:37:59 -0500
|
||||
</span>
|
||||
</div>
|
||||
|
||||
<!-- Brython -->
|
||||
<script src="/assets/js/brython.js"></script>
|
||||
<script src="/assets/js/brython_stdlib.js"></script>
|
||||
|
||||
<script>
|
||||
function startPY(){
|
||||
|
||||
brython();
|
||||
console.log("Started Python")
|
||||
}
|
||||
|
||||
window.onload = startPY;
|
||||
</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://stackpath.bootstrapcdn.com/bootstrap/4.3.1/js/bootstrap.min.js"
|
||||
integrity="sha384-JjSmVgyd0p3pXB1rRibZUAYoIIy6OrQ6VrjIEaFf/nJGzIxFDsf4x0xIM+B07jRM"
|
||||
crossorigin="anonymous"></script>
|
||||
|
||||
<!-- Offsets for links -->
|
||||
<script>
|
||||
(function ($, window) {
|
||||
var adjustAnchor = function () {
|
||||
|
||||
var $anchor = $(':target'),
|
||||
fixedElementHeight = 100;
|
||||
|
||||
if ($anchor.length > 0) {
|
||||
|
||||
window.scrollTo(0, $anchor.offset().top - fixedElementHeight);
|
||||
}
|
||||
|
||||
};
|
||||
|
||||
$(window).on('hashchange load', function () {
|
||||
adjustAnchor();
|
||||
});
|
||||
|
||||
})(jQuery, window);
|
||||
</script>
|
||||
|
||||
<!-- Global site tag (gtag.js) - Google Analytics -->
|
||||
<script async src="https://www.googletagmanager.com/gtag/js?id=UA-74118570-2"></script>
|
||||
<script>
|
||||
window.dataLayer = window.dataLayer || [];
|
||||
function gtag() { dataLayer.push(arguments); }
|
||||
gtag('js', new Date());
|
||||
|
||||
gtag('config', 'UA-74118570-2');
|
||||
</script>
|
||||
|
||||
|
||||
<!-- particles -->
|
||||
<script>
|
||||
var body = document.body
|
||||
|
||||
var particles = document.getElementById("particles-js")
|
||||
|
||||
particles.style.height = body.scrollHeight + "px"
|
||||
|
||||
console.log(body.scrollHeight)
|
||||
</script>
|
||||
<script src="/assets/js/particles.min.js"></script>
|
||||
<script>
|
||||
particlesJS.load('particles-js', '/assets/js/particles.json', function () {
|
||||
console.log('callback - particles.js config loaded');
|
||||
});
|
||||
</script>
|
||||
|
||||
<!-- Twitter embeds -->
|
||||
<script async src="https://platform.twitter.com/widgets.js" charset="utf-8"></script>
|
||||
|
||||
|
||||
</body>
|
@ -1,214 +0,0 @@
|
||||
<head>
|
||||
<title>Evan Pratten</title>
|
||||
<meta charset="utf-8" />
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=no" />
|
||||
|
||||
<!-- Begin Jekyll SEO tag v2.6.1 -->
|
||||
<title>GitHub’s CSS is boring. So I refreshed the design | Evan Pratten</title>
|
||||
<meta name="generator" content="Jekyll v4.0.0" />
|
||||
<meta property="og:title" content="GitHub’s CSS is boring. So I refreshed the design" />
|
||||
<meta property="og:locale" content="en_US" />
|
||||
<meta name="description" content="I have been using GitHub since 2017, and have been getting tired of GitHub’s theme. I didn’t need a huge change, just a small refresh. So, to solve this, I whipped out Stylus and made a nice little CSS file for it." />
|
||||
<meta property="og:description" content="I have been using GitHub since 2017, and have been getting tired of GitHub’s theme. I didn’t need a huge change, just a small refresh. So, to solve this, I whipped out Stylus and made a nice little CSS file for it." />
|
||||
<link rel="canonical" href="http://0.0.0.0:4000/blog/2019/06/12/styiling-github" />
|
||||
<meta property="og:url" content="http://0.0.0.0:4000/blog/2019/06/12/styiling-github" />
|
||||
<meta property="og:site_name" content="Evan Pratten" />
|
||||
<meta property="og:type" content="article" />
|
||||
<meta property="article:published_time" content="2019-06-12T09:09:00-04:00" />
|
||||
<script type="application/ld+json">
|
||||
{"datePublished":"2019-06-12T09:09:00-04:00","mainEntityOfPage":{"@type":"WebPage","@id":"http://0.0.0.0:4000/blog/2019/06/12/styiling-github"},"@type":"BlogPosting","url":"http://0.0.0.0:4000/blog/2019/06/12/styiling-github","headline":"GitHub’s CSS is boring. So I refreshed the design","description":"I have been using GitHub since 2017, and have been getting tired of GitHub’s theme. I didn’t need a huge change, just a small refresh. So, to solve this, I whipped out Stylus and made a nice little CSS file for it.","dateModified":"2019-06-12T09:09:00-04:00","@context":"https://schema.org"}</script>
|
||||
<!-- End Jekyll SEO tag -->
|
||||
|
||||
|
||||
|
||||
<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="/assets/css/main.css">
|
||||
<link rel="stylesheet" href="/assets/css/github-syntax.css">
|
||||
<link href="https://fonts.googleapis.com/css?family=IBM+Plex+Mono:400,400i|IBM+Plex+Sans:100,100i,400,400i,700,700i" rel="stylesheet">
|
||||
<link href="https://stackpath.bootstrapcdn.com/font-awesome/4.7.0/css/font-awesome.min.css" rel="stylesheet" integrity="sha384-wvfXpqpZZVQGK6TAh5PVlGOfQNHSoD2xbE+QkPxCAFlNEevoEH3Sl0sibVcOQVnN" crossorigin="anonymous">
|
||||
</head>
|
||||
|
||||
<body>
|
||||
|
||||
<div class="site-ctr">
|
||||
<!-- Navbar -->
|
||||
<nav class="navbar navbar-dark sticky-top bg-dark navbar-expand-lg">
|
||||
<!-- Navbar content -->
|
||||
<!-- <div class="container"> -->
|
||||
<a class="navbar-brand" href="/">Evan Pratten</a>
|
||||
<button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbarNavAltMarkup"
|
||||
aria-controls="navbarNavAltMarkup" aria-expanded="false" aria-label="Toggle navigation">
|
||||
<span class="navbar-toggler-icon"></span>
|
||||
</button>
|
||||
<div class="collapse navbar-collapse" id="navbarNavAltMarkup">
|
||||
<div class="navbar-nav ml-auto">
|
||||
<a class="nav-item nav-link" href="/blog">Blog</a>
|
||||
<a class="nav-item nav-link" href="/projects">Projects</a>
|
||||
<!-- <a class="nav-item nav-link" href="/documentation">Documentation</a> -->
|
||||
<a class="nav-item nav-link" href="/about">About</a>
|
||||
</div>
|
||||
<!-- </div> -->
|
||||
</div>
|
||||
</nav>
|
||||
<!-- <div style="height:5vh"></div> -->
|
||||
|
||||
<!-- Header -->
|
||||
<!-- <div class="header">
|
||||
<div class="container">
|
||||
<div class="content">
|
||||
</div>
|
||||
</div>
|
||||
<div class="header-gap"></div>
|
||||
</div> -->
|
||||
|
||||
<div class="reactive-bg">
|
||||
<div class="post container">
|
||||
<h1>GitHub's CSS is boring. So I refreshed the design
|
||||
|
||||
</h1>
|
||||
<h4>
|
||||
|
||||
</h4>
|
||||
<hr>
|
||||
<p><em>2019-06-12 09:09:00 -0400
|
||||
|
||||
</em></p>
|
||||
|
||||
<br>
|
||||
|
||||
<p>I have been using GitHub since 2017, and have been getting tired of GitHub’s theme. I didn’t need a huge change, just a small refresh. So, to solve this, I whipped out <a href="https://addons.mozilla.org/en-CA/firefox/addon/styl-us/">Stylus</a> and made a nice little CSS file for it.</p>
|
||||
|
||||
<h2 id="the-css">The CSS</h2>
|
||||
<p>Here is the CSS. Feel free to play with it.</p>
|
||||
|
||||
<div class="language-css highlighter-rouge"><div class="highlight"><pre class="highlight"><code><span class="k">@-moz-document</span> <span class="n">url-prefix</span><span class="p">(</span><span class="s1">"https://github.com/"</span><span class="p">)</span> <span class="p">{</span>
|
||||
<span class="nc">.Header</span> <span class="p">{</span>
|
||||
<span class="nl">background-color</span><span class="p">:</span> <span class="m">#1a3652</span><span class="p">;</span>
|
||||
<span class="p">}</span>
|
||||
|
||||
<span class="nc">.repohead.experiment-repo-nav</span> <span class="p">{</span>
|
||||
<span class="nl">background-color</span><span class="p">:</span> <span class="m">#fff</span><span class="p">;</span>
|
||||
<span class="p">}</span>
|
||||
<span class="nc">.reponav-item.selected</span> <span class="p">{</span>
|
||||
<span class="nl">border-color</span><span class="p">:</span> <span class="m">#fff</span> <span class="m">#fff</span> <span class="m">#4a79a8</span><span class="p">;</span>
|
||||
<span class="p">}</span>
|
||||
|
||||
<span class="nc">.btn.hover</span><span class="o">,</span>
|
||||
<span class="nc">.btn</span><span class="nd">:hover</span><span class="o">,</span>
|
||||
<span class="nc">.btn</span><span class="o">,</span>
|
||||
<span class="nc">.btn</span> <span class="p">{</span>
|
||||
<span class="nl">background-color</span><span class="p">:</span> <span class="m">#fafafa</span><span class="p">;</span>
|
||||
<span class="nl">background-image</span><span class="p">:</span> <span class="n">linear-gradient</span><span class="p">(</span><span class="m">-180deg</span><span class="p">,</span> <span class="m">#fafafa</span><span class="p">,</span> <span class="m">#fafafa</span> <span class="m">90%</span><span class="p">);</span>
|
||||
<span class="p">}</span>
|
||||
|
||||
<span class="nc">.btn-primary.hover</span><span class="o">,</span>
|
||||
<span class="nc">.btn-primary</span><span class="nd">:hover</span><span class="o">,</span>
|
||||
<span class="nc">.btn-primary</span><span class="o">,</span>
|
||||
<span class="nc">.btn-primary</span> <span class="p">{</span>
|
||||
<span class="nl">background-color</span><span class="p">:</span> <span class="m">#1aaa55</span><span class="p">;</span>
|
||||
<span class="nl">background-image</span><span class="p">:</span> <span class="n">linear-gradient</span><span class="p">(</span><span class="m">-180deg</span><span class="p">,</span> <span class="m">#1aaa55</span><span class="p">,</span> <span class="m">#1aaa55</span> <span class="m">90%</span><span class="p">);</span>
|
||||
<span class="p">}</span>
|
||||
|
||||
<span class="nc">.overall-summary</span> <span class="p">{}</span>
|
||||
<span class="p">}</span>
|
||||
</code></pre></div></div>
|
||||
|
||||
<h2 id="use-it-yourself">Use it yourself</h2>
|
||||
<p>I put this theme on userstyles.org. You can download and install it by going to <a href="https://userstyles.org/styles/172679/ewpratten-s-githubtheme">my userstyles page</a>.</p>
|
||||
|
||||
</div>
|
||||
</div>
|
||||
|
||||
</div>
|
||||
<!-- <div id="particles-js"></div> -->
|
||||
|
||||
<div class="container foot" style="text-align:center;">
|
||||
<br>
|
||||
<span class="site-info">
|
||||
Site design by: <a href="https://retrylife.ca">Evan Pratten</a> |
|
||||
|
||||
This site was last updated at: 2019-11-30 11:37:59 -0500
|
||||
</span>
|
||||
</div>
|
||||
|
||||
<!-- Brython -->
|
||||
<script src="/assets/js/brython.js"></script>
|
||||
<script src="/assets/js/brython_stdlib.js"></script>
|
||||
|
||||
<script>
|
||||
function startPY(){
|
||||
|
||||
brython();
|
||||
console.log("Started Python")
|
||||
}
|
||||
|
||||
window.onload = startPY;
|
||||
</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://stackpath.bootstrapcdn.com/bootstrap/4.3.1/js/bootstrap.min.js"
|
||||
integrity="sha384-JjSmVgyd0p3pXB1rRibZUAYoIIy6OrQ6VrjIEaFf/nJGzIxFDsf4x0xIM+B07jRM"
|
||||
crossorigin="anonymous"></script>
|
||||
|
||||
<!-- Offsets for links -->
|
||||
<script>
|
||||
(function ($, window) {
|
||||
var adjustAnchor = function () {
|
||||
|
||||
var $anchor = $(':target'),
|
||||
fixedElementHeight = 100;
|
||||
|
||||
if ($anchor.length > 0) {
|
||||
|
||||
window.scrollTo(0, $anchor.offset().top - fixedElementHeight);
|
||||
}
|
||||
|
||||
};
|
||||
|
||||
$(window).on('hashchange load', function () {
|
||||
adjustAnchor();
|
||||
});
|
||||
|
||||
})(jQuery, window);
|
||||
</script>
|
||||
|
||||
<!-- Global site tag (gtag.js) - Google Analytics -->
|
||||
<script async src="https://www.googletagmanager.com/gtag/js?id=UA-74118570-2"></script>
|
||||
<script>
|
||||
window.dataLayer = window.dataLayer || [];
|
||||
function gtag() { dataLayer.push(arguments); }
|
||||
gtag('js', new Date());
|
||||
|
||||
gtag('config', 'UA-74118570-2');
|
||||
</script>
|
||||
|
||||
|
||||
<!-- particles -->
|
||||
<script>
|
||||
var body = document.body
|
||||
|
||||
var particles = document.getElementById("particles-js")
|
||||
|
||||
particles.style.height = body.scrollHeight + "px"
|
||||
|
||||
console.log(body.scrollHeight)
|
||||
</script>
|
||||
<script src="/assets/js/particles.min.js"></script>
|
||||
<script>
|
||||
particlesJS.load('particles-js', '/assets/js/particles.json', function () {
|
||||
console.log('callback - particles.js config loaded');
|
||||
});
|
||||
</script>
|
||||
|
||||
<!-- Twitter embeds -->
|
||||
<script async src="https://platform.twitter.com/widgets.js" charset="utf-8"></script>
|
||||
|
||||
|
||||
</body>
|
@ -1,228 +0,0 @@
|
||||
<head>
|
||||
<title>Evan Pratten</title>
|
||||
<meta charset="utf-8" />
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=no" />
|
||||
|
||||
<!-- Begin Jekyll SEO tag v2.6.1 -->
|
||||
<title>Graphing the relation between wheels and awards for FRC | Evan Pratten</title>
|
||||
<meta name="generator" content="Jekyll v4.0.0" />
|
||||
<meta property="og:title" content="Graphing the relation between wheels and awards for FRC" />
|
||||
<meta property="og:locale" content="en_US" />
|
||||
<meta name="description" content="AKA. Why programmer + reddit + matplotlib is a bad idea." />
|
||||
<meta property="og:description" content="AKA. Why programmer + reddit + matplotlib is a bad idea." />
|
||||
<link rel="canonical" href="http://0.0.0.0:4000/blog/2019/06/16/graphing-w2a" />
|
||||
<meta property="og:url" content="http://0.0.0.0:4000/blog/2019/06/16/graphing-w2a" />
|
||||
<meta property="og:site_name" content="Evan Pratten" />
|
||||
<meta property="og:type" content="article" />
|
||||
<meta property="article:published_time" content="2019-06-16T11:51:00-04:00" />
|
||||
<script type="application/ld+json">
|
||||
{"datePublished":"2019-06-16T11:51:00-04:00","mainEntityOfPage":{"@type":"WebPage","@id":"http://0.0.0.0:4000/blog/2019/06/16/graphing-w2a"},"@type":"BlogPosting","url":"http://0.0.0.0:4000/blog/2019/06/16/graphing-w2a","headline":"Graphing the relation between wheels and awards for FRC","description":"AKA. Why programmer + reddit + matplotlib is a bad idea.","dateModified":"2019-06-16T11:51:00-04:00","@context":"https://schema.org"}</script>
|
||||
<!-- End Jekyll SEO tag -->
|
||||
|
||||
|
||||
|
||||
<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="/assets/css/main.css">
|
||||
<link rel="stylesheet" href="/assets/css/github-syntax.css">
|
||||
<link href="https://fonts.googleapis.com/css?family=IBM+Plex+Mono:400,400i|IBM+Plex+Sans:100,100i,400,400i,700,700i" rel="stylesheet">
|
||||
<link href="https://stackpath.bootstrapcdn.com/font-awesome/4.7.0/css/font-awesome.min.css" rel="stylesheet" integrity="sha384-wvfXpqpZZVQGK6TAh5PVlGOfQNHSoD2xbE+QkPxCAFlNEevoEH3Sl0sibVcOQVnN" crossorigin="anonymous">
|
||||
</head>
|
||||
|
||||
<body>
|
||||
|
||||
<div class="site-ctr">
|
||||
<!-- Navbar -->
|
||||
<nav class="navbar navbar-dark sticky-top bg-dark navbar-expand-lg">
|
||||
<!-- Navbar content -->
|
||||
<!-- <div class="container"> -->
|
||||
<a class="navbar-brand" href="/">Evan Pratten</a>
|
||||
<button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbarNavAltMarkup"
|
||||
aria-controls="navbarNavAltMarkup" aria-expanded="false" aria-label="Toggle navigation">
|
||||
<span class="navbar-toggler-icon"></span>
|
||||
</button>
|
||||
<div class="collapse navbar-collapse" id="navbarNavAltMarkup">
|
||||
<div class="navbar-nav ml-auto">
|
||||
<a class="nav-item nav-link" href="/blog">Blog</a>
|
||||
<a class="nav-item nav-link" href="/projects">Projects</a>
|
||||
<!-- <a class="nav-item nav-link" href="/documentation">Documentation</a> -->
|
||||
<a class="nav-item nav-link" href="/about">About</a>
|
||||
</div>
|
||||
<!-- </div> -->
|
||||
</div>
|
||||
</nav>
|
||||
<!-- <div style="height:5vh"></div> -->
|
||||
|
||||
<!-- Header -->
|
||||
<!-- <div class="header">
|
||||
<div class="container">
|
||||
<div class="content">
|
||||
</div>
|
||||
</div>
|
||||
<div class="header-gap"></div>
|
||||
</div> -->
|
||||
|
||||
<div class="reactive-bg">
|
||||
<div class="post container">
|
||||
<h1>Graphing the relation between wheels and awards for FRC
|
||||
|
||||
</h1>
|
||||
<h4>AKA. Why programmer + reddit + matplotlib is a bad idea.
|
||||
|
||||
</h4>
|
||||
<hr>
|
||||
<p><em>2019-06-16 11:51:00 -0400
|
||||
|
||||
</em></p>
|
||||
|
||||
<br>
|
||||
|
||||
<p>I was scrolling through reddit the other day, and came across <a href="https://www.reddit.com/r/FRC/comments/byzv5q/i_know_what_im_doing/">this great post</a> by u/<a href="https://www.reddit.com/user/MasterQuacks/">MasterQuacks</a>.</p>
|
||||
|
||||
<p><img src="/assets/images/w2ainspo.jpg" alt="My insporation" /></p>
|
||||
|
||||
<p>I thought to myself “ha. Thats funny”, and moved on. But that thought had stuck with me.</p>
|
||||
|
||||
<p>So here I am, bored on a sunday afternoon, staring at the matplotlib documentation.</p>
|
||||
|
||||
<h2 id="my-creation">My creation</h2>
|
||||
<p>In only a few lines of python, I have a program that will (badly) graph the number of awards per wheel for any team, or set of teams.</p>
|
||||
|
||||
<p>As always, feel free to tinker with the code. This one is not published anywhere, so if you want to share it, I would appreciate a mention.</p>
|
||||
|
||||
<div class="language-python highlighter-rouge"><div class="highlight"><pre class="highlight"><code><span class="kn">import</span> <span class="nn">requests</span>
|
||||
<span class="kn">import</span> <span class="nn">matplotlib.pyplot</span> <span class="k">as</span> <span class="n">plt</span>
|
||||
|
||||
<span class="k">class</span> <span class="nc">Team</span><span class="p">:</span>
|
||||
<span class="k">def</span> <span class="nf">__init__</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="nb">id</span><span class="p">,</span> <span class="n">wheels</span><span class="p">):</span>
|
||||
<span class="bp">self</span><span class="o">.</span><span class="nb">id</span> <span class="o">=</span> <span class="nb">id</span>
|
||||
<span class="bp">self</span><span class="o">.</span><span class="n">wheels</span> <span class="o">=</span> <span class="n">wheels</span> <span class="o">*</span> <span class="mi">2</span>
|
||||
|
||||
<span class="c1">### CONFIG ###
|
||||
</span>
|
||||
<span class="n">teams</span> <span class="o">=</span> <span class="p">[</span><span class="n">Team</span><span class="p">(</span><span class="mi">5024</span><span class="p">,</span> <span class="mi">3</span><span class="p">),</span> <span class="n">Team</span><span class="p">(</span><span class="mi">254</span><span class="p">,</span> <span class="mi">4</span><span class="p">),</span> <span class="n">Team</span><span class="p">(</span><span class="mi">1114</span><span class="p">,</span> <span class="mi">3</span><span class="p">),</span> <span class="n">Team</span><span class="p">(</span><span class="mi">5406</span><span class="p">,</span> <span class="mi">3</span><span class="p">),</span> <span class="n">Team</span><span class="p">(</span><span class="mi">2056</span><span class="p">,</span> <span class="mi">4</span><span class="p">)]</span>
|
||||
<span class="n">year</span> <span class="o">=</span> <span class="mi">2019</span>
|
||||
|
||||
<span class="c1">##############
|
||||
</span>
|
||||
|
||||
<span class="k">for</span> <span class="n">i</span><span class="p">,</span> <span class="n">team</span> <span class="ow">in</span> <span class="nb">enumerate</span><span class="p">(</span><span class="n">teams</span><span class="p">):</span>
|
||||
<span class="n">award_data</span> <span class="o">=</span> <span class="n">requests</span><span class="o">.</span><span class="n">get</span><span class="p">(</span><span class="s">"https://www.thebluealliance.com/api/v3/team/frc"</span> <span class="o">+</span> <span class="nb">str</span><span class="p">(</span><span class="n">team</span><span class="o">.</span><span class="nb">id</span><span class="p">)</span> <span class="o">+</span> <span class="s">"/awards/"</span> <span class="o">+</span> <span class="nb">str</span><span class="p">(</span><span class="n">year</span><span class="p">),</span> <span class="n">params</span><span class="o">=</span><span class="p">{</span><span class="s">"X-TBA-Auth-Key"</span><span class="p">:</span> <span class="s">"mz0VWTNtXTDV8NNOz3dYg9fHOZw8UYek270gynLQ4v9veaaUJEPvJFCZRmte7AUN"</span><span class="p">})</span><span class="o">.</span><span class="n">json</span><span class="p">()</span>
|
||||
|
||||
<span class="n">awards_count</span> <span class="o">=</span> <span class="nb">len</span><span class="p">(</span><span class="n">award_data</span><span class="p">)</span>
|
||||
|
||||
<span class="n">team</span><span class="o">.</span><span class="n">w2a</span> <span class="o">=</span> <span class="n">awards_count</span> <span class="o">/</span> <span class="n">team</span><span class="o">.</span><span class="n">wheels</span>
|
||||
<span class="k">print</span><span class="p">(</span><span class="n">team</span><span class="o">.</span><span class="nb">id</span><span class="p">,</span> <span class="n">team</span><span class="o">.</span><span class="n">w2a</span><span class="p">)</span>
|
||||
|
||||
<span class="n">plt</span><span class="o">.</span><span class="n">bar</span><span class="p">(</span><span class="n">i</span> <span class="o">+</span> <span class="mi">1</span><span class="p">,</span> <span class="n">team</span><span class="o">.</span><span class="n">w2a</span><span class="p">,</span> <span class="n">tick_label</span><span class="o">=</span><span class="nb">str</span><span class="p">(</span><span class="n">team</span><span class="o">.</span><span class="nb">id</span><span class="p">))</span>
|
||||
|
||||
<span class="c1"># Plot
|
||||
</span><span class="n">x_lables</span> <span class="o">=</span> <span class="p">[</span><span class="n">team</span><span class="o">.</span><span class="nb">id</span> <span class="k">for</span> <span class="n">team</span> <span class="ow">in</span> <span class="n">teams</span><span class="p">]</span>
|
||||
<span class="c1"># plt.set_xticklabels(x_lables)
|
||||
</span>
|
||||
<span class="k">with</span> <span class="n">plt</span><span class="o">.</span><span class="n">xkcd</span><span class="p">():</span>
|
||||
<span class="n">plt</span><span class="o">.</span><span class="n">title</span><span class="p">(</span><span class="s">'Awards per wheel'</span><span class="p">)</span>
|
||||
<span class="n">plt</span><span class="o">.</span><span class="n">show</span><span class="p">()</span>
|
||||
|
||||
</code></pre></div></div>
|
||||
|
||||
<h2 id="the-result">The result</h2>
|
||||
<p>Here is the resulting image. From left, to right: 5024, 254, 1114, 5406, 2056</p>
|
||||
|
||||
<p><img src="/assets/images/w2a.png" alt="Thr result" /></p>
|
||||
|
||||
</div>
|
||||
</div>
|
||||
|
||||
</div>
|
||||
<!-- <div id="particles-js"></div> -->
|
||||
|
||||
<div class="container foot" style="text-align:center;">
|
||||
<br>
|
||||
<span class="site-info">
|
||||
Site design by: <a href="https://retrylife.ca">Evan Pratten</a> |
|
||||
|
||||
This site was last updated at: 2019-11-30 11:37:59 -0500
|
||||
</span>
|
||||
</div>
|
||||
|
||||
<!-- Brython -->
|
||||
<script src="/assets/js/brython.js"></script>
|
||||
<script src="/assets/js/brython_stdlib.js"></script>
|
||||
|
||||
<script>
|
||||
function startPY(){
|
||||
|
||||
brython();
|
||||
console.log("Started Python")
|
||||
}
|
||||
|
||||
window.onload = startPY;
|
||||
</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://stackpath.bootstrapcdn.com/bootstrap/4.3.1/js/bootstrap.min.js"
|
||||
integrity="sha384-JjSmVgyd0p3pXB1rRibZUAYoIIy6OrQ6VrjIEaFf/nJGzIxFDsf4x0xIM+B07jRM"
|
||||
crossorigin="anonymous"></script>
|
||||
|
||||
<!-- Offsets for links -->
|
||||
<script>
|
||||
(function ($, window) {
|
||||
var adjustAnchor = function () {
|
||||
|
||||
var $anchor = $(':target'),
|
||||
fixedElementHeight = 100;
|
||||
|
||||
if ($anchor.length > 0) {
|
||||
|
||||
window.scrollTo(0, $anchor.offset().top - fixedElementHeight);
|
||||
}
|
||||
|
||||
};
|
||||
|
||||
$(window).on('hashchange load', function () {
|
||||
adjustAnchor();
|
||||
});
|
||||
|
||||
})(jQuery, window);
|
||||
</script>
|
||||
|
||||
<!-- Global site tag (gtag.js) - Google Analytics -->
|
||||
<script async src="https://www.googletagmanager.com/gtag/js?id=UA-74118570-2"></script>
|
||||
<script>
|
||||
window.dataLayer = window.dataLayer || [];
|
||||
function gtag() { dataLayer.push(arguments); }
|
||||
gtag('js', new Date());
|
||||
|
||||
gtag('config', 'UA-74118570-2');
|
||||
</script>
|
||||
|
||||
|
||||
<!-- particles -->
|
||||
<script>
|
||||
var body = document.body
|
||||
|
||||
var particles = document.getElementById("particles-js")
|
||||
|
||||
particles.style.height = body.scrollHeight + "px"
|
||||
|
||||
console.log(body.scrollHeight)
|
||||
</script>
|
||||
<script src="/assets/js/particles.min.js"></script>
|
||||
<script>
|
||||
particlesJS.load('particles-js', '/assets/js/particles.json', function () {
|
||||
console.log('callback - particles.js config loaded');
|
||||
});
|
||||
</script>
|
||||
|
||||
<!-- Twitter embeds -->
|
||||
<script async src="https://platform.twitter.com/widgets.js" charset="utf-8"></script>
|
||||
|
||||
|
||||
</body>
|