rj1
about | log | files | refs
commit 1d51bf864a2c84b40bff1e551adedd41c2e4581f
parent 30129f8bff4b4d24d2e6719e32de0b143a693c38
author: rj1 <[email protected]>
date:   Fri,  9 Dec 2022 18:18:38 -0600

new section: irc ascii art archive

Diffstat:
M.gitignore | 3+++
MREADME.md | 6++++++
Acontent/ascii/.gitkeep | 0
Astatic/ascii/sshot/.gitkeep | 0
Astatic/ascii/txt/.gitkeep | 0
Athemes/rj1/layouts/ascii/list.html | 31+++++++++++++++++++++++++++++++
Athemes/rj1/layouts/ascii/single.html | 13+++++++++++++
Mthemes/rj1/layouts/partials/head.html | 3++-
Athemes/rj1/static/css/hack.css | 34++++++++++++++++++++++++++++++++++
Mthemes/rj1/static/css/style.css | 913++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-
Athemes/rj1/static/fonts/.gitkeep | 0
Athemes/rj1/static/js/ascii.js | 40++++++++++++++++++++++++++++++++++++++++
12 files changed, 1034 insertions(+), 9 deletions(-)

diff --git a/.gitignore b/.gitignore @@ -2,3 +2,6 @@ /public /resources /static/repos/ +/static/ascii/* +/content/ascii/* +!/content/ascii/.gitkeep diff --git a/README.md b/README.md @@ -5,3 +5,9 @@ source files for [my website](https://rj1.su) this site is generated using a combination of [hugo](https://gohugo.io/) and [my personal fork](https://rj1.su/repos/stagit) of [stagit](https://codemadness.org/stagit.html) + +## font + +download [Hack web fonts](https://github.com/source-foundry/Hack/blob/master/docs/WEBFONT_USAGE.md) and place them in +`themes/rj1/static/fonts/` + diff --git a/content/ascii/.gitkeep b/content/ascii/.gitkeep diff --git a/static/ascii/sshot/.gitkeep b/static/ascii/sshot/.gitkeep diff --git a/static/ascii/txt/.gitkeep b/static/ascii/txt/.gitkeep diff --git a/themes/rj1/layouts/ascii/list.html b/themes/rj1/layouts/ascii/list.html @@ -0,0 +1,31 @@ +{{ define "main" }} + <h1>{{ lower .Title }}</h1> + <input + class="ascii-search" + id="ascii-search" + type="text" + placeholder="search.." + autocomplete="off" + /> + <p class="disclaimer"> + disclaimer: this is user-generated content, I'm not responsible for nor endorse the contents of this archive + </p> + <div id="ascii-gallery" class="ascii-gallery"> + {{ range (.Paginate (.RegularPagesRecursive | shuffle) 72).Pages}} + <div class="ascii"> + <a href="{{ .RelPermalink }}"> + <img src="/ascii/sshot/thumb/{{ .Title }}.png" loading="lazy"/> + <span class="ascii-caption">{{ .Title }}</span> + </a> + </div> + {{ end }} + </div> + <div id="pagination" class="pagination"> + {{ template "_internal/pagination.html" . }} + </div> + <script type="text/javascript"> + var asciis = document.getElementById("ascii-gallery").innerHTML; + </script> + <script src="{{ "js/ascii-index.js" | relURL }}"></script> + <script src="{{ "js/ascii.js" | relURL }}"></script> +{{ end }} diff --git a/themes/rj1/layouts/ascii/single.html b/themes/rj1/layouts/ascii/single.html @@ -0,0 +1,13 @@ +{{ define "main" }} + <div class="irc-art"> + <h1><a href="/ascii">ascii</a> // {{ lower .Title }}</h1> + <div> + download: + <a href="{{ .Params.txt }}">txt</a> + <a href="{{ .Params.sshot }}">png</a> + </div> + <div id="irc"> + {{ .Params.asciiData | base64Decode | htmlUnescape | safeHTML }} + </div> + </div> +{{ end }} diff --git a/themes/rj1/layouts/partials/head.html b/themes/rj1/layouts/partials/head.html @@ -14,5 +14,6 @@ {{ printf `<link rel="%s" type="%s" href="%s" title="%s" />` .Rel .MediaType.Type .Permalink $.Site.Title | safeHTML }} {{ end -}} <link rel="stylesheet" type="text/css" media="screen" href="/css/style.css" /> - <link rel="icon" href="/favicon.svg"> + <link rel="stylesheet" href="/css/hack.css"> + <link rel="icon" href="/favicon.svg"> </head> diff --git a/themes/rj1/static/css/hack.css b/themes/rj1/static/css/hack.css @@ -0,0 +1,34 @@ +/*! + * Hack typeface https://github.com/source-foundry/Hack + * License: https://github.com/source-foundry/Hack/blob/master/LICENSE.md + */ +/* FONT PATHS + * -------------------------- */ +@font-face { + font-family: 'Hack'; + src: url('/fonts/hack-regular.woff2?sha=3114f1256') format('woff2'), url('fonts/hack-regular.woff?sha=3114f1256') format('woff'); + font-weight: 400; + font-style: normal; +} + +@font-face { + font-family: 'Hack'; + src: url('/fonts/hack-bold.woff2?sha=3114f1256') format('woff2'), url('fonts/hack-bold.woff?sha=3114f1256') format('woff'); + font-weight: 700; + font-style: normal; +} + +@font-face { + font-family: 'Hack'; + src: url('/fonts/hack-italic.woff2?sha=3114f1256') format('woff2'), url('fonts/hack-italic.woff?sha=3114f1256') format('woff'); + font-weight: 400; + font-style: italic; +} + +@font-face { + font-family: 'Hack'; + src: url('/fonts/hack-bolditalic.woff2?sha=3114f1256') format('woff2'), url('fonts/hack-bolditalic.woff?sha=3114f1256') format('woff'); + font-weight: 700; + font-style: italic; +} + diff --git a/themes/rj1/static/css/style.css b/themes/rj1/static/css/style.css @@ -45,7 +45,8 @@ ul li { text-indent: -2ch; } -ul > li::before { +.posts, +.md li::before { content: "* "; font-weight: bold; } @@ -142,7 +143,6 @@ pre code { margin-right: auto; max-width: 900px; padding: 0 1ch; - word-wrap: break-word; } header { @@ -745,15 +745,33 @@ span.linenos.special { color: #d19a66; } /* literal.number.integer.long */ -/* ascii art */ -.ascii_gallery { +/* ascii art gallery */ + +.disclaimer { + font-size: 0.5em; + color: #999; + text-align: center; +} + +.ascii-search { + height: 25px; + width: 98%; + padding: 8px; + border: 2px solid; + line-height: 1.6; + font-size: 1.25rem; + margin-top: 0.75rem; + background-color: #869e74 +} + +.ascii-gallery { display: grid; grid-gap: 10px; grid-template-columns: repeat(auto-fit, minmax(100px, 1fr)); margin-top: 1.25rem; } -.ascii_gallery img { +.ascii-gallery img { width: 100%; display: block; max-height: 120px; @@ -761,14 +779,14 @@ span.linenos.special { object-fit: cover; } -.ascii_gallery .ascii { +.ascii-gallery .ascii { margin-top: 0px; position: relative; overflow: hidden; } -.ascii_gallery .caption { - font-size: 14px; +.ascii-gallery .ascii-caption { + font-size: 0.7em; padding: 0.01em; position: absolute; bottom: 0; @@ -777,3 +795,882 @@ span.linenos.special { background: rgba(0, 0, 0, 0.7); color: rgb(255, 255, 255); } + +/* #irc { +white-space: nowrap; +overflow-wrap: normal; +} */ + +#irc, +#irc li { + font-family: Hack, monospace; + margin: 0px 0px 0px 0px; + list-style: none; + font-size: 0.8em; + text-transform: none; +} + +#irc { + margin-top: 10px; + overflow-x: scroll; + overflow-y: hidden; + white-space: nowrap; + line-height: normal; +} + +/* irc color codes */ +.irc-0 { + color: #fff; +} + +.irc-1 { + color: #000; +} + +.irc-2 { + color: #001f3f; +} + +.irc-3 { + color: #2ecc40; +} + +.irc-4 { + color: #ff4136; +} + +.irc-5 { + color: #85144b; +} + +.irc-6 { + color: #b10dc9; +} + +.irc-7 { + color: #ff851b; +} + +.irc-8 { + color: #ffdc00; +} + +.irc-9 { + color: #01ff70; +} + +.irc-10 { + color: #39cccc; +} + +.irc-11 { + color: #0ff; +} + +.irc-12 { + color: #0074d9; +} + +.irc-13 { + color: #f012be; +} + +.irc-14 { + color: #aaa; +} + +.irc-15 { + color: #ddd; +} + +.irc-16 { + color: #470000; +} + +.irc-17 { + color: #472100; +} + +.irc-18 { + color: #474700; +} + +.irc-19 { + color: #324700; +} + +.irc-20 { + color: #004700; +} + +.irc-21 { + color: #00472c; +} + +.irc-22 { + color: #004747; +} + +.irc-23 { + color: #002747; +} + +.irc-24 { + color: #000047; +} + +.irc-25 { + color: #2e0047; +} + +.irc-26 { + color: #470047; +} + +.irc-27 { + color: #47002a; +} + +.irc-28 { + color: #740000; +} + +.irc-29 { + color: #743a00; +} + +.irc-30 { + color: #747400; +} + +.irc-31 { + color: #517400; +} + +.irc-32 { + color: #007400; +} + +.irc-33 { + color: #007449; +} + +.irc-34 { + color: #007474; +} + +.irc-35 { + color: #004074; +} + +.irc-36 { + color: #000074; +} + +.irc-37 { + color: #4b0074; +} + +.irc-38 { + color: #740074; +} + +.irc-39 { + color: #740045; +} + +.irc-40 { + color: #b50000; +} + +.irc-41 { + color: #b56300; +} + +.irc-42 { + color: #b5b500; +} + +.irc-43 { + color: #7db500; +} + +.irc-44 { + color: #00b500; +} + +.irc-45 { + color: #00b571; +} + +.irc-46 { + color: #00b5b5; +} + +.irc-47 { + color: #0063b5; +} + +.irc-48 { + color: #0000b5; +} + +.irc-49 { + color: #7500b5; +} + +.irc-50 { + color: #b500b5; +} + +.irc-51 { + color: #b5006b; +} + +.irc-52 { + color: #ff0000; +} + +.irc-53 { + color: #ff8c00; +} + +.irc-54 { + color: #ffff00; +} + +.irc-55 { + color: #b2ff00; +} + +.irc-56 { + color: #00ff00; +} + +.irc-57 { + color: #00ffa0; +} + +.irc-58 { + color: #00ffff; +} + +.irc-59 { + color: #008cff; +} + +.irc-60 { + color: #0000ff; +} + +.irc-61 { + color: #a500ff; +} + +.irc-62 { + color: #ff00ff; +} + +.irc-63 { + color: #ff0098; +} + +.irc-64 { + color: #ff5959; +} + +.irc-65 { + color: #ffb459; +} + +.irc-66 { + color: #ffff71; +} + +.irc-67 { + color: #cfff60; +} + +.irc-68 { + color: #6fff6f; +} + +.irc-69 { + color: #65ffc9; +} + +.irc-70 { + color: #6dffff; +} + +.irc-71 { + color: #59b4ff; +} + +.irc-72 { + color: #5959ff; +} + +.irc-73 { + color: #c459ff; +} + +.irc-74 { + color: #ff66ff; +} + +.irc-75 { + color: #ff59bc; +} + +.irc-76 { + color: #ff9c9c; +} + +.irc-77 { + color: #ffd39c; +} + +.irc-78 { + color: #ffff9c; +} + +.irc-79 { + color: #e2ff9c; +} + +.irc-80 { + color: #9cff9c; +} + +.irc-81 { + color: #9cffdb; +} + +.irc-82 { + color: #9cffff; +} + +.irc-83 { + color: #9cd3ff; +} + +.irc-84 { + color: #9c9cff; +} + +.irc-85 { + color: #dc9cff; +} + +.irc-86 { + color: #ff9cff; +} + +.irc-87 { + color: #ff94d3; +} + +.irc-88 { + color: #000000; +} + +.irc-89 { + color: #131313; +} + +.irc-90 { + color: #282828; +} + +.irc-91 { + color: #363636; +} + +.irc-92 { + color: #4d4d4d; +} + +.irc-93 { + color: #656565; +} + +.irc-94 { + color: #818181; +} + +.irc-95 { + color: #9f9f9f; +} + +.irc-96 { + color: #bcbcbc; +} + +.irc-97 { + color: #e2e2e2; +} + +.irc-98 { + color: #ffffff; +} + +.irc-bg0 { + background: #fff; +} + +.irc-bg1 { + background: #000; +} + +.irc-bg2 { + background: #001f3f; +} + +.irc-bg3 { + background: #2ecc40; +} + +.irc-bg4 { + background: #ff4136; +} + +.irc-bg5 { + background: #85144b; +} + +.irc-bg6 { + background: #b10dc9; +} + +.irc-bg7 { + background: #ff851b; +} + +.irc-bg8 { + background: #ffdc00; +} + +.irc-bg9 { + background: #01ff70; +} + +.irc-bg10 { + background: #39cccc; +} + +.irc-bg11 { + background: #0ff; +} + +.irc-bg12 { + background: #0074d9; +} + +.irc-bg13 { + background: #f012be; +} + +.irc-bg14 { + background: #aaa; +} + +.irc-bg15 { + background: #ddd; +} + +.irc-bg16 { + background: #470000; +} + +.irc-bg17 { + background: #472100; +} + +.irc-bg18 { + background: #474700; +} + +.irc-bg19 { + background: #324700; +} + +.irc-bg20 { + background: #004700; +} + +.irc-bg21 { + background: #00472c; +} + +.irc-bg22 { + background: #004747; +} + +.irc-bg23 { + background: #002747; +} + +.irc-bg24 { + background: #000047; +} + +.irc-bg25 { + background: #2e0047; +} + +.irc-bg26 { + background: #470047; +} + +.irc-bg27 { + background: #47002a; +} + +.irc-bg28 { + background: #740000; +} + +.irc-bg29 { + background: #743a00; +} + +.irc-bg30 { + background: #747400; +} + +.irc-bg31 { + background: #517400; +} + +.irc-bg32 { + background: #007400; +} + +.irc-bg33 { + background: #007449; +} + +.irc-bg34 { + background: #007474; +} + +.irc-bg35 { + background: #004074; +} + +.irc-bg36 { + background: #000074; +} + +.irc-bg37 { + background: #4b0074; +} + +.irc-bg38 { + background: #740074; +} + +.irc-bg39 { + background: #740045; +} + +.irc-bg40 { + background: #b50000; +} + +.irc-bg41 { + background: #b56300; +} + +.irc-bg42 { + background: #b5b500; +} + +.irc-bg43 { + background: #7db500; +} + +.irc-bg44 { + background: #00b500; +} + +.irc-bg45 { + background: #00b571; +} + +.irc-bg46 { + background: #00b5b5; +} + +.irc-bg47 { + background: #0063b5; +} + +.irc-bg48 { + background: #0000b5; +} + +.irc-bg49 { + background: #7500b5; +} + +.irc-bg50 { + background: #b500b5; +} + +.irc-bg51 { + background: #b5006b; +} + +.irc-bg52 { + background: #ff0000; +} + +.irc-bg53 { + background: #ff8c00; +} + +.irc-bg54 { + background: #ffff00; +} + +.irc-bg55 { + background: #b2ff00; +} + +.irc-bg56 { + background: #00ff00; +} + +.irc-bg57 { + background: #00ffa0; +} + +.irc-bg58 { + background: #00ffff; +} + +.irc-bg59 { + background: #008cff; +} + +.irc-bg60 { + background: #0000ff; +} + +.irc-bg61 { + background: #a500ff; +} + +.irc-bg62 { + background: #ff00ff; +} + +.irc-bg63 { + background: #ff0098; +} + +.irc-bg64 { + background: #ff5959; +} + +.irc-bg65 { + background: #ffb459; +} + +.irc-bg66 { + background: #ffff71; +} + +.irc-bg67 { + background: #cfff60; +} + +.irc-bg68 { + background: #6fff6f; +} + +.irc-bg69 { + background: #65ffc9; +} + +.irc-bg70 { + background: #6dffff; +} + +.irc-bg71 { + background: #59b4ff; +} + +.irc-bg72 { + background: #5959ff; +} + +.irc-bg73 { + background: #c459ff; +} + +.irc-bg74 { + background: #ff66ff; +} + +.irc-bg75 { + background: #ff59bc; +} + +.irc-bg76 { + background: #ff9c9c; +} + +.irc-bg77 { + background: #ffd39c; +} + +.irc-bg78 { + background: #ffff9c; +} + +.irc-bg79 { + background: #e2ff9c; +} + +.irc-bg80 { + background: #9cff9c; +} + +.irc-bg81 { + background: #9cffdb; +} + +.irc-bg82 { + background: #9cffff; +} + +.irc-bg83 { + background: #9cd3ff; +} + +.irc-bg84 { + background: #9c9cff; +} + +.irc-bg85 { + background: #dc9cff; +} + +.irc-bg86 { + background: #ff9cff; +} + +.irc-bg87 { + background: #ff94d3; +} + +.irc-bg88 { + background: #000000; +} + +.irc-bg89 { + background: #131313; +} + +.irc-bg90 { + background: #282828; +} + +.irc-bg91 { + background: #363636; +} + +.irc-bg92 { + background: #4d4d4d; +} + +.irc-bg93 { + background: #656565; +} + +.irc-bg94 { + background: #818181; +} + +.irc-bg95 { + background: #9f9f9f; +} + +.irc-bg96 { + background: #bcbcbc; +} + +.irc-bg97 { + background: #e2e2e2; +} + +.irc-bg98 { + background: #ffffff; +} + +.irc-bold { + font-weight: 700; +} + +.irc-underline { + text-decoration: underline; +} + +.irc-strikethrough { + text-decoration: line-through; +} + +.irc-underline.irc-strikethrough { + text-decoration: underline line-through; +} + +.irc-italic { + font-style: italic; +} + +.pagination { + display: flex; + list-style: none; + margin: 20px 0; + padding: 0; + justify-content: center; +} + +.pagination .page-link { + margin-top: 0; + position: relative; + display: block; + padding: 0.75rem 1.5rem; + color: #000; + background-color: #869e74; + margin-right: 30px; + font-weight: bold; +} + +.pagination .page-item { + margin-top: 0; +} + +.pagination .homepage .page-link, +.listing .page-link { + background-color: #432; +} + +.pagination .page-item.disabled .page-link { + color: #666; + background-color: #869e74; +} + +.pagination .page-item.active .page-link { + z-index: 1; + color: #000; + font-weight: bold; + background-color: #dbf7c6 +} + +.pagination ul li { + text-indent: 0; +} diff --git a/themes/rj1/static/fonts/.gitkeep b/themes/rj1/static/fonts/.gitkeep diff --git a/themes/rj1/static/js/ascii.js b/themes/rj1/static/js/ascii.js @@ -0,0 +1,40 @@ +(function () { + var ascii_search = function (event, arts) { + var filter = ascii_input.value.toUpperCase(); + var ascii_gallery = document.getElementById("ascii-gallery"); + + if (ascii_input.value.length == 0) { + ascii_gallery.innerHTML = asciis; + ascii_gallery.style.display = ""; + document.getElementById("pagination").style.display = ""; + return; + } else if (ascii_input.value.length > 2) { + ascii_gallery.innerHTML = ""; + document.getElementById("pagination").style.display = "none"; + + for (i = 0; i < ascii_list.length; i++) { + var item = ascii_list[i]; + var text = item.toUpperCase(); + if (text.indexOf(filter) > -1) { + ascii_gallery.innerHTML += + '<div class="ascii"><a href="/ascii/' + + item.toLowerCase().replace(/ /g, "-") + + '"><img src="/ascii/sshot/thumb/' + + item + + '.png" loading="lazy"/><span class="caption">' + + item + + "</span></a></div>"; + } + } + } + }; + + var ascii_input = document.getElementById("ascii-search"); + if (ascii_input) { + ascii_input.addEventListener( + "keyup", + ascii_search.bind(event, ascii_list), + false + ); + } +})();