Compare commits
2 commits
1e7b295384
...
65ffda928e
Author | SHA1 | Date | |
---|---|---|---|
65ffda928e | |||
978905270b |
21 changed files with 1851 additions and 16821 deletions
3
.gitignore
vendored
3
.gitignore
vendored
|
@ -11,4 +11,5 @@ build/assets/misc/
|
|||
__pycache__/
|
||||
variables.py
|
||||
log.py
|
||||
build/user.css
|
||||
build/user.css
|
||||
key.html
|
|
@ -3,7 +3,7 @@ Python scripts to generate a mobile-friendly static site for tracking tcg cards
|
|||
|
||||
** Instructions
|
||||
*** Requirements
|
||||
- =python3=
|
||||
- =python3= (needs the following libraries: =bs4, collections, datetime, os, re, requests=)
|
||||
- server space
|
||||
- subdomain pointing to your site root on the server
|
||||
- =rclone= with your server set up as a remote
|
||||
|
|
2
build.sh
2
build.sh
|
@ -1,5 +1,5 @@
|
|||
#!/usr/bin/env bash
|
||||
|
||||
python3 generate.py
|
||||
python3 new.py
|
||||
|
||||
rclone copy build prazevps:/var/www/tcg/public -P -L
|
||||
|
|
|
@ -1,63 +0,0 @@
|
|||
import datetime,os
|
||||
import log,variables,skel,tcgcore
|
||||
|
||||
def collectinggen(colour=False):
|
||||
if not os.path.isdir("build/collecting"):
|
||||
os.mkdir("build/collecting")
|
||||
if colour:
|
||||
if not os.path.isdir("build/collecting/" + colour):
|
||||
os.mkdir("build/collecting/" + colour)
|
||||
thefile = "build/collecting/" + colour + "/index.html"
|
||||
else:
|
||||
thefile = "build/collecting/index.html"
|
||||
if os.path.exists(thefile):
|
||||
os.remove(thefile)
|
||||
skel.headerwrite(thefile,"collecting")
|
||||
content = open(thefile,"a")
|
||||
content.write("<h1>decks in progress</h1>\n")
|
||||
decksofinterest = []
|
||||
for card in tcgcore.ownedcards():
|
||||
if card[0:4] != "sig_":
|
||||
if colour:
|
||||
if tcgcore.cardtype(card) == colour:
|
||||
decksofinterest.append(card[:-2])
|
||||
else:
|
||||
decksofinterest.append(card[:-2])
|
||||
decksofinterest = sorted(list(dict.fromkeys(decksofinterest)))
|
||||
highpriority = []
|
||||
medpriority = []
|
||||
lowpriority = []
|
||||
for deck in decksofinterest:
|
||||
if tcgcore.collecting(deck):
|
||||
if tcgcore.priority(deck) == "high":
|
||||
highpriority.append(deck)
|
||||
elif tcgcore.priority(deck) == "medium":
|
||||
medpriority.append(deck)
|
||||
else:
|
||||
lowpriority.append(deck)
|
||||
content.write(tcgcore.filterwrite("collecting",colour))
|
||||
if len(highpriority) > 0:
|
||||
content.write("<div>\n<h2 class=\"collectingheader\">High priority</h2>\n")
|
||||
for deck in highpriority:
|
||||
content.write(tcgcore.printdeck(deck,False))
|
||||
content.write("</div>\n")
|
||||
if len(medpriority) > 0:
|
||||
content.write("<div>\n<h2 class=\"collectingheader\">Medium priority</h2>\n")
|
||||
for deck in medpriority:
|
||||
content.write(tcgcore.printdeck(deck))
|
||||
content.write("</div>\n")
|
||||
if len(lowpriority) > 0:
|
||||
content.write("<div>\n<h2 class=\"collectingheader\">Low priority</h2>\n")
|
||||
for deck in lowpriority:
|
||||
content.write(tcgcore.printdeck(deck))
|
||||
content.write("</div>\n")
|
||||
content.close()
|
||||
skel.footerwrite(thefile)
|
||||
|
||||
def collectingall():
|
||||
collectinggen()
|
||||
for type in tcgcore.typelist:
|
||||
collectinggen(type)
|
||||
|
||||
if __name__ == "__main__":
|
||||
collectingall()
|
53
download.py
53
download.py
|
@ -1,53 +0,0 @@
|
|||
import os,requests
|
||||
import tcgcore,thetypes
|
||||
|
||||
def getimg():
|
||||
for card in tcgcore.ownedcards():
|
||||
if card[0:4] == "sig_":
|
||||
if not os.path.exists("build/decks/sigs/" + card[4:] + ".gif"):
|
||||
r = requests.get("https://colors-tcg.eu/cards/" + card + ".gif")
|
||||
open("build/decks/sigs/" + card[4:] + ".gif","wb").write(r.content)
|
||||
else:
|
||||
thepath = "build/decks/" + card[:-2]
|
||||
if not os.path.isdir(thepath):
|
||||
os.mkdir(thepath)
|
||||
if card[:-2] in thetypes.typedict:
|
||||
decktype = thetypes.typedict[card[:-2]]
|
||||
else:
|
||||
index = 0 # adapted from https://stackoverflow.com/a/64536882
|
||||
indexValidList = []
|
||||
print("Deck type for " + card[:-2] + ":")
|
||||
options = tcgcore.typelist
|
||||
for optionName in options:
|
||||
index = index + 1
|
||||
indexValidList.extend([options.index(optionName)])
|
||||
print(str(index) + ") " + optionName)
|
||||
inputValid = False
|
||||
while not inputValid:
|
||||
inputRaw = input("Type: ")
|
||||
inputNo = int(inputRaw) - 1
|
||||
if inputNo > -1 and inputNo < len(indexValidList):
|
||||
selected = indexValidList[inputNo]
|
||||
inputValid = True
|
||||
break
|
||||
else:
|
||||
print("Select a number from the list")
|
||||
decktype = options[selected]
|
||||
typefile = open(thepath + "/type","w")
|
||||
typefile.write(decktype)
|
||||
typefile.close()
|
||||
print("Downloading " + card[:-2])
|
||||
number = 0
|
||||
while number < 21:
|
||||
if number < 10:
|
||||
r = requests.get("https://colors-tcg.eu/cards/" + card[:-2] + "0" + str(number) + ".gif")
|
||||
open(thepath + "/0" + str(number) + ".gif","wb").write(r.content)
|
||||
else:
|
||||
r = requests.get("https://colors-tcg.eu/cards/" + card[:-2] + str(number) + ".gif")
|
||||
open(thepath + "/" + str(number) + ".gif","wb").write(r.content)
|
||||
number += 1
|
||||
master = requests.get("https://colors-tcg.eu/cards/" + card[:-2] + "master.gif")
|
||||
open(thepath + "/master.gif","wb").write(master.content)
|
||||
|
||||
if __name__ == "__main__":
|
||||
getimg()
|
43
generate.py
43
generate.py
|
@ -1,43 +0,0 @@
|
|||
import sys
|
||||
print("Building tradelist")
|
||||
|
||||
import download,indexgen,collectinggen,ownedgen,wantedgen,loggen,levelsgen,tradegen,masteredgen,portfoliosgen,searchgen,massgen,variables
|
||||
|
||||
print("Checking for new decks … ",end="")
|
||||
sys.stdout.flush()
|
||||
download.getimg()
|
||||
print("done\nBuilding index page …",end="")
|
||||
sys.stdout.flush()
|
||||
indexgen.indexgen()
|
||||
print(" done\nBuilding collecting page …",end="")
|
||||
sys.stdout.flush()
|
||||
massgen.massall()
|
||||
print(" done\nBuilding mass decks pages …",end="")
|
||||
sys.stdout.flush()
|
||||
collectinggen.collectingall()
|
||||
if variables.ownedpage:
|
||||
print(" done\nBuilding owned page …",end="")
|
||||
sys.stdout.flush()
|
||||
ownedgen.ownedall()
|
||||
print(" done\nBuilding wanted page …",end="")
|
||||
sys.stdout.flush()
|
||||
wantedgen.wantedgen()
|
||||
print(" done\nBuilding log pages …",end="")
|
||||
sys.stdout.flush()
|
||||
loggen.logall()
|
||||
print(" done\nBuilding levels page …",end="")
|
||||
sys.stdout.flush()
|
||||
levelsgen.levelsgen()
|
||||
print(" done\nBuilding trading page …",end="")
|
||||
sys.stdout.flush()
|
||||
tradegen.tradeall()
|
||||
print(" done\nBuilding mastered page …",end="")
|
||||
sys.stdout.flush()
|
||||
masteredgen.masteredall()
|
||||
print(" done\nBuilding portfolios page …",end="")
|
||||
sys.stdout.flush()
|
||||
portfoliosgen.portfoliosgen()
|
||||
print(" done\nBuilding search page …",end="")
|
||||
sys.stdout.flush()
|
||||
searchgen.searchgen()
|
||||
print(" done")
|
342
indexgen.py
342
indexgen.py
|
@ -1,342 +0,0 @@
|
|||
import datetime,os,re
|
||||
from collections import Counter
|
||||
import log,skel,variables,tcgcore
|
||||
|
||||
def indexgen():
|
||||
if os.path.exists("build/index.html"):
|
||||
os.remove("build/index.html")
|
||||
thefile = "build/index.html"
|
||||
skel.headerwrite(thefile,"index")
|
||||
content = open(thefile,"a")
|
||||
firstdate = log.log[0]["date"]
|
||||
if len(tcgcore.ownedcards()) > 14400:
|
||||
rankcode = "rainbow"
|
||||
extra = len(tcgcore.ownedcards()) - 14400
|
||||
plusranks = int(extra / 300)
|
||||
if plusranks > 0:
|
||||
rank = "rainbow + " + str(plusranks)
|
||||
else:
|
||||
rank = "rainbow"
|
||||
else:
|
||||
if len(tcgcore.ownedcards()) > 14100:
|
||||
rank = "himalayan"
|
||||
elif len(tcgcore.ownedcards()) > 13800:
|
||||
rank = "puma"
|
||||
elif len(tcgcore.ownedcards()) > 13500:
|
||||
rank = "chartreux"
|
||||
elif len(tcgcore.ownedcards()) > 13500:
|
||||
rank = "russian blue"
|
||||
elif len(tcgcore.ownedcards()) > 12900:
|
||||
rank = "panther"
|
||||
elif len(tcgcore.ownedcards()) > 12600:
|
||||
rank = "cheetah"
|
||||
elif len(tcgcore.ownedcards()) > 12300:
|
||||
rank = "tiger"
|
||||
elif len(tcgcore.ownedcards()) > 12000:
|
||||
rank = "lion"
|
||||
elif len(tcgcore.ownedcards()) > 11700:
|
||||
rank = "metal"
|
||||
elif len(tcgcore.ownedcards()) > 11400:
|
||||
rank = "ground"
|
||||
elif len(tcgcore.ownedcards()) > 11100:
|
||||
rank = "darkness"
|
||||
elif len(tcgcore.ownedcards()) > 10800:
|
||||
rank = "water"
|
||||
elif len(tcgcore.ownedcards()) > 10500:
|
||||
rank = "nature"
|
||||
elif len(tcgcore.ownedcards()) > 10200:
|
||||
rank = "light"
|
||||
elif len(tcgcore.ownedcards()) > 9900:
|
||||
rank = "wind"
|
||||
elif len(tcgcore.ownedcards()) > 9600:
|
||||
rank = "fire"
|
||||
elif len(tcgcore.ownedcards()) > 9300:
|
||||
rank = "mercury"
|
||||
elif len(tcgcore.ownedcards()) > 9000:
|
||||
rank = "jupiter"
|
||||
elif len(tcgcore.ownedcards()) > 8700:
|
||||
rank = "uranus"
|
||||
elif len(tcgcore.ownedcards()) > 8400:
|
||||
rank = "neptune"
|
||||
elif len(tcgcore.ownedcards()) > 8100:
|
||||
rank = "earth"
|
||||
elif len(tcgcore.ownedcards()) > 7800:
|
||||
rank = "venus"
|
||||
elif len(tcgcore.ownedcards()) > 7500:
|
||||
rank = "saturn"
|
||||
elif len(tcgcore.ownedcards()) > 7200:
|
||||
rank = "mars"
|
||||
elif len(tcgcore.ownedcards()) > 6900:
|
||||
rank = "magnolia"
|
||||
elif len(tcgcore.ownedcards()) > 6600:
|
||||
rank = "chocolate cosmos"
|
||||
elif len(tcgcore.ownedcards()) > 6300:
|
||||
rank = "lilac"
|
||||
elif len(tcgcore.ownedcards()) > 6000:
|
||||
rank = "hydrangea"
|
||||
elif len(tcgcore.ownedcards()) > 5700:
|
||||
rank = "clover"
|
||||
elif len(tcgcore.ownedcards()) > 5400:
|
||||
rank = "daffodil"
|
||||
elif len(tcgcore.ownedcards()) > 5100:
|
||||
rank = "tiger lily"
|
||||
elif len(tcgcore.ownedcards()) > 4800:
|
||||
rank = "sakura"
|
||||
elif len(tcgcore.ownedcards()) > 4500:
|
||||
rank = "silver"
|
||||
elif len(tcgcore.ownedcards()) > 4200:
|
||||
rank = "bronze"
|
||||
elif len(tcgcore.ownedcards()) > 3900:
|
||||
rank = "amethyst"
|
||||
elif len(tcgcore.ownedcards()) > 3600:
|
||||
rank = "sapphire"
|
||||
elif len(tcgcore.ownedcards()) > 3300:
|
||||
rank = "emerald"
|
||||
elif len(tcgcore.ownedcards()) > 3000:
|
||||
rank = "gold"
|
||||
elif len(tcgcore.ownedcards()) > 2700:
|
||||
rank = "amber"
|
||||
elif len(tcgcore.ownedcards()) > 2400:
|
||||
rank = "ruby"
|
||||
elif len(tcgcore.ownedcards()) > 2200:
|
||||
rank = "dragon fruit"
|
||||
elif len(tcgcore.ownedcards()) > 2000:
|
||||
rank = "apricot"
|
||||
elif len(tcgcore.ownedcards()) > 1800:
|
||||
rank = "grape"
|
||||
elif len(tcgcore.ownedcards()) > 1600:
|
||||
rank = "blueberry"
|
||||
elif len(tcgcore.ownedcards()) > 1400:
|
||||
rank = "lime"
|
||||
elif len(tcgcore.ownedcards()) > 1200:
|
||||
rank = "lemon"
|
||||
elif len(tcgcore.ownedcards()) > 1000:
|
||||
rank = "tangerine"
|
||||
elif len(tcgcore.ownedcards()) > 800:
|
||||
rank = "strawberry"
|
||||
elif len(tcgcore.ownedcards()) > 700:
|
||||
rank = "gray"
|
||||
elif len(tcgcore.ownedcards()) > 600:
|
||||
rank = "brown"
|
||||
elif len(tcgcore.ownedcards()) > 500:
|
||||
rank = "purple"
|
||||
elif len(tcgcore.ownedcards()) > 400:
|
||||
rank = "blue"
|
||||
elif len(tcgcore.ownedcards()) > 300:
|
||||
rank = "green"
|
||||
elif len(tcgcore.ownedcards()) > 200:
|
||||
rank = "yellow"
|
||||
elif len(tcgcore.ownedcards()) > 100:
|
||||
rank = "orange"
|
||||
else:
|
||||
rank = "red"
|
||||
rankcode = re.sub(" ","",rank)
|
||||
content.write("<a href=\"/levels\"><img src=\"/assets/levels/" + rankcode + ".gif\"></a>" + tcgcore.printcard("sig_" + variables.name.lower()) + "\n<ul>\n<li>player name: <span class=\"name\">" + variables.name + "</span></li>\n<li>" + str(len(tcgcore.ownedcards())) + " cards held <span class=\"rank " + rank + "\">(" + rank + ")</span></li>\n<li>started <code>" + firstdate.strftime("%Y-%m-%d") + "</code></li>\n<li>last updated <code>" + datetime.datetime.today().strftime("%Y-%m-%d") + "</code></li>\n<li><a href=\"https://git.praze.net/tre/tcg\" target=\"_blank\">code</a> under construction</li>\n")
|
||||
if len(variables.misclink["text"]) > 0:
|
||||
content.write("<li><a href=\"" + variables.misclink["link"] + "\">" + variables.misclink["text"] + "</a></li>\n")
|
||||
content.write("</ul>\n")
|
||||
crayred = 0
|
||||
crayorange = 0
|
||||
crayyellow = 0
|
||||
craygreen = 0
|
||||
crayblue = 0
|
||||
craypurple = 0
|
||||
craybrown = 0
|
||||
craygrey = 0
|
||||
for event in log.log:
|
||||
try:
|
||||
crayred += event["crayons"]["red"]
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
crayorange += event["crayons"]["orange"]
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
crayyellow += event["crayons"]["yellow"]
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
craygreen += event["crayons"]["green"]
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
crayblue += event["crayons"]["blue"]
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
craypurple += event["crayons"]["purple"]
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
craybrown += event["crayons"]["brown"]
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
craygrey += event["crayons"]["gray"]
|
||||
except:
|
||||
pass
|
||||
if crayred + crayorange + crayyellow + craygreen + crayblue + craypurple + craybrown + craygrey > 0:
|
||||
content.write("<table id=\"crayontable\">\n<tbody>\n<tr>\n")
|
||||
if crayred > 0:
|
||||
content.write("<td class=\"red\"><img src=\"/assets/crayons/crayon1.gif\" class=\"crayon\" title=\"red\"> × " + str(crayred) + "</td>\n")
|
||||
if crayorange > 0:
|
||||
content.write("<td class=\"orange\"><img src=\"/assets/crayons/crayon2.gif\" class=\"crayon\" title=\"orange\"> × " + str(crayorange) + "</td>\n")
|
||||
if crayyellow > 0:
|
||||
content.write("<td class=\"yellow\"><img src=\"/assets/crayons/crayon3.gif\" class=\"crayon\" title=\"yellow\"> × " + str(crayyellow) + "</td>\n")
|
||||
if craygreen > 0:
|
||||
content.write("<td class=\"green\"><img src=\"/assets/crayons/crayon4.gif\" class=\"crayon\" title=\"green\"> × " + str(craygreen) + "</td>\n")
|
||||
if crayblue > 0:
|
||||
content.write("<td class=\"blue\"><img src=\"/assets/crayons/crayon5.gif\" class=\"crayon\" title=\"blue\"> × " + str(crayblue) + "</td>\n")
|
||||
if craypurple > 0:
|
||||
content.write("<td class=\"purple\"><img src=\"/assets/crayons/crayon6.gif\" class=\"crayon\" title=\"purple\"> × " + str(craypurple) + "</td>\n")
|
||||
if craybrown > 0:
|
||||
content.write("<td class=\"brown\"><img src=\"/assets/crayons/crayon7.gif\" class=\"crayon\" title=\"brown\"> × " + str(craybrown) + "</td>\n")
|
||||
if craygrey > 0:
|
||||
content.write("<td class=\"grey\"><img src=\"/assets/crayons/crayon8.gif\" class=\"crayon\" title=\"")
|
||||
if variables.british:
|
||||
content.write("grey")
|
||||
else:
|
||||
content.write("gray")
|
||||
content.write("\"> × " + str(craygrey) + "</td>\n")
|
||||
content.write("</tr>\n</tbody>\n</table>\n")
|
||||
tradeout = []
|
||||
tradein = []
|
||||
for event in log.log:
|
||||
if event["event"][0:11] == "trade with ":
|
||||
try:
|
||||
for card in event["lost"]:
|
||||
tradeout.append(event["event"])
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
for card in event["received"]:
|
||||
tradein.append(event["event"])
|
||||
except:
|
||||
pass
|
||||
tradecommon = list((Counter(tradeout) & Counter(tradein)).elements())
|
||||
sketch = len(tradecommon)
|
||||
if sketch > 0:
|
||||
content.write("<table class=\"sketchpads\">\n<tbody>\n<tr>\n<td><img src=\"/assets/sketch/")
|
||||
if sketch % 20 < 10:
|
||||
content.write("0" + str(sketch % 20))
|
||||
else:
|
||||
content.write(str(sketch % 20))
|
||||
content.write(".gif\"></td>\n")
|
||||
if sketch > 19:
|
||||
content.write("<td><img src=\"/assets/sketch/20.gif\" title=\"")
|
||||
redeemedsketch = 0
|
||||
for event in log.log:
|
||||
try:
|
||||
redeemedsketch -= event["sketch"]
|
||||
except:
|
||||
pass
|
||||
sketchdifference = int(sketch / 20) - redeemedsketch
|
||||
if sketchdifference > 0:
|
||||
content.write(str(sketchdifference) + " to turn in")
|
||||
else:
|
||||
content.write("all turned in")
|
||||
content.write("\"></td>\n")
|
||||
content.write("</tr>\n<tr>\n<td align=\"center\">" + str(sketch % 20) + "/20</td>\n")
|
||||
if sketch > 19:
|
||||
content.write("<td align=\"center\">" + str(int(sketch / 20)) + " completed</td>\n")
|
||||
content.write("</tr>\n</tbody>\n</table>")
|
||||
if len(tcgcore.getpalettes()) + len(tcgcore.getmonochrome()) > 0:
|
||||
content.write("<a href=\"/portfolios\">\n<div class=\"foliocase\">\n")
|
||||
if len(tcgcore.getpalettes()) > 0:
|
||||
content.write(tcgcore.portfoliogen(tcgcore.getpalettes()[-1],"palette",len(tcgcore.getpalettes())))
|
||||
if len(tcgcore.getmonochrome()) > 0:
|
||||
content.write(tcgcore.portfoliogen(tcgcore.getmonochrome()[-1],"monochrome",len(tcgcore.getmonochrome())))
|
||||
content.write("</div>\n</a>\n")
|
||||
decksofinterest = []
|
||||
for card in tcgcore.ownedcards():
|
||||
if card[0:4] != "sig_":
|
||||
decksofinterest.append(card[:-2])
|
||||
decksofinterest = sorted(list(dict.fromkeys(decksofinterest)))
|
||||
mastereddecks = []
|
||||
for deck in decksofinterest:
|
||||
if tcgcore.deckmastered(deck):
|
||||
mastereddecks.append({"name":deck,"date":tcgcore.datemastered(deck)})
|
||||
mastereddecks = sorted(mastereddecks,key=lambda d: d["date"],reverse=True)
|
||||
if len(mastereddecks) > 0:
|
||||
content.write("<h2>mastered decks</h2>\n<p id=\"masteredcarousel\">")
|
||||
masteredcount = 0
|
||||
for deck in mastereddecks:
|
||||
if masteredcount < variables.maxmastered:
|
||||
content.write("<img src=\"/decks/" + deck["name"] + "/master.gif\" title=\"mastered " + deck["name"])
|
||||
try:
|
||||
if deck["name"] in variables.firstmasteries:
|
||||
content.write(" (first)\" class=\"first")
|
||||
except:
|
||||
pass
|
||||
content.write("\">")
|
||||
masteredcount += 1
|
||||
if len(mastereddecks) > variables.maxmastered:
|
||||
content.write(" <a href=\"mastered\">see all</a>")
|
||||
content.write("</p>\n")
|
||||
sigs = []
|
||||
for card in tcgcore.ownedcards():
|
||||
if card[0:4] == "sig_":
|
||||
sigs.append(card)
|
||||
if len(sigs) > 0:
|
||||
content.write("<h2>signatures</h2>\n<p>")
|
||||
for card in sigs:
|
||||
content.write(tcgcore.printcard(card))
|
||||
content.write("</p>\n")
|
||||
if len(variables.faves) > 0:
|
||||
content.write("<h2>faves</h2>\n<p>")
|
||||
faveslist = sorted(variables.faves)
|
||||
for card in faveslist:
|
||||
content.write(tcgcore.printcard(card))
|
||||
content.write("</p>\n")
|
||||
coupons = []
|
||||
for event in log.log:
|
||||
try:
|
||||
for newcoupon in event["coupons"]:
|
||||
found = False
|
||||
for oldcoupon in coupons:
|
||||
if found == False:
|
||||
if newcoupon == list(oldcoupon.keys())[0]:
|
||||
found = True
|
||||
oldcoupon[newcoupon] += event["coupons"][newcoupon]
|
||||
if found == False:
|
||||
coupons.append({newcoupon:event["coupons"][newcoupon]})
|
||||
except:
|
||||
pass
|
||||
coupons = coupons[::-1]
|
||||
if len(coupons) > 0:
|
||||
content.write("<h2>coupons</h2>\n<p>")
|
||||
for coupon in coupons:
|
||||
for key,value in coupon.items():
|
||||
content.write("<img src=\"/assets/coupons/" + key + ".png\" class=\"coupon")
|
||||
if value == 0:
|
||||
content.write(" expired\" title=\"expired\"")
|
||||
else:
|
||||
content.write("\" title=\"" + str(value) + " left\"")
|
||||
content.write(" loading=\"lazy\">")
|
||||
content.write("</p>\n")
|
||||
donations = []
|
||||
try:
|
||||
for deck in variables.donations["decks"]:
|
||||
donations.append(deck + "00")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
for card in variables.donations["scrapbook"]:
|
||||
donations.append(card)
|
||||
except:
|
||||
pass
|
||||
if len(donations) > 0:
|
||||
donations = sorted(donations)
|
||||
content.write("<h2>donations</h2>\n<p>")
|
||||
for donation in donations:
|
||||
if donation[-2:] == "00":
|
||||
content.write("<img src=\"/decks/" + donation[:-2] + "/00.gif\" loading=\"lazy\">")
|
||||
else:
|
||||
content.write(tcgcore.printcard(card))
|
||||
content.write("</p>\n")
|
||||
content.close()
|
||||
skel.footerwrite(thefile)
|
||||
|
||||
if __name__ == "__main__":
|
||||
indexgen()
|
254
levelsgen.py
254
levelsgen.py
|
@ -1,254 +0,0 @@
|
|||
import datetime,os,re
|
||||
import log,skel
|
||||
|
||||
def levelsgen():
|
||||
if not os.path.isdir("build/levels"):
|
||||
os.mkdir("build/levels")
|
||||
if os.path.exists("build/levels/index.html"):
|
||||
os.remove("build/levels/index.html")
|
||||
thefile = "build/levels/index.html"
|
||||
skel.headerwrite(thefile,"levels")
|
||||
content = open(thefile,"a")
|
||||
content.write("<h1>levels</h1>\n")
|
||||
dates = []
|
||||
for event in log.log:
|
||||
try:
|
||||
for card in event["received"]:
|
||||
dates.append(event["date"])
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
for card in event["lost"]:
|
||||
dates.remove(dates[-1])
|
||||
except:
|
||||
pass
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/red.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[0].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/orange.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[100].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/yellow.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[200].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/green.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[300].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/blue.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[400].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/purple.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[500].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/brown.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[600].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/gray.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[700].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/strawberry.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[800].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/tangerine.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[1000].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/lemon.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[1200].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/lime.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[1400].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/blueberry.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[1600].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/grape.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[1800].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/apricot.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[2000].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/dragonfruit.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[2200].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/ruby.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[2400].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/amber.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[2700].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/gold.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[3000].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/emerald.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[3300].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/sapphire.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[3600].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/amethyst.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[3900].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/bronze.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[4200].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/silver.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[4500].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/sakura.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[4800].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/tigerlily.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[5100].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/daffodil.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[5400].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/clover.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[5700].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/hydrangea.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[6000].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/lilac.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[6300].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/chocolatecosmos.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[6600].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/magnolia.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[6900].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/mars.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[7200].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/saturn.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[7500].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/venus.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[7800].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/earth.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[8100].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/neptune.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[8400].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/uranus.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[8700].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/jupiter.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[9000].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/mercury.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[9300].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/fire.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[9600].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/wind.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[9900].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/light.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[10200].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/nature.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[10500].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/water.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[10800].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/darkness.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[11100].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/ground.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[11400].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/metal.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[11700].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/lion.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[12000].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/tiger.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[12300].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/cheetah.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[12600].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/panther.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[12900].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/russianblue.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[13200].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/chartreux.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[13500].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/puma.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[13800].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/himalayan.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[14100].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write("<table class=\"level\">\n<tbody>\n<tr>\n<td align=\"center\"><img src=\"/assets/levels/rainbow.gif\" loading=\"lazy\"></td>\n</tr>\n<tr>\n<td align=\"center\"><code>" + dates[14400].strftime("%Y-%m-%d") + "</code></td>\n</tr>\n</tbody>\n</table>\n")
|
||||
except:
|
||||
pass
|
||||
content.close()
|
||||
skel.footerwrite(thefile)
|
||||
|
||||
if __name__ == "__main__":
|
||||
levelsgen()
|
168
loggen.py
168
loggen.py
|
@ -1,168 +0,0 @@
|
|||
import datetime,os
|
||||
import log,skel,tcgcore,variables
|
||||
|
||||
def crayonlog(colour,event):
|
||||
crayonno = event["crayons"][colour]
|
||||
if variables.british:
|
||||
if colour == "gray":
|
||||
crayonrend = "grey"
|
||||
else:
|
||||
crayonrend = colour
|
||||
else:
|
||||
crayonrend = colour
|
||||
if crayonno > 0:
|
||||
crayonstring = "+" + str(crayonno) + " " + crayonrend
|
||||
else:
|
||||
crayonstring = str(crayonno) + " " + crayonrend
|
||||
return crayonstring
|
||||
|
||||
def loggen(month=False):
|
||||
if month:
|
||||
if not os.path.isdir("build/log/month"):
|
||||
os.mkdir("build/log/month")
|
||||
if os.path.exists("build/log/month/index.html"):
|
||||
os.remove("build/log/month/index.html")
|
||||
thefile = "build/log/month/index.html"
|
||||
else:
|
||||
if not os.path.isdir("build/log"):
|
||||
os.mkdir("build/log")
|
||||
if os.path.exists("build/log/index.html"):
|
||||
os.remove("build/log/index.html")
|
||||
thefile = "build/log/index.html"
|
||||
skel.headerwrite(thefile,"log")
|
||||
content = open(thefile,"a")
|
||||
content.write("<h1>log</h1>\n<p class=\"typefilter\">")
|
||||
if month:
|
||||
content.write("<a href=\"/log\">Show all</a>")
|
||||
else:
|
||||
content.write("<a href=\"/log/month\">Show current month only</a>")
|
||||
content.write("</p>\n")
|
||||
if month:
|
||||
thelog = []
|
||||
for event in log.log:
|
||||
if event["date"].month == datetime.datetime.now().month and event["date"].year == datetime.datetime.now().year:
|
||||
thelog.append(event)
|
||||
thelog = thelog[::-1]
|
||||
else:
|
||||
thelog = log.log[::-1]
|
||||
for event in thelog:
|
||||
if event == "portfolio":
|
||||
logit = False
|
||||
else:
|
||||
try:
|
||||
if event["received"]:
|
||||
logit = True
|
||||
except:
|
||||
try:
|
||||
if event["lost"]:
|
||||
logit = True
|
||||
except:
|
||||
try:
|
||||
if event["crayons"]:
|
||||
logit = True
|
||||
except:
|
||||
logit = False
|
||||
if logit == True:
|
||||
content.write("<p><code>" + event["date"].strftime("%Y-%m-%d") + "</code> <a href=\"" + event["url"] + "\">[" + event["event"] + "]</a>: ")
|
||||
try:
|
||||
if event["received"]:
|
||||
content.write("Received ")
|
||||
receivedlist = sorted(event["received"])
|
||||
position = 1
|
||||
for card in receivedlist:
|
||||
content.write(tcgcore.cardtext(card))
|
||||
if len(receivedlist) != position:
|
||||
content.write(", ")
|
||||
position += 1
|
||||
content.write(".")
|
||||
try:
|
||||
if event["lost"]:
|
||||
content.write(" ")
|
||||
except:
|
||||
try:
|
||||
if event["crayons"]:
|
||||
content.write(" ")
|
||||
except:
|
||||
pass
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
if event["lost"]:
|
||||
content.write("Lost ")
|
||||
lostlist = sorted(event["lost"])
|
||||
position = 1
|
||||
for card in lostlist:
|
||||
content.write(tcgcore.cardtext(card))
|
||||
if len(lostlist) != position:
|
||||
content.write(", ")
|
||||
position += 1
|
||||
content.write(".")
|
||||
try:
|
||||
if event["crayons"]:
|
||||
content.write(" ")
|
||||
except:
|
||||
pass
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
if event["crayons"]:
|
||||
content.write("Crayons: ")
|
||||
try:
|
||||
content.write(crayonlog("red",event))
|
||||
if list(event["crayons"])[-1] != "red":
|
||||
content.write(", ")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write(crayonlog("orange",event))
|
||||
if list(event["crayons"])[-1] != "orange":
|
||||
content.write(", ")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write(crayonlog("yellow",event))
|
||||
if list(event["crayons"])[-1] != "yellow":
|
||||
content.write(", ")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write(crayonlog("green",event))
|
||||
if list(event["crayons"])[-1] != "green":
|
||||
content.write(", ")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write(crayonlog("blue",event))
|
||||
if list(event["crayons"])[-1] != "blue":
|
||||
content.write(", ")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write(crayonlog("purple",event))
|
||||
if list(event["crayons"])[-1] != "purple":
|
||||
content.write(", ")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write(crayonlog("brown",event))
|
||||
if list(event["crayons"])[-1] != "brown":
|
||||
content.write(", ")
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
content.write(crayonlog("gray",event))
|
||||
except:
|
||||
pass
|
||||
content.write(".")
|
||||
except:
|
||||
pass
|
||||
content.write("</p>\n")
|
||||
content.close()
|
||||
skel.footerwrite(thefile)
|
||||
|
||||
def logall():
|
||||
loggen(False)
|
||||
loggen(True)
|
||||
|
||||
if __name__ == "__main__":
|
||||
logall()
|
107
massgen.py
107
massgen.py
|
@ -1,107 +0,0 @@
|
|||
import datetime,os
|
||||
import log,skel,tcgcore,variables
|
||||
|
||||
massdecks = dict(sorted(variables.masscollect.items()))
|
||||
massowned = {}
|
||||
for series in massdecks:
|
||||
ownedlist = []
|
||||
for card in tcgcore.ownedcards():
|
||||
try:
|
||||
if card[:-2] in massdecks[series]["decks"]:
|
||||
ownedlist.append(card)
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
if card in massdecks[series]["singles"]:
|
||||
ownedlist.append(card)
|
||||
except:
|
||||
pass
|
||||
if len(ownedlist) > 0:
|
||||
ownedlist = sorted(list(dict.fromkeys(ownedlist)))
|
||||
massowned[series] = ownedlist
|
||||
|
||||
def massindexgen():
|
||||
if not os.path.isdir("build/mass"):
|
||||
os.mkdir("build/mass")
|
||||
thefile = "build/mass/index.html"
|
||||
if os.path.exists(thefile):
|
||||
os.remove(thefile)
|
||||
skel.headerwrite(thefile,"mass")
|
||||
content = open(thefile,"a")
|
||||
content.write("<h1>mass collecting</h1>\n<ul>\n")
|
||||
massindex = 1
|
||||
for series in massowned:
|
||||
content.write("<li><a href=\"/mass/" + str(massindex) + "\">" + series + "</a>")
|
||||
if variables.masscollect[series]["full"] == True:
|
||||
totalno = 0
|
||||
try:
|
||||
totalno += len(variables.masscollect[series]["decks"]) * 20
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
totalno += len(variables.masscollect[series]["singles"])
|
||||
except:
|
||||
pass
|
||||
content.write(" (")
|
||||
if len(massowned[series]) == totalno:
|
||||
content.write("complete")
|
||||
else:
|
||||
content.write(str(len(massowned[series])) + "/" + str(totalno))
|
||||
content.write(")")
|
||||
content.write("</li>\n")
|
||||
massindex += 1
|
||||
content.write("</ul>\n")
|
||||
content.close()
|
||||
skel.footerwrite(thefile)
|
||||
|
||||
def massseriesgen(series,massindex):
|
||||
if not os.path.isdir("build/mass/" + str(massindex)):
|
||||
os.mkdir("build/mass/" + str(massindex))
|
||||
thefile = "build/mass/" + str(massindex) + "/index.html"
|
||||
if os.path.exists(thefile):
|
||||
os.remove(thefile)
|
||||
skel.headerwrite(thefile,"mass")
|
||||
content = open(thefile,"a")
|
||||
content.write("<h1>" + series + "</h1>\n<p><a href=\"/mass\">back to mass decks page</a></p>\n<p>")
|
||||
themassdecks = []
|
||||
for card in massowned[series]:
|
||||
try:
|
||||
if card[:-2] in variables.masscollect[series]["decks"]:
|
||||
themassdecks.append(card[:-2])
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
if card[:-2] in variables.masscollect[series]["masters"]:
|
||||
themassdecks.append(card[:-2])
|
||||
except:
|
||||
pass
|
||||
themassdecks = sorted(list(dict.fromkeys(themassdecks)))
|
||||
massmastered = []
|
||||
for deck in themassdecks:
|
||||
if tcgcore.deckmastered(deck):
|
||||
massmastered.append(deck)
|
||||
if len(massmastered) > 0:
|
||||
for deck in massmastered:
|
||||
content.write("<img src=\"/decks/" + deck + "/master.gif\" title=\"mastered " + deck)
|
||||
try:
|
||||
if deck in variables.firstmasteries:
|
||||
content.write(" (first)\" class=\"first")
|
||||
except:
|
||||
pass
|
||||
content.write("\">")
|
||||
content.write("</p><p>")
|
||||
for card in massowned[series]:
|
||||
content.write(tcgcore.printcard(card))
|
||||
content.write("</p>\n")
|
||||
content.close()
|
||||
skel.footerwrite(thefile)
|
||||
|
||||
def massall():
|
||||
massindexgen()
|
||||
massindex = 1
|
||||
for series in massowned:
|
||||
massseriesgen(series,massindex)
|
||||
massindex += 1
|
||||
|
||||
if __name__ == "__main__":
|
||||
massall()
|
|
@ -1,43 +0,0 @@
|
|||
import datetime,os
|
||||
import log,variables,skel,tcgcore
|
||||
|
||||
def masteredgen(colour=False):
|
||||
if not os.path.isdir("build/mastered"):
|
||||
os.mkdir("build/mastered")
|
||||
if colour:
|
||||
if not os.path.isdir("build/mastered/" + colour):
|
||||
os.mkdir("build/mastered/" + colour)
|
||||
thefile = "build/mastered/" + colour + "/index.html"
|
||||
else:
|
||||
thefile = "build/mastered/index.html"
|
||||
if os.path.exists(thefile):
|
||||
os.remove(thefile)
|
||||
skel.headerwrite(thefile,"mastered")
|
||||
content = open(thefile,"a")
|
||||
content.write("<h1>mastered decks</h1>\n")
|
||||
decksofinterest = []
|
||||
for card in tcgcore.ownedcards():
|
||||
if card[0:4] != "sig_":
|
||||
if colour:
|
||||
if tcgcore.cardtype(card) == colour:
|
||||
decksofinterest.append(card[:-2])
|
||||
else:
|
||||
decksofinterest.append(card[:-2])
|
||||
decksofinterest = sorted(list(dict.fromkeys(decksofinterest)))
|
||||
mastereddecks = []
|
||||
for deck in decksofinterest:
|
||||
if tcgcore.deckmastered(deck):
|
||||
mastereddecks.append(deck)
|
||||
content.write(tcgcore.filterwrite("mastered",colour))
|
||||
for deck in mastereddecks:
|
||||
content.write(tcgcore.printdeck(deck))
|
||||
content.close()
|
||||
skel.footerwrite(thefile)
|
||||
|
||||
def masteredall():
|
||||
masteredgen()
|
||||
for type in tcgcore.typelist:
|
||||
masteredgen(type)
|
||||
|
||||
if __name__ == "__main__":
|
||||
masteredall()
|
37
ownedgen.py
37
ownedgen.py
|
@ -1,37 +0,0 @@
|
|||
import datetime,os
|
||||
import log,skel,tcgcore,variables
|
||||
|
||||
def ownedgen(colour=False):
|
||||
if not os.path.isdir("build/owned"):
|
||||
os.mkdir("build/owned")
|
||||
if colour:
|
||||
if not os.path.isdir("build/owned/" + colour):
|
||||
os.mkdir("build/owned/" + colour)
|
||||
thefile = "build/owned/" + colour + "/index.html"
|
||||
else:
|
||||
thefile = "build/owned/index.html"
|
||||
if os.path.exists(thefile):
|
||||
os.remove(thefile)
|
||||
skel.headerwrite(thefile,"owned")
|
||||
content = open(thefile,"a")
|
||||
content.write("<h1>owned cards</h1>\n")
|
||||
content.write(tcgcore.filterwrite("owned",colour))
|
||||
content.write("<p>")
|
||||
for card in tcgcore.ownedcards():
|
||||
if card[0:4] != "sig_":
|
||||
if colour:
|
||||
if tcgcore.cardtype(card) == colour:
|
||||
content.write(tcgcore.printcard(card))
|
||||
else:
|
||||
content.write(tcgcore.printcard(card))
|
||||
content.write("</p>\n")
|
||||
content.close()
|
||||
skel.footerwrite(thefile)
|
||||
|
||||
def ownedall():
|
||||
ownedgen()
|
||||
for type in tcgcore.typelist:
|
||||
ownedgen(type)
|
||||
|
||||
if __name__ == "__main__":
|
||||
ownedall()
|
|
@ -1,37 +0,0 @@
|
|||
import datetime,os
|
||||
import log,skel,tcgcore,variables
|
||||
|
||||
def portfoliosgen(colour=False):
|
||||
if not os.path.isdir("build/portfolios"):
|
||||
os.mkdir("build/portfolios")
|
||||
if colour:
|
||||
if not os.path.isdir("build/portfolios/" + colour):
|
||||
os.mkdir("build/portfolios/" + colour)
|
||||
thefile = "build/portfolios/" + colour + "/index.html"
|
||||
else:
|
||||
thefile = "build/portfolios/index.html"
|
||||
if os.path.exists(thefile):
|
||||
os.remove(thefile)
|
||||
skel.headerwrite(thefile,"portfolios")
|
||||
content = open(thefile,"a")
|
||||
content.write("<h1>portfolios</h1>\n")
|
||||
if len(tcgcore.getpalettes()) + len(tcgcore.getmonochrome()) > 0:
|
||||
if len(tcgcore.getpalettes()) > 0:
|
||||
content.write("<div class=\"foliocase\">\n")
|
||||
portnumber = 1
|
||||
for portfolio in tcgcore.getpalettes():
|
||||
content.write(tcgcore.portfoliogen(portfolio,"palette",portnumber))
|
||||
portnumber += 1
|
||||
content.write("</div>\n")
|
||||
if len(tcgcore.getmonochrome()) > 0:
|
||||
content.write("<div class=\"foliocase\">\n")
|
||||
portnumber = 1
|
||||
for portfolio in tcgcore.getmonochrome():
|
||||
content.write(tcgcore.portfoliogen(portfolio,"monochrome",portnumber))
|
||||
portnumber += 1
|
||||
content.write("</div>\n")
|
||||
content.close()
|
||||
skel.footerwrite(thefile)
|
||||
|
||||
if __name__ == "__main__":
|
||||
portfoliosgen()
|
119
searchgen.py
119
searchgen.py
|
@ -1,119 +0,0 @@
|
|||
import os
|
||||
import skel,tcgcore,variables
|
||||
|
||||
def searchgen():
|
||||
decksofinterest = []
|
||||
for card in tcgcore.ownedcards():
|
||||
if card[0:4] != "sig_":
|
||||
decksofinterest.append(card[:-2])
|
||||
decksofinterest = sorted(list(dict.fromkeys(decksofinterest)))
|
||||
wantedcards = []
|
||||
ownedcollecting = []
|
||||
for deck in decksofinterest:
|
||||
if tcgcore.collecting(deck):
|
||||
wantedlist = ["01","02","03","04","05","06","07","08","09","10","11","12","13","14","15","16","17","18","19","20"]
|
||||
for card in wantedlist:
|
||||
combined = deck + card
|
||||
if combined in tcgcore.ownedcards():
|
||||
ownedcollecting.append(combined)
|
||||
else:
|
||||
wantedcards.append(combined)
|
||||
hpw = []
|
||||
mpw = []
|
||||
lpw = []
|
||||
hpt = []
|
||||
mpt = []
|
||||
lpt = []
|
||||
for card in wantedcards:
|
||||
if tcgcore.priority(card[:-2]) == "high":
|
||||
hpw.append(card)
|
||||
elif tcgcore.priority(card[:-2]) == "medium":
|
||||
mpw.append(card)
|
||||
elif tcgcore.priority(card[:-2]) == "low":
|
||||
lpw.append(card)
|
||||
previouscard = ""
|
||||
for card in tcgcore.ownedcards():
|
||||
if card[0:4] != "sig_":
|
||||
if card == previouscard:
|
||||
lpt.append(card)
|
||||
else:
|
||||
if not tcgcore.deckmastered(card[:-2]):
|
||||
mass = False
|
||||
for series in variables.masscollect:
|
||||
try:
|
||||
if card in variables.masscollect[series]["singles"]:
|
||||
mass = True
|
||||
except:
|
||||
pass
|
||||
if mass == True:
|
||||
if tcgcore.priority(card[:-2]) != "high":
|
||||
hpt.append(card)
|
||||
else:
|
||||
if card in ownedcollecting:
|
||||
if tcgcore.priority(card[:-2]) == "medium":
|
||||
hpt.append(card)
|
||||
elif tcgcore.priority(card[:-2]) == "low":
|
||||
mpt.append(card)
|
||||
else:
|
||||
lpt.append(card)
|
||||
previouscard = card
|
||||
hpw = sorted(list(dict.fromkeys(hpw)))
|
||||
mpw = sorted(list(dict.fromkeys(mpw)))
|
||||
lpw = sorted(list(dict.fromkeys(lpw)))
|
||||
hpt = sorted(list(dict.fromkeys(hpt)))
|
||||
mpt = sorted(list(dict.fromkeys(mpt)))
|
||||
lpt = sorted(list(dict.fromkeys(lpt)))
|
||||
if not os.path.isdir("build/search"):
|
||||
os.mkdir("build/search")
|
||||
thefile = "build/search/index.html"
|
||||
if os.path.exists(thefile):
|
||||
os.remove(thefile)
|
||||
skel.headerwrite(thefile,"search")
|
||||
content = open(thefile,"a")
|
||||
content.write("<h1>card search</h1>\n<form>\n <label for=\"cardinput\">Enter a list of cards and/or decks here:</label>\n <textarea id=\"cardinput\" name=\"cardinput\"></textarea>\n <input type=\"button\" value=\"Search\" onclick=\"searchcards()\">\n</form>\n<p id=\"hpwfound\"></p>\n<p id=\"mpwfound\"></p>\n<p id=\"lpwfound\"></p>\n<p id=\"hptfound\"></p>\n<p id=\"mptfound\"></p>\n<p id=\"lptfound\"></p>\n<p id=\"nothing\"></p>\n<script>\n function searchcards() {\n const thecards = ['01', '02', '03', '04', '05', '06', '07', '08', '09', '10', '11', '12', '13', '14', '15', '16', '17', '18', '19', '20'];\n const hpw = [")
|
||||
precomma = False
|
||||
for card in hpw:
|
||||
if precomma:
|
||||
content.write(", ")
|
||||
content.write("'" + card + "'")
|
||||
precomma = True
|
||||
content.write("];\n const mpw = [")
|
||||
precomma = False
|
||||
for card in mpw:
|
||||
if precomma:
|
||||
content.write(", ")
|
||||
content.write("'" + card + "'")
|
||||
precomma = True
|
||||
content.write("];\n const lpw = [")
|
||||
precomma = False
|
||||
for card in lpw:
|
||||
if precomma:
|
||||
content.write(", ")
|
||||
content.write("'" + card + "'")
|
||||
precomma = True
|
||||
content.write("];\n const hpt = [")
|
||||
precomma = False
|
||||
for card in hpt:
|
||||
if precomma:
|
||||
content.write(", ")
|
||||
content.write("'" + card + "'")
|
||||
precomma = True
|
||||
content.write("];\n const mpt = [")
|
||||
precomma = False
|
||||
for card in mpt:
|
||||
if precomma:
|
||||
content.write(", ")
|
||||
content.write("'" + card + "'")
|
||||
precomma = True
|
||||
content.write("];\n const lpt = [")
|
||||
precomma = False
|
||||
for card in lpt:
|
||||
if precomma:
|
||||
content.write(", ")
|
||||
content.write("'" + card + "'")
|
||||
precomma = True
|
||||
content.write("];\n const searchstring = document.getElementById('cardinput').value;\n const searcharray = searchstring.replaceAll(' ','').replaceAll('\\n',',').replaceAll('\\r',',').toLowerCase().split(',');\n const hpwfound = [];\n const mpwfound = [];\n const lpwfound = [];\n const hptfound = [];\n const mptfound = [];\n const lptfound = [];\n for (const element of searcharray) {\n let cardend = element.substring(element.length, element.length - 2);\n if (!(thecards.includes(cardend))) {\n for (const ending of thecards) {\n searcharray.push(element + ending);\n };\n };\n };\n for (const element of searcharray) {\n if (hpw.includes(element)) {\n hpwfound.push(element);\n } else if (mpw.includes(element)) {\n mpwfound.push(element);\n } else if (lpw.includes(element)) {\n lpwfound.push(element);\n } else if (hpt.includes(element)) {\n hptfound.push(element);\n } else if (mpt.includes(element)) {\n mptfound.push(element);\n } else if (lpt.includes(element)) {\n lptfound.push(element);\n };\n };\n if ((hpwfound.length) > 0) {\n document.getElementById('hpwfound').innerHTML = '<span class=\"sorttitle\">Wanted (high priority):</span> <span class=\"searchresults\">' + hpwfound.join(', ') + '</span>';\n } else {\n document.getElementById('hpwfound').innerHTML = '';\n };\n if ((mpwfound.length) > 0) {\n document.getElementById('mpwfound').innerHTML = '<span class=\"sorttitle\">Wanted (medium priority):</span> <span class=\"searchresults\">' + mpwfound.join(', ') + '</span>';\n } else {\n document.getElementById('mpwfound').innerHTML = '';\n };\n if ((lpwfound.length) > 0) {\n document.getElementById('lpwfound').innerHTML = '<span class=\"sorttitle\">Wanted (low priority):</span> <span class=\"searchresults\">' + lpwfound.join(', ') + '</span>';\n } else {\n document.getElementById('lpwfound').innerHTML = '';\n };\n if ((hptfound.length) > 0) {\n document.getElementById('hptfound').innerHTML = '<span class=\"sorttitle\">Will trade out for <a href=\"/wanted\">high priority cards</a> only:</span> <span class=\"searchresults\">' + hptfound.join(', ') + '</span>';\n } else {\n document.getElementById('hptfound').innerHTML = '';\n };\n if ((mptfound.length) > 0) {\n document.getElementById('mptfound').innerHTML = '<span class=\"sorttitle\">Will trade out for <a href=\"/wanted\">high or medium priority cards</a>:</span> <span class=\"searchresults\">' + mptfound.join(', ') + '</span>';\n } else {\n document.getElementById('mptfound').innerHTML = '';\n };\n if ((lptfound.length) > 0) {\n document.getElementById('lptfound').innerHTML = '<span class=\"sorttitle\">Will trade out for <a href=\"/wanted\">any wanted card</a>:</span> <span class=\"searchresults\">' + lptfound.join(', ') + '</span>';\n } else {\n document.getElementById('lptfound').innerHTML = '';\n };\n if ((hpwfound.length) + (mpwfound.length) + (lpwfound.length) + (hptfound.length) + (mptfound.length) + (lptfound.length) == 0) {\n document.getElementById('nothing').innerHTML = 'No results';\n } else {\n document.getElementById('nothing').innerHTML = '';\n }\n }\n</script>\n </main>\n </body>\n</html>")
|
||||
content.close()
|
||||
|
||||
if __name__ == "__main__":
|
||||
searchgen()
|
2
setup.py
2
setup.py
|
@ -1,7 +1,7 @@
|
|||
import variables
|
||||
|
||||
buildscript = open("build.sh","w")
|
||||
buildscript.write("#!/usr/bin/env bash\n\npython3 generate.py\n\nrclone copy build " + variables.servername + ":" + variables.serverpath + " -P -L")
|
||||
buildscript.write("#!/usr/bin/env bash\n\npython3 new.py\n\nrclone copy build " + variables.servername + ":" + variables.serverpath + " -P -L")
|
||||
buildscript.close()
|
||||
|
||||
if not os.path.exists("build/user.css"):
|
||||
|
|
59
skel.py
59
skel.py
|
@ -1,59 +0,0 @@
|
|||
import variables
|
||||
|
||||
def headerwrite(thefile,pagename):
|
||||
header = open(thefile,"a")
|
||||
header.write("<!DOCTYPE html>\n<html lang=\"en\" style=\"--headbg:" + variables.headerbackground + ";\">\n <head>\n <meta charset=\"UTF-8\">\n <meta name=\"viewport\" content=\"width=device-width, initial-scale=1.0\">\n <link rel=\"stylesheet\" href=\"/style.css\">\n <link rel=\"stylesheet\" href=\"/user.css\">\n <meta name=\"theme-color\" content=\"" + variables.headerbackground + "\">\n <title>" + variables.name + "’s card collection :: " + pagename + "</title>\n </head>\n <body class=\"" + pagename + "\">\n <aside>\n \n </aside>\n <nav>\n <ul>\n <li>")
|
||||
if pagename == "index":
|
||||
header.write("home")
|
||||
else:
|
||||
header.write("<a href=\"/\">home</a>")
|
||||
header.write("</li>\n <li>")
|
||||
if pagename == "collecting":
|
||||
header.write("collecting")
|
||||
else:
|
||||
header.write("<a href=\"/collecting\">collecting</a>")
|
||||
header.write("</li>\n <li>")
|
||||
if pagename == "mass":
|
||||
header.write("mass collecting")
|
||||
else:
|
||||
header.write("<a href=\"/mass\">mass collecting</a>")
|
||||
header.write("</li>\n <li>")
|
||||
if pagename == "mastered":
|
||||
header.write("mastered")
|
||||
else:
|
||||
header.write("<a href=\"/mastered\">mastered</a>")
|
||||
header.write("</li>\n")
|
||||
if variables.ownedpage:
|
||||
header.write(" <li>")
|
||||
if pagename == "owned":
|
||||
header.write("owned")
|
||||
else:
|
||||
header.write("<a href=\"/owned\">owned</a>")
|
||||
header.write("</li>\n")
|
||||
header.write(" <li>")
|
||||
if pagename == "trade":
|
||||
header.write("trading")
|
||||
else:
|
||||
header.write("<a href=\"/trade\">trading</a>")
|
||||
header.write("</li>\n <li>")
|
||||
if pagename == "wanted":
|
||||
header.write("wanted")
|
||||
else:
|
||||
header.write("<a href=\"/wanted\">wanted</a>")
|
||||
header.write("</li>\n <li>")
|
||||
if pagename == "search":
|
||||
header.write("search")
|
||||
else:
|
||||
header.write("<a href=\"/search\">search</a>")
|
||||
header.write("</li>\n <li>")
|
||||
if pagename == "log":
|
||||
header.write("log")
|
||||
else:
|
||||
header.write("<a href=\"/log\">log</a>")
|
||||
header.write("</li>\n <li><a href=\"" + variables.tradepost + "\" target=\"_blank\">trade post @ dw</a></li>\n <li><a href=\"https://colors-tcg.eu/services.php\" target=\"_blank\">service links</a></li>\n </ul>\n </nav>\n <main>\n")
|
||||
header.close()
|
||||
|
||||
def footerwrite(thefile):
|
||||
footer = open(thefile,"a")
|
||||
footer.write(" </main>\n </body>\n</html>")
|
||||
footer.close()
|
425
tcgcore.py
425
tcgcore.py
|
@ -1,425 +0,0 @@
|
|||
import log,variables
|
||||
|
||||
typelist = ["red","orange","yellow","green","blue","purple","brown","gray","special"]
|
||||
|
||||
def ownedcards():
|
||||
ownedcards = []
|
||||
for event in log.log:
|
||||
try:
|
||||
for card in event["received"]:
|
||||
ownedcards.append(card)
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
for card in event["lost"]:
|
||||
ownedcards.remove(card)
|
||||
except:
|
||||
pass
|
||||
return sorted(ownedcards)
|
||||
|
||||
def showdupes():
|
||||
dupeslist = []
|
||||
previouscard = ""
|
||||
for card in ownedcards():
|
||||
if card == previouscard:
|
||||
dupeslist.append(card)
|
||||
previouscard = card
|
||||
return dupeslist
|
||||
|
||||
def deckcards(deck):
|
||||
deckcards = []
|
||||
for card in ownedcards():
|
||||
if card[:-2] == deck:
|
||||
deckcards.append(int(card[-2:]))
|
||||
deckcards = sorted(list(dict.fromkeys(deckcards)))
|
||||
return deckcards
|
||||
|
||||
def deckmastered(deck):
|
||||
if len(deckcards(deck)) == 20:
|
||||
return True
|
||||
else:
|
||||
return False
|
||||
|
||||
def datemastered(deck):
|
||||
if deckmastered(deck):
|
||||
deckdates = []
|
||||
for event in log.log:
|
||||
try:
|
||||
if event["received"]:
|
||||
for card in event["received"]:
|
||||
if card[:-2] == deck:
|
||||
deckdates.append({"card":card,"date":event["date"],"event":"received"})
|
||||
except:
|
||||
pass
|
||||
try:
|
||||
if event["lost"]:
|
||||
for card in event["lost"]:
|
||||
if card[:-2] == deck:
|
||||
deckdates.append({"card":card,"date":event["date"],"event":"lost"})
|
||||
except:
|
||||
pass
|
||||
cards = {1:0,2:0,3:0,4:0,5:0,6:0,7:0,8:0,9:0,10:0,11:0,12:0,13:0,14:0,15:0,16:0,17:0,18:0,19:0,20:0}
|
||||
mastered = False
|
||||
for event in deckdates:
|
||||
if not mastered:
|
||||
if event["event"] == "received":
|
||||
cards[int(event["card"][-2:])] += 1
|
||||
if event["event"] == "lost":
|
||||
cards[int(event["card"][-2:])] -= 1
|
||||
if cards[1] > 0 and cards[2] > 0 and cards[3] > 0 and cards[4] > 0 and cards[5] > 0 and cards[6] > 0 and cards[7] > 0 and cards[8] > 0 and cards[9] > 0 and cards[10] > 0 and cards[11] > 0 and cards[12] > 0 and cards[13] > 0 and cards[14] > 0 and cards[15] > 0 and cards[16] > 0 and cards[17] > 0 and cards[18] > 0 and cards[19] > 0 and cards[20] > 0:
|
||||
mastered = event["date"]
|
||||
return mastered
|
||||
|
||||
medium = []
|
||||
for series in variables.masscollect:
|
||||
try:
|
||||
for deck in variables.masscollect[series]["decks"]:
|
||||
medium.append(deck)
|
||||
except:
|
||||
pass
|
||||
medium = sorted(list(dict.fromkeys(medium)))
|
||||
|
||||
def collecting(deck):
|
||||
if 0 < len (deckcards(deck)) < 20:
|
||||
if deck in variables.highpriority:
|
||||
return True
|
||||
else:
|
||||
portfoliocollecting = False
|
||||
for event in log.log:
|
||||
if portfoliocollecting == False:
|
||||
if event["event"] == "portfolio":
|
||||
if deck in event["decks"]:
|
||||
portfoliocollecting = True
|
||||
return True
|
||||
if portfoliocollecting == False:
|
||||
if deck in medium:
|
||||
return True
|
||||
else:
|
||||
if len(deckcards(deck)) < variables.collectthreshold:
|
||||
return False
|
||||
else:
|
||||
return True
|
||||
else:
|
||||
return False
|
||||
|
||||
def priority(deck):
|
||||
if collecting(deck):
|
||||
if deck in variables.highpriority:
|
||||
return "high"
|
||||
elif len(deckcards(deck)) >= variables.highthreshold:
|
||||
return "high"
|
||||
else:
|
||||
portfoliopriority = False
|
||||
for event in log.log:
|
||||
if portfoliopriority == False:
|
||||
if event["event"] == "portfolio":
|
||||
if deck in event["decks"]:
|
||||
portfoliopriority = True
|
||||
return "high"
|
||||
if portfoliopriority == False:
|
||||
if deck in medium:
|
||||
return "medium"
|
||||
elif len(deckcards(deck)) >= variables.mediumthreshold:
|
||||
return "medium"
|
||||
else:
|
||||
return ("low")
|
||||
|
||||
def cardtype(card):
|
||||
with open("build/decks/" + card[:-2] + "/type") as thetype:
|
||||
cardtype = thetype.read()
|
||||
return(cardtype)
|
||||
|
||||
def cardtext(card):
|
||||
cardtext = "<span class=\"cardname\">"
|
||||
if card[0:4] == "sig_":
|
||||
cardtext += "<span title=\"signature\">✍</span>" + card + "</span>"
|
||||
else:
|
||||
if cardtype(card) == "red":
|
||||
cardtext += "<span title=\"red\">🔴</span>"
|
||||
elif cardtype(card) == "orange":
|
||||
cardtext += "<span title=\"orange\">🟠</span>"
|
||||
elif cardtype(card) == "yellow":
|
||||
cardtext += "<span title=\"yellow\">🟡</span>"
|
||||
elif cardtype(card) == "green":
|
||||
cardtext += "<span title=\"green\">🟢</span>"
|
||||
elif cardtype(card) == "blue":
|
||||
cardtext += "<span title=\"blue\">🔵</span>"
|
||||
elif cardtype(card) == "purple":
|
||||
cardtext += "<span title=\"purple\">🟣</span>"
|
||||
elif cardtype(card) == "brown":
|
||||
cardtext += "<span title=\"brown\">🟤</span>"
|
||||
elif cardtype(card) == "gray":
|
||||
cardtext += "<span title=\""
|
||||
if variables.british:
|
||||
cardtext += "grey"
|
||||
else:
|
||||
cardtext += "gray"
|
||||
cardtext += "\">⚪</span>"
|
||||
elif cardtype(card) == "special":
|
||||
cardtext += "<span title=\"special\">✨</span>"
|
||||
cardtext += card + "</span>"
|
||||
return cardtext
|
||||
|
||||
def printcard(card):
|
||||
if card[0:4] == "sig_":
|
||||
return "<img src=\"/decks/sigs/" + card[4:] + ".gif\" title=\"" + card + "\" loading=\"lazy\">"
|
||||
else:
|
||||
deck = card[:-2]
|
||||
cardid = card[-2:]
|
||||
return "<img src=\"/decks/" + deck + "/" + cardid + ".gif\" title=\"" + card + "\" loading=\"lazy\">"
|
||||
|
||||
def printdeck(deck,fold=True):
|
||||
if fold:
|
||||
deckstring = "<details class=\"deckwrap\">\n<summary>" + deck + " ["
|
||||
if deckmastered(deck):
|
||||
deckstring += datemastered(deck).strftime("%Y-%m-%d")
|
||||
else:
|
||||
deckstring += str(len(deckcards(deck))) + "/20"
|
||||
deckstring += "]</summary>\n"
|
||||
else:
|
||||
deckstring = ""
|
||||
deckstring += "<table class=\"decktable "
|
||||
with open("build/decks/" + deck + "/type") as thetype:
|
||||
decktype = thetype.read()
|
||||
deckstring += decktype + "\">\n"
|
||||
if not fold:
|
||||
deckstring += "<thead>\n <tr>\n <th colspan=\"5\">" + deck + " ["
|
||||
if deckmastered(deck):
|
||||
deckstring += datemastered(deck).strftime("%Y-%m-%d")
|
||||
else:
|
||||
deckstring += str(len(deckcards(deck))) + "/20"
|
||||
deckstring += "]</th>\n </tr>\n</thead>\n"
|
||||
deckstring += "<tbody>\n"
|
||||
test = 1
|
||||
while test < 21:
|
||||
if test % 5 == 1:
|
||||
deckstring += " <tr>\n"
|
||||
deckstring += " <td>"
|
||||
if test in deckcards(deck):
|
||||
if test > 9:
|
||||
deckstring += printcard(deck + str(test))
|
||||
else:
|
||||
deckstring += printcard(deck + "0" + str(test))
|
||||
else:
|
||||
deckstring += "<img src=\"/decks/" + deck + "/00.gif\" loading=\"lazy\">"
|
||||
deckstring += "</td>\n"
|
||||
if test % 5 == 0:
|
||||
deckstring += " </tr>\n"
|
||||
test += 1
|
||||
if deckmastered(deck):
|
||||
deckstring += " <tr>\n <td colspan=\"5\" align=\"center\"><img src=\"/decks/" + deck + "/master.gif\" title=\"mastered " + deck
|
||||
try:
|
||||
if deck in variables.firstmasteries:
|
||||
deckstring += " (first)\" class=\"first"
|
||||
except:
|
||||
pass
|
||||
deckstring += "\"><td>\n</tr>\n"
|
||||
deckstring += "</tbody>\n</table>\n"
|
||||
if fold:
|
||||
deckstring += "</details>\n"
|
||||
return deckstring
|
||||
|
||||
def filterwrite(page,colour=False,sigs=False):
|
||||
filterstring = "<p class=\"typefilter\">"
|
||||
if colour:
|
||||
filterstring += "Filtered to <span class=\"" + colour + "\"><b>"
|
||||
if colour == "gray":
|
||||
if variables.british:
|
||||
filterstring += "grey"
|
||||
else:
|
||||
filterstring += "gray"
|
||||
else:
|
||||
filterstring += colour
|
||||
filterstring += "</b></span>. <a href=\"/" + page + "\">Show all</a>"
|
||||
else:
|
||||
filterstring += "Filter: <a href=\"/" + page + "/red\" title=\"red\">🔴</a> <a href=\"/" + page + "/orange\" title=\"orange\">🟠</a> <a href=\"/" + page + "/yellow\" title=\"yellow\">🟡</a> <a href=\"/" + page + "/green\" title=\"green\">🟢</a> <a href=\"/" + page + "/blue\" title=\"blue\">🔵</a> <a href=\"/" + page + "/purple\" title=\"purple\">🟣</a> <a href=\"/" + page + "/brown\" title=\"brown\">🟤</a> <a href=\"/" + page + "/gray\" title=\""
|
||||
if variables.british:
|
||||
filterstring += "grey"
|
||||
else:
|
||||
filterstring += "gray"
|
||||
filterstring += "\">⚪</a> <a href=\"/" + page + "/special\" title=\"special\">✨</a>"
|
||||
if sigs:
|
||||
filterstring += " <a href=\"/" + page + "/sig\" title=\"sig\">✍</a>"
|
||||
filterstring += "</p>\n"
|
||||
return filterstring
|
||||
|
||||
def getpalettes():
|
||||
palette = []
|
||||
for event in log.log:
|
||||
if event["event"] == "portfolio":
|
||||
if cardtype(event["decks"][0] + "01") != cardtype(event["decks"][1] + "01"):
|
||||
for deck in event["decks"]:
|
||||
event[cardtype(deck + "01")] = deck
|
||||
palette.append(event)
|
||||
return palette
|
||||
|
||||
def getmonochrome():
|
||||
monochrome = []
|
||||
for event in log.log:
|
||||
if event["event"] == "portfolio":
|
||||
if cardtype(event["decks"][0] + "01") == cardtype(event["decks"][1] + "01"):
|
||||
event["colour"] = cardtype(event["decks"][0] + "01")
|
||||
event["decks"] = sorted(event["decks"])
|
||||
monochrome.append(event)
|
||||
return monochrome
|
||||
|
||||
def portfoliogen(portfolio,thetype,portnumber):
|
||||
if thetype == "palette":
|
||||
portstring = "<table class=\"palette portfolio\">\n<tbody>\n<tr>\n<td colspan=\"2\">" + variables.name.lower() + "</td>\n</tr>\n<tr>\n<td class=\"deck1\">"
|
||||
try:
|
||||
if deckmastered(portfolio["red"]):
|
||||
portstring += "■"
|
||||
else:
|
||||
portstring += "□"
|
||||
portstring += " " + portfolio["red"]
|
||||
except:
|
||||
if deckmastered(portfolio["special"]):
|
||||
portstring += "■"
|
||||
else:
|
||||
portstring += "□"
|
||||
portstring += " " + portfolio["special"]
|
||||
portstring += "</td>\n<td class=\"deck5\">"
|
||||
try:
|
||||
if deckmastered(portfolio["blue"]):
|
||||
portstring += "■"
|
||||
else:
|
||||
portstring += "□"
|
||||
portstring += " " + portfolio["blue"]
|
||||
except:
|
||||
if deckmastered(portfolio["special"]):
|
||||
portstring += "■"
|
||||
else:
|
||||
portstring += "□"
|
||||
portstring += " " + portfolio["special"]
|
||||
portstring += "</td>\n</tr>\n<tr>\n<td class=\"deck2\">"
|
||||
try:
|
||||
if deckmastered(portfolio["orange"]):
|
||||
portstring += "■"
|
||||
else:
|
||||
portstring += "□"
|
||||
portstring += " " + portfolio["orange"]
|
||||
except:
|
||||
if deckmastered(portfolio["special"]):
|
||||
portstring += "■"
|
||||
else:
|
||||
portstring += "□"
|
||||
portstring += " " + portfolio["special"]
|
||||
portstring += "</td>\n<td class=\"deck6\">"
|
||||
try:
|
||||
if deckmastered(portfolio["purple"]):
|
||||
portstring += "■"
|
||||
else:
|
||||
portstring += "□"
|
||||
portstring += " " + portfolio["purple"]
|
||||
except:
|
||||
if deckmastered(portfolio["special"]):
|
||||
portstring += "■"
|
||||
else:
|
||||
portstring += "□"
|
||||
portstring += " " + portfolio["special"]
|
||||
portstring += "</td>\n</tr>\n<tr>\n<td class=\"deck3\">"
|
||||
try:
|
||||
if deckmastered(portfolio["yellow"]):
|
||||
portstring += "■"
|
||||
else:
|
||||
portstring += "□"
|
||||
portstring += " " + portfolio["yellow"]
|
||||
except:
|
||||
if deckmastered(portfolio["special"]):
|
||||
portstring += "■"
|
||||
else:
|
||||
portstring += "□"
|
||||
portstring += " " + portfolio["special"]
|
||||
portstring += "</td>\n<td class=\"deck7\">"
|
||||
try:
|
||||
if deckmastered(portfolio["brown"]):
|
||||
portstring += "■"
|
||||
else:
|
||||
portstring += "□"
|
||||
portstring += " " + portfolio["brown"]
|
||||
except:
|
||||
if deckmastered(portfolio["special"]):
|
||||
portstring += "■"
|
||||
else:
|
||||
portstring += "□"
|
||||
portstring += " " + portfolio["special"]
|
||||
portstring += "</td>\n</tr>\n<tr>\n<td class=\"deck4\">"
|
||||
try:
|
||||
if deckmastered(portfolio["green"]):
|
||||
portstring += "■"
|
||||
else:
|
||||
portstring += "□"
|
||||
portstring += " " + portfolio["green"]
|
||||
except:
|
||||
if deckmastered(portfolio["special"]):
|
||||
portstring += "■"
|
||||
else:
|
||||
portstring += "□"
|
||||
portstring += " " + portfolio["special"]
|
||||
portstring += "</td>\n<td class=\"deck8\">"
|
||||
try:
|
||||
if deckmastered(portfolio["gray"]):
|
||||
portstring += "■"
|
||||
else:
|
||||
portstring += "□"
|
||||
portstring += " " + portfolio["gray"]
|
||||
except:
|
||||
if deckmastered(portfolio["special"]):
|
||||
portstring += "■"
|
||||
else:
|
||||
portstring += "□"
|
||||
portstring += " " + portfolio["special"]
|
||||
portstring += "</td>\n</tr>\n<tr>\n<td colspan=\"2\"><a href=\"" + portfolio["url"] + "\">palette portfolio "
|
||||
if portnumber < 10:
|
||||
portstring += "0" + str(portnumber)
|
||||
else:
|
||||
portstring += str(portnumber)
|
||||
portstring += "</a></td>\n</tr>\n</tbody>\n</table>\n"
|
||||
elif thetype == "monochrome":
|
||||
portstring = "<table class=\"" + portfolio["colour"] + " portfolio\">\n<tbody>\n<tr>\n<td colspan=\"2\">" + variables.name.lower() + "</td>\n</tr>\n<tr>\n<td class=\"deck1\">"
|
||||
if deckmastered(portfolio["decks"][0]):
|
||||
portstring += "■"
|
||||
else:
|
||||
portstring += "□"
|
||||
portstring += " " + portfolio["decks"][0] + "</td>\n<td class=\"deck5\">"
|
||||
if deckmastered(portfolio["decks"][4]):
|
||||
portstring += "■"
|
||||
else:
|
||||
portstring += "□"
|
||||
portstring += " " + portfolio["decks"][4] + "</td>\n</tr>\n<tr>\n<td class=\"deck2\">"
|
||||
if deckmastered(portfolio["decks"][1]):
|
||||
portstring += "■"
|
||||
else:
|
||||
portstring += "□"
|
||||
portstring += " " + portfolio["decks"][1] + "</td>\n<td class=\"deck6\">"
|
||||
if deckmastered(portfolio["decks"][5]):
|
||||
portstring += "■"
|
||||
else:
|
||||
portstring += "□"
|
||||
portstring += " " + portfolio["decks"][5] + "</td>\n</tr>\n<tr>\n<td class=\"deck3\">"
|
||||
if deckmastered(portfolio["decks"][2]):
|
||||
portstring += "■"
|
||||
else:
|
||||
portstring += "□"
|
||||
portstring += " " + portfolio["decks"][2] + "</td>\n<td class=\"deck7\">"
|
||||
if deckmastered(portfolio["decks"][6]):
|
||||
portstring += "■"
|
||||
else:
|
||||
portstring += "□"
|
||||
portstring += " " + portfolio["decks"][6] + "</td>\n</tr>\n<tr>\n<td class=\"deck4\">"
|
||||
if deckmastered(portfolio["decks"][3]):
|
||||
portstring += "■"
|
||||
else:
|
||||
portstring += "□"
|
||||
portstring += " " + portfolio["decks"][3] + "</td>\n<td class=\"deck8\">"
|
||||
if deckmastered(portfolio["decks"][7]):
|
||||
portstring += "■"
|
||||
else:
|
||||
portstring += "□"
|
||||
portstring += " " + portfolio["decks"][7] + "</td>\n</tr>\n<tr>\n<td colspan=\"2\"><a href=\"" + portfolio["url"] + "\">monochrome portfolio "
|
||||
if portnumber < 10:
|
||||
portstring += "0" + str(portnumber)
|
||||
else:
|
||||
portstring += str(portnumber)
|
||||
portstring += "</a></td>\n</tr>\n</tbody>\n</table>\n"
|
||||
return portstring
|
14925
thetypes.py
14925
thetypes.py
File diff suppressed because it is too large
Load diff
77
tradegen.py
77
tradegen.py
|
@ -1,77 +0,0 @@
|
|||
import datetime,os
|
||||
import log,skel,tcgcore,variables
|
||||
|
||||
tradelist = []
|
||||
previouscard = ""
|
||||
for card in tcgcore.ownedcards():
|
||||
if card[0:4] != "sig_":
|
||||
if card == previouscard:
|
||||
tradelist.append(card)
|
||||
else:
|
||||
if not tcgcore.deckmastered(card[:-2]):
|
||||
if not tcgcore.collecting(card[:-2]):
|
||||
mass = False
|
||||
for series in variables.masscollect:
|
||||
try:
|
||||
if card in variables.masscollect[series]["singles"]:
|
||||
mass = True
|
||||
except:
|
||||
pass
|
||||
if mass == False:
|
||||
tradelist.append(card)
|
||||
previouscard = card
|
||||
siglist = []
|
||||
for card in tcgcore.ownedcards():
|
||||
if card == "sig_" + variables.name.lower():
|
||||
siglist.append(card)
|
||||
if variables.keepsig == True:
|
||||
if len(siglist) > 0:
|
||||
siglist.remove(siglist[0])
|
||||
|
||||
def tradegen(colour=False):
|
||||
if not os.path.isdir("build/trade"):
|
||||
os.mkdir("build/trade")
|
||||
if colour:
|
||||
if not os.path.isdir("build/trade/" + colour):
|
||||
os.mkdir("build/trade/" + colour)
|
||||
thefile = "build/trade/" + colour + "/index.html"
|
||||
else:
|
||||
thefile = "build/trade/index.html"
|
||||
if os.path.exists(thefile):
|
||||
os.remove(thefile)
|
||||
skel.headerwrite(thefile,"trade")
|
||||
content = open(thefile,"a")
|
||||
content.write("<h1>available for trade</h1>\n")
|
||||
content.write(tcgcore.filterwrite("trade",colour,True) + "<p class=\"tradeterms\">")
|
||||
if len(variables.tradestatement) > 0:
|
||||
content.write(variables.tradestatement + " ")
|
||||
content.write("Trade cards <a href=\"" + variables.tradepost + "\">here</a></p>\n<p>")
|
||||
thetradelist = []
|
||||
if colour:
|
||||
if colour == "sig":
|
||||
for sig in siglist:
|
||||
thetradelist.append(sig)
|
||||
else:
|
||||
for card in tradelist:
|
||||
if tcgcore.cardtype(card) == colour:
|
||||
thetradelist.append(card)
|
||||
else:
|
||||
for card in tradelist:
|
||||
thetradelist.append(card)
|
||||
for sig in siglist:
|
||||
thetradelist.append(sig)
|
||||
content.write("<textarea readonly>" + ", ".join(thetradelist) + "</textarea>\n<p>")
|
||||
for card in thetradelist:
|
||||
content.write(tcgcore.printcard(card))
|
||||
content.write("</p>\n")
|
||||
content.close()
|
||||
skel.footerwrite(thefile)
|
||||
|
||||
def tradeall():
|
||||
tradegen()
|
||||
for type in tcgcore.typelist:
|
||||
tradegen(type)
|
||||
tradegen("sig")
|
||||
|
||||
if __name__ == "__main__":
|
||||
tradeall()
|
65
wantedgen.py
65
wantedgen.py
|
@ -1,65 +0,0 @@
|
|||
import datetime,os
|
||||
import log,variables,skel,tcgcore
|
||||
|
||||
def wantedgen():
|
||||
if not os.path.isdir("build/wanted"):
|
||||
os.mkdir("build/wanted")
|
||||
if os.path.exists("build/wanted/index.html"):
|
||||
os.remove("build/wanted/index.html")
|
||||
thefile = "build/wanted/index.html"
|
||||
skel.headerwrite(thefile,"wanted")
|
||||
content = open(thefile,"a")
|
||||
content.write("<h1>wanted cards</h1>\n")
|
||||
decksofinterest = []
|
||||
for card in tcgcore.ownedcards():
|
||||
if card[0:4] != "sig_":
|
||||
decksofinterest.append(card[:-2])
|
||||
decksofinterest = sorted(list(dict.fromkeys(decksofinterest)))
|
||||
highpriority = []
|
||||
medpriority = []
|
||||
lowpriority = []
|
||||
for deck in decksofinterest:
|
||||
if tcgcore.collecting(deck):
|
||||
wantedlist = ["01","02","03","04","05","06","07","08","09","10","11","12","13","14","15","16","17","18","19","20"]
|
||||
for card in wantedlist:
|
||||
combined = deck + card
|
||||
if combined not in tcgcore.ownedcards():
|
||||
if tcgcore.priority(deck) == "high":
|
||||
highpriority.append(combined)
|
||||
elif tcgcore.priority(deck) == "medium":
|
||||
medpriority.append(combined)
|
||||
elif tcgcore.priority(deck) == "low":
|
||||
lowpriority.append(combined)
|
||||
if len(highpriority) > 0:
|
||||
content.write("<h2>High priority</h2>\n<textarea readonly>" + ", ".join(highpriority) + "</textarea>\n<p>")
|
||||
for card in highpriority:
|
||||
content.write(tcgcore.cardtext(card))
|
||||
if highpriority.index(card) == len(highpriority) - 1:
|
||||
content.write(" ")
|
||||
else:
|
||||
content.write(", ")
|
||||
content.write("</p>\n")
|
||||
if len(medpriority) > 0:
|
||||
content.write("<h2>Medium priority</h2>\n<textarea readonly>" + ", ".join(medpriority) + "</textarea>\n<p>")
|
||||
for card in medpriority:
|
||||
content.write(tcgcore.cardtext(card))
|
||||
if medpriority.index(card) == len(medpriority) - 1:
|
||||
content.write(" ")
|
||||
else:
|
||||
content.write(", ")
|
||||
content.write("</p>\n")
|
||||
if len(lowpriority) > 0:
|
||||
content.write("<h2>Low priority</h2>\n<textarea readonly>" + ", ".join(lowpriority) + "</textarea>\n<p>")
|
||||
for card in lowpriority:
|
||||
content.write(tcgcore.cardtext(card))
|
||||
if lowpriority.index(card) == len(lowpriority) - 1:
|
||||
content.write(" ")
|
||||
else:
|
||||
content.write(", ")
|
||||
content.write("</p>\n")
|
||||
content.write("<p>I’m probably also interested in anything I’m <a href=\"/mass\">mass collecting</a>.</p>\n")
|
||||
content.close()
|
||||
skel.footerwrite(thefile)
|
||||
|
||||
if __name__ == "__main__":
|
||||
wantedgen()
|
Loading…
Add table
Add a link
Reference in a new issue