AdventOfCode /list view kinda finished
This commit is contained in:
parent
e00edb7425
commit
65f75c26ef
@ -1125,6 +1125,102 @@ html, body {
|
||||
flex-direction: row;
|
||||
}
|
||||
}
|
||||
/* 400px */
|
||||
.aoc_calendar_parent {
|
||||
display: flex;
|
||||
justify-content: center;
|
||||
margin-top: 1em;
|
||||
padding-bottom: 1.5em;
|
||||
}
|
||||
|
||||
.aoc_calendar_header {
|
||||
display: flex;
|
||||
flex-direction: row;
|
||||
justify-content: space-between;
|
||||
margin-bottom: 0.5em;
|
||||
background: #F8B229;
|
||||
}
|
||||
|
||||
.aoc_calendar_header_link {
|
||||
display: flex;
|
||||
color: #000000;
|
||||
text-decoration: none;
|
||||
}
|
||||
|
||||
.aoc_calendar_header_title {
|
||||
flex-grow: 0;
|
||||
display: flex;
|
||||
color: #000000;
|
||||
font-family: Lato, "Helvetica Neue", Helvetica, Arial, sans-serif;
|
||||
font-weight: bold;
|
||||
}
|
||||
|
||||
.aoc_calendar_header_link.aoc_prev {
|
||||
flex-grow: 0;
|
||||
padding-left: 0.5em;
|
||||
}
|
||||
|
||||
.aoc_calendar_header_link.aoc_next {
|
||||
flex-grow: 0;
|
||||
padding-right: 0.5em;
|
||||
}
|
||||
|
||||
.aoc_calendar_header_link.aoc_link_hidden {
|
||||
visibility: hidden;
|
||||
}
|
||||
|
||||
.aoc_calendar {
|
||||
display: flex;
|
||||
flex-direction: column;
|
||||
background: #EFEFEF;
|
||||
font-size: xx-large;
|
||||
font-family: Consolas, Monaco, "Courier New", Menlo, monospace;
|
||||
border: 1px solid #000000;
|
||||
padding-bottom: 0.5em;
|
||||
}
|
||||
|
||||
.aoc_calendar_row {
|
||||
display: flex;
|
||||
flex-direction: row;
|
||||
justify-content: center;
|
||||
margin-left: 0.5em;
|
||||
margin-right: 0.5em;
|
||||
}
|
||||
|
||||
.aoc_calendar_field {
|
||||
display: flex;
|
||||
align-items: center;
|
||||
justify-content: center;
|
||||
width: 2em;
|
||||
height: 2em;
|
||||
margin: 4px;
|
||||
text-decoration: none;
|
||||
font-weight: bold;
|
||||
}
|
||||
|
||||
.aoc_calendar_field.aoc_enabled {
|
||||
background: #165B33;
|
||||
color: #BB2528;
|
||||
border: 1px solid #FFFFFF;
|
||||
text-shadow: 0 0 0.2em #222;
|
||||
font-weight: bold;
|
||||
}
|
||||
|
||||
.aoc_calendar_field.aoc_enabled:hover {
|
||||
background: #165B00;
|
||||
color: #BB2528;
|
||||
border: 1px solid #BB2528;
|
||||
text-shadow: 0 0 0 #000;
|
||||
}
|
||||
|
||||
.aoc_calendar_field.aoc_disabled {
|
||||
background: #444;
|
||||
color: #888;
|
||||
border: 1px solid #888;
|
||||
cursor: default;
|
||||
font-weight: normal;
|
||||
}
|
||||
|
||||
/* 400px */
|
||||
.prgl_parent {
|
||||
display: flex;
|
||||
|
13
www/data/css/styles.min.css
vendored
13
www/data/css/styles.min.css
vendored
@ -219,6 +219,19 @@ html,body{margin:0;padding:0;height:100%}
|
||||
.bce_pag10{flex-direction:row}
|
||||
.bce_pag05{flex-direction:row}
|
||||
}
|
||||
.aoc_calendar_parent{display:flex;justify-content:center;margin-top:1em;padding-bottom:1.5em}
|
||||
.aoc_calendar_header{display:flex;flex-direction:row;justify-content:space-between;margin-bottom:.5em;background:#f8b229}
|
||||
.aoc_calendar_header_link{display:flex;color:#000;text-decoration:none}
|
||||
.aoc_calendar_header_title{flex-grow:0;display:flex;color:#000;font-family:Lato,"Helvetica Neue",Helvetica,Arial,sans-serif;font-weight:bold}
|
||||
.aoc_calendar_header_link.aoc_prev{flex-grow:0;padding-left:.5em}
|
||||
.aoc_calendar_header_link.aoc_next{flex-grow:0;padding-right:.5em}
|
||||
.aoc_calendar_header_link.aoc_link_hidden{visibility:hidden}
|
||||
.aoc_calendar{display:flex;flex-direction:column;background:#efefef;font-size:xx-large;font-family:Consolas,Monaco,"Courier New",Menlo,monospace;border:1px solid #000;padding-bottom:.5em}
|
||||
.aoc_calendar_row{display:flex;flex-direction:row;justify-content:center;margin-left:.5em;margin-right:.5em}
|
||||
.aoc_calendar_field{display:flex;align-items:center;justify-content:center;width:2em;height:2em;margin:4px;text-decoration:none;font-weight:bold}
|
||||
.aoc_calendar_field.aoc_enabled{background:#165b33;color:#bb2528;border:1px solid #fff;text-shadow:0 0 .2em #222;font-weight:bold}
|
||||
.aoc_calendar_field.aoc_enabled:hover{background:#165b00;color:#bb2528;border:1px solid #bb2528;text-shadow:0 0 0 #000}
|
||||
.aoc_calendar_field.aoc_disabled{background:#444;color:#888;border:1px solid #888;cursor:default;font-weight:normal}
|
||||
.prgl_parent{display:flex;flex-direction:column}
|
||||
@media(max-width:850px){.prgl_parent{align-items:center}}
|
||||
.prgl_elem{display:flex;flex-direction:row;text-decoration:none;background:#BBB;border:solid 1px #444;margin:5px 0}
|
||||
|
@ -10,6 +10,7 @@
|
||||
@import 'styles_bloglist';
|
||||
@import 'styles_blogview';
|
||||
@import 'styles_blogview_euler';
|
||||
@import 'styles_blogview_aoc';
|
||||
|
||||
@import 'styles_programslist';
|
||||
@import 'styles_programsview';
|
||||
|
120
www/data/css/styles_blogview_aoc.scss
Normal file
120
www/data/css/styles_blogview_aoc.scss
Normal file
@ -0,0 +1,120 @@
|
||||
@import 'styles_config';
|
||||
|
||||
$COL_CHRISTMAS_YELLOW: #F8B229;
|
||||
$COL_CHRISTMAS_WHITE: #EFEFEF;
|
||||
$COL_CHRISTMAS_GREEN: #165B33;
|
||||
$COL_CHRISTMAS_GREEN_ALT: #165B00;
|
||||
$COL_CHRISTMAS_RED: #BB2528;
|
||||
|
||||
// ==================== AdventOfCode Blog Listing ==================== //
|
||||
|
||||
.aoc_calendar_parent {
|
||||
display: flex;
|
||||
justify-content: center;
|
||||
|
||||
margin-top: 1em;
|
||||
padding-bottom: 1.5em;
|
||||
}
|
||||
|
||||
.aoc_calendar_header {
|
||||
display: flex;
|
||||
flex-direction: row;
|
||||
justify-content: space-between;
|
||||
|
||||
margin-bottom: 0.5em;
|
||||
|
||||
background: $COL_CHRISTMAS_YELLOW;
|
||||
}
|
||||
|
||||
.aoc_calendar_header_link {
|
||||
display: flex;
|
||||
|
||||
color: #000000;
|
||||
text-decoration: none;
|
||||
}
|
||||
|
||||
.aoc_calendar_header_title {
|
||||
flex-grow: 0;
|
||||
display: flex;
|
||||
|
||||
color: #000000;
|
||||
font-family: $FONT_HEADER;
|
||||
font-weight: bold;
|
||||
}
|
||||
|
||||
.aoc_calendar_header_link.aoc_prev {
|
||||
flex-grow: 0;
|
||||
padding-left: 0.5em;
|
||||
}
|
||||
|
||||
.aoc_calendar_header_link.aoc_next {
|
||||
flex-grow: 0;
|
||||
padding-right: 0.5em;
|
||||
}
|
||||
|
||||
.aoc_calendar_header_link.aoc_link_hidden {
|
||||
visibility: hidden;
|
||||
}
|
||||
|
||||
.aoc_calendar {
|
||||
display: flex;
|
||||
flex-direction: column;
|
||||
|
||||
background: $COL_CHRISTMAS_WHITE;
|
||||
|
||||
font-size: xx-large;
|
||||
font-family: $FONT_CODE;
|
||||
|
||||
border: 1px solid #000000;
|
||||
|
||||
padding-bottom: 0.5em;
|
||||
}
|
||||
|
||||
.aoc_calendar_row {
|
||||
display: flex;
|
||||
flex-direction: row;
|
||||
|
||||
justify-content: center;
|
||||
|
||||
margin-left: 0.5em;
|
||||
margin-right: 0.5em;
|
||||
}
|
||||
|
||||
.aoc_calendar_field {
|
||||
display: flex;
|
||||
align-items: center;
|
||||
justify-content: center;
|
||||
|
||||
width: 2em;
|
||||
height: 2em;
|
||||
|
||||
margin: 4px;
|
||||
|
||||
text-decoration: none;
|
||||
font-weight: bold;
|
||||
}
|
||||
|
||||
.aoc_calendar_field.aoc_enabled {
|
||||
background: $COL_CHRISTMAS_GREEN;
|
||||
color: $COL_CHRISTMAS_RED;
|
||||
border: 1px solid #FFFFFF;
|
||||
text-shadow: 0 0 0.2em #222;
|
||||
font-weight: bold;
|
||||
}
|
||||
|
||||
.aoc_calendar_field.aoc_enabled:hover {
|
||||
background: $COL_CHRISTMAS_GREEN_ALT;
|
||||
color: $COL_CHRISTMAS_RED;
|
||||
border: 1px solid $COL_CHRISTMAS_RED;
|
||||
text-shadow: 0 0 0 #000;
|
||||
}
|
||||
|
||||
.aoc_calendar_field.aoc_disabled {
|
||||
background: #444;
|
||||
color: #888;
|
||||
border: 1px solid #888;
|
||||
cursor: default;
|
||||
font-weight: normal;
|
||||
}
|
||||
|
||||
// ==================== AdventOfCode Blog - Single Day View ==================== //
|
62
www/fragments/blogview_aoc_list.php
Normal file
62
www/fragments/blogview_aoc_list.php
Normal file
@ -0,0 +1,62 @@
|
||||
<?php
|
||||
require_once (__DIR__ . '/../internals/base.php');
|
||||
require_once (__DIR__ . '/../internals/blog.php');
|
||||
require_once (__DIR__ . '/../internals/adventofcode.php');
|
||||
|
||||
$year = $post['extras']['aoc:year'];
|
||||
|
||||
$assocdays = AdventOfCode::listSingleYearAssociative($year);
|
||||
|
||||
$prev_year = AdventOfCode::getPrevYear($year);
|
||||
$next_year = AdventOfCode::getNextYear($year);
|
||||
|
||||
?>
|
||||
|
||||
<div class="boxedcontent blogcontent_plain">
|
||||
|
||||
<div style="position: relative;">
|
||||
<a href="<?php echo AdventOfCode::getGithubLink($year); ?>" style="position: absolute; top: 0; right: 0; border: 0;">
|
||||
<img src="/data/images/blog/github_band.png" alt="Fork me on GitHub" data-canonical-src="https://s3.amazonaws.com/github/ribbons/forkme_right_darkblue_121621.png">
|
||||
</a>
|
||||
</div>
|
||||
|
||||
<div class="bc_header">
|
||||
<?php echo $post['date']; ?>
|
||||
</div>
|
||||
|
||||
<div class="bc_data">
|
||||
|
||||
<?php echo nl2br(Blog::getPostFragment($post)); ?>
|
||||
|
||||
<div class="aoc_calendar_parent">
|
||||
<div class="aoc_calendar">
|
||||
<div class="aoc_calendar_header">
|
||||
<?php
|
||||
if ($prev_year !== null) echo '<a href="' . AdventOfCode::getURLForYear($prev_year) . '" class="aoc_calendar_header_link aoc_prev" ><</a>';
|
||||
else echo '<a href="#" class="aoc_calendar_header_link aoc_prev aoc_link_hidden" ><</a>';
|
||||
|
||||
echo '<span class="aoc_calendar_header_title">'.$year.'</span>';
|
||||
|
||||
if ($next_year !== null) echo '<a href="' . AdventOfCode::getURLForYear($next_year) . '" class="aoc_calendar_header_link aoc_next" >></a>';
|
||||
else echo '<a href="" class="aoc_calendar_header_link aoc_next aoc_link_hidden" >></a>';
|
||||
?>
|
||||
</div>
|
||||
|
||||
<?php
|
||||
for ($i=0; $i<5; $i++)
|
||||
{
|
||||
echo '<div class="aoc_calendar_row">'."\n";
|
||||
for ($j=0; $j<5; $j++)
|
||||
{
|
||||
$day = $assocdays[$i*5+$j];
|
||||
if ($day === null) echo '<span class="aoc_calendar_field aoc_disabled">'.($i*5+$j+1).'</span>'."\n";
|
||||
else echo '<a href="'.$day['url'].'" class="aoc_calendar_field aoc_enabled" >'.($i*5+$j+1).'</a>'."\n";
|
||||
}
|
||||
echo '</div>'."\n";
|
||||
}
|
||||
?>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
</div>
|
||||
</div>
|
@ -181,7 +181,7 @@ try {
|
||||
}
|
||||
|
||||
$OPTIONS = $opt;
|
||||
include $target;
|
||||
include $target;
|
||||
return;
|
||||
|
||||
}
|
||||
|
@ -10,7 +10,15 @@ class AdventOfCode
|
||||
|
||||
const LANGUAGES =
|
||||
[
|
||||
'cs' => ['ext'=>'linq', 'css'=>'language-csharp', 'name'=>'C#'],
|
||||
'cs' => ['ext'=>'linq', 'css'=>'language-csharp', 'name'=>'C#'],
|
||||
'java' => ['ext'=>'java', 'css'=>'language-java', 'name'=>'Java'],
|
||||
'bef' => ['ext'=>'b93', 'css'=>'language-befungerunner', 'name'=>'Befunge-93+'],
|
||||
'cpp' => ['ext'=>'cpp', 'css'=>'language-cpp', 'name'=>'C++'],
|
||||
'pyth' => ['ext'=>'py', 'css'=>'language-python', 'name'=>'Python'],
|
||||
'rust' => ['ext'=>'rs', 'css'=>'language-rust', 'name'=>'Rust'],
|
||||
'go' => ['ext'=>'go', 'css'=>'language-go', 'name'=>'Go'],
|
||||
'js' => ['ext'=>'js', 'css'=>'language-javascript', 'name'=>'Javascript'],
|
||||
'pas' => ['ext'=>'pas', 'css'=>'language-pascal', 'name'=>'Pascal/Delphi'],
|
||||
];
|
||||
|
||||
public static function listAllFromAllYears()
|
||||
@ -26,7 +34,25 @@ class AdventOfCode
|
||||
{
|
||||
$all = require (__DIR__ . '/../statics/aoc/__all.php');
|
||||
|
||||
return array_map('self::readSingle', $all[$year]);
|
||||
$result = $all[$year];
|
||||
|
||||
array_walk($result, function(&$value) use ($year) { $value = self::readSingle($year, $value); });
|
||||
|
||||
return $result;
|
||||
}
|
||||
|
||||
public static function listSingleYearAssociative($year)
|
||||
{
|
||||
$all = self::listSingleYear($year);
|
||||
|
||||
$result = array_fill(0, 25, null);
|
||||
|
||||
foreach ($all as $d)
|
||||
{
|
||||
$result[$d['day']-1] = $d;
|
||||
}
|
||||
|
||||
return $result;
|
||||
}
|
||||
|
||||
public static function listYears()
|
||||
@ -85,6 +111,38 @@ class AdventOfCode
|
||||
return null;
|
||||
}
|
||||
|
||||
public static function getGithubLink($year)
|
||||
{
|
||||
return self::YEARS['' . $year]['github'];
|
||||
}
|
||||
|
||||
public static function getURLForYear($year)
|
||||
{
|
||||
return '/blog/' . self::YEARS[''.$year]['blog-id'] . '/Advent_of_Code_' . $year . '/';
|
||||
}
|
||||
|
||||
public static function getPrevYear($year)
|
||||
{
|
||||
$last = null;
|
||||
foreach (self::YEARS as $y => $d)
|
||||
{
|
||||
if ($y == $year) return $last;
|
||||
$last = $y;
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
public static function getNextYear($year)
|
||||
{
|
||||
$found = false;
|
||||
foreach (self::YEARS as $y => $d)
|
||||
{
|
||||
if ($found) return $y;
|
||||
if ($y == $year) $found = true;
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
public static function checkConsistency()
|
||||
{
|
||||
$warn = null;
|
||||
@ -104,6 +162,8 @@ class AdventOfCode
|
||||
if (in_array($aocdata['title'], $titlelist)) return ['result'=>'err', 'message' => 'Duplicate title ' . $aocdata['title']];
|
||||
$titlelist []= $aocdata['title'];
|
||||
|
||||
if ($aocdata['day'] < 1 || $aocdata['day'] > 25) return ['result'=>'err', 'message' => 'Invali [day]-value title ' . $aocdata['day']];
|
||||
|
||||
if (count($aocdata['solutions']) !== $aocdata['parts']) return ['result'=>'err', 'message' => 'Not enough solution-values in day' . $aocdata['day']];
|
||||
if (count($aocdata['file_solutions']) !== $aocdata['parts']) return ['result'=>'err', 'message' => 'Not enough solution-files in day' . $aocdata['day']];
|
||||
|
||||
|
@ -31,9 +31,9 @@ if ($isSubAdventOfCode)
|
||||
}
|
||||
if ($adventofcodeday === null) $isSubAdventOfCode = false;
|
||||
|
||||
$title = $post['title'];
|
||||
if ($isSubEuler) $title = $eulerproblem['title'];
|
||||
if ($isSubAdventOfCode) $title = $adventofcodeday['title'];
|
||||
$htmltitle = $post['title'];
|
||||
if ($isSubEuler) $htmltitle = $eulerproblem['title'];
|
||||
if ($isSubAdventOfCode) $htmltitle = $adventofcodeday['title'];
|
||||
|
||||
$canonical = $post['canonical'];
|
||||
if ($isSubEuler) $canonical = $eulerproblem['canonical'];
|
||||
@ -42,7 +42,7 @@ if ($isSubAdventOfCode) $canonical = $adventofcodeday['canonical'];
|
||||
?>
|
||||
<head>
|
||||
<meta charset="utf-8">
|
||||
<title>Mikescher.com - <?php echo $title; ?></title>
|
||||
<title>Mikescher.com - <?php echo $htmltitle; ?></title>
|
||||
<link rel="icon" type="image/png" href="/data/images/favicon.png"/>
|
||||
<?php printCSS(); ?>
|
||||
<?php echo '<link rel="canonical" href="' . $canonical . '"/>'; ?>
|
||||
|
@ -24,6 +24,6 @@ return
|
||||
[ 'id' => 9, 'date' => '2016-10-22', 'visible' => true, 'title' => 'A complete sudoku solver in Befunge-93', 'fragment' => 'sudoku_befunge.md', 'type' => 'markdown', 'cat' => 'blog' ],
|
||||
[ 'id' => 21, 'date' => '2018-01-02', 'visible' => true, 'title' => 'A simple javascript befunge-93 runner', 'fragment' => 'js_befrunner.md', 'type' => 'markdown', 'cat' => 'blog' ],
|
||||
[ 'id' => 22, 'date' => '2018-02-06', 'visible' => true, 'title' => 'Homepage iteration 5', 'fragment' => 'v5.md', 'type' => 'markdown', 'cat' => 'log' ],
|
||||
[ 'id' => 23, 'date' => '2019-11-02', 'visible' => true, 'title' => 'Advent of Code 2018', 'fragment' => '', 'type' => 'aoc', 'cat' => 'blog', 'extras' => ['aoc:year' => '2018'] ],
|
||||
[ 'id' => 24, 'date' => '2019-12-01', 'visible' => false, 'title' => 'Advent of Code 2019', 'fragment' => '', 'type' => 'aoc', 'cat' => 'blog', 'extras' => ['aoc:year' => '2019'] ],
|
||||
[ 'id' => 23, 'date' => '2019-11-02', 'visible' => true, 'title' => 'Advent of Code 2018', 'fragment' => 'aoc2018.txt', 'type' => 'aoc', 'cat' => 'blog', 'extras' => ['aoc:year' => '2018'] ],
|
||||
[ 'id' => 24, 'date' => '2019-12-01', 'visible' => false, 'title' => 'Advent of Code 2019', 'fragment' => 'aoc2019.txt', 'type' => 'aoc', 'cat' => 'blog', 'extras' => ['aoc:year' => '2019'] ],
|
||||
];
|
5
www/statics/blog/aoc2018.txt
Normal file
5
www/statics/blog/aoc2018.txt
Normal file
@ -0,0 +1,5 @@
|
||||
This is the first year I'm participating in the advent of code programming challenges.
|
||||
|
||||
I intend to solve the puzzles with C# and Linqpad 5, just because that's the configuration I'm most confortable at writing small one-off scripts.
|
||||
|
||||
If you haven't solved them by yourself be aware that clicking on the days below will spoiler the solutions and the second daily challenges...
|
1
www/statics/blog/aoc2019.txt
Normal file
1
www/statics/blog/aoc2019.txt
Normal file
@ -0,0 +1 @@
|
||||
//TODO ENTER TEXT HERE
|
Loading…
x
Reference in New Issue
Block a user