Experimental communication tools (televex screen + televex print)
https://televex.vvvvvvaria.org/
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
87 lines
2.3 KiB
87 lines
2.3 KiB
4 years ago
|
import feedparser
|
||
|
import os
|
||
|
from icalendar import Calendar
|
||
|
import datetime
|
||
|
from requests import get
|
||
|
import urllib
|
||
|
import json
|
||
|
import pypandoc
|
||
|
import time
|
||
|
|
||
|
ics = get("https://varia.zone/events.ics").text
|
||
|
gcal = Calendar.from_ical(ics)
|
||
|
now = datetime.datetime.now()
|
||
|
|
||
|
while True:
|
||
|
|
||
4 years ago
|
#os.system("toilet --gay -w 125 -W --filter border:gay \ \ \ \ \ VARIA\ \ \ \ \ ")
|
||
|
os.system("./venv/bin/python3 tools/ascii-art-but-with-unicode/repeated_sinus_amplitude_variation.py | lolcat -a -d 1")
|
||
4 years ago
|
print("")
|
||
4 years ago
|
time.sleep(1)
|
||
4 years ago
|
|
||
4 years ago
|
os.system("./venv/bin/python3 tools/ascii-art-but-with-unicode/multi_column_page.py | lolcat -a -d 1")
|
||
|
|
||
|
print("")
|
||
4 years ago
|
time.sleep(10)
|
||
4 years ago
|
|
||
|
for c in gcal.walk():
|
||
|
|
||
|
if c.name == "VEVENT":
|
||
|
|
||
|
date = c.get("dtstart").dt
|
||
|
title = c.get("summary")
|
||
|
|
||
|
if date > now:
|
||
|
|
||
4 years ago
|
# An attempt to keep TeleVex running throughout the night
|
||
|
# (even if the Multifeeder/server is not available)
|
||
|
try:
|
||
|
url = 'https://multi.vvvvvvaria.org/API/latest/25'
|
||
|
response = urllib.request.urlopen(url).read()
|
||
|
multifeeder = json.loads(response)
|
||
4 years ago
|
|
||
4 years ago
|
except:
|
||
4 years ago
|
|
||
4 years ago
|
multifeeder = []
|
||
|
os.system("toilet -f script -w 125 --gay Zzz... the server sleeps.")
|
||
4 years ago
|
|
||
|
for post in multifeeder:
|
||
|
|
||
|
# Clean up the title of the RSS & Calendar
|
||
4 years ago
|
title_check = title.lower().strip().replace('\n','')
|
||
|
rss_title_check = post["title"].lower().strip().replace('\n','')
|
||
4 years ago
|
|
||
4 years ago
|
if title_check == rss_title_check:
|
||
4 years ago
|
|
||
4 years ago
|
os.system("toilet --gay -w 125 -W --filter border:gay \ \ \ COMING UP\ \ \ \ ")
|
||
|
print("")
|
||
|
time.sleep(1)
|
||
|
|
||
|
description = pypandoc.convert_text(post["summary"], 'plain', format='html',extra_args=['--columns=64'])
|
||
4 years ago
|
|
||
|
# Send the event to the terminal·
|
||
4 years ago
|
|
||
|
# Title
|
||
|
os.system(f"toilet -f big --gay -w 125 '{ title }'")
|
||
4 years ago
|
print("")
|
||
|
time.sleep(1)
|
||
|
|
||
4 years ago
|
# Date
|
||
4 years ago
|
print(date.strftime("%A %d %B %Y (%H:%M:%S)"))
|
||
|
print("")
|
||
|
time.sleep(1)
|
||
|
|
||
4 years ago
|
# Description
|
||
4 years ago
|
lines = [line for line in description.split('\n')]
|
||
|
for line in lines:
|
||
|
# HACKY!!!
|
||
4 years ago
|
line = line.replace('\n', '')
|
||
|
#line = line.replace('(', '(')
|
||
|
#line = line.replace(')', ')')
|
||
|
#line = line.replace(';', '\;')
|
||
|
#line = line.replace('"', '\"')
|
||
|
#line = line.replace("'", "\'")
|
||
|
os.system(f"echo '{ line }' | lolcat -a -d 1")
|
||
4 years ago
|
print("")
|
||
4 years ago
|
time.sleep(3)
|