diff --git a/app/app.py b/app/app.py
index 87a3aec..09aa5d8 100644
--- a/app/app.py
+++ b/app/app.py
@@ -12,18 +12,29 @@ st.set_page_config(
# the same favicon and if posting links for example in whatsapp they will have the same title
page_title="tebarius Mysteryhelfer (web)",
page_icon="images/favicon.ico",
- layout="wide"
+ layout="wide",
+ menu_items={
+ 'About': '### tebarius Mysteryhelfer (web)\n'
+ 'Dies ist die Umsetzung der [Desktop-App Mysteryhelfer](https://mysteryhelfer.tebarius.duckdns.org/) '
+ '([Source](https://gitea.tebarius.duckdns.org/tebarius/Mysteryhelfer)) als Web-App. \n \n'
+ 'Für die Umsetzung kommt das Python-Framework [Streamlit](https://streamlit.io/) zum Einsatz. \n \n'
+ '_Der Sourcecode und Docker-Images zum selbst hosten sind auf_ '
+ '_https://gitea.tebarius.duckdns.org/tebarius/Mysteryhelfer-web verfügbar._ \n \n'
+ 'Anregungen, Hinweise, Fehlerreports gerne an: '
+ '[tba@gmx.li](mailto:tba@gmx.li?subject=Mysteryhelfer-web) oder über einen Logeintrag beim '
+ '[App-TB](https://www.geocaching.com/track/details.aspx?tracker=arx57k) '
+ '(trackbar auf geocaching.com).',
+ }
)
-st.logo('images/logo.png', size='large')
+st.logo('images/logo.png', size='large', link='https://gitea.tebarius.duckdns.org/tebarius/Mysteryhelfer-web')
logo_col, title_col = st.columns([1,4])
with logo_col:
- st.markdown(f''
+ st.markdown(f''
f'
'
- f'
'
+ f'{base64.b64encode(open("images/logo-mit-tb.png", "rb").read()).decode()}" '
+ f'width="150" style="border-radius: 10px;">'
f'',
unsafe_allow_html=True)
with title_col:
@@ -36,228 +47,229 @@ def auswahl_verarbeiten():
if auswahl == "Wähle eine Funktion":
st.session_state.output_text = standard_output
st.session_state.map_data = None
- elif auswahl == "Cesarchiffre (all)":
+ elif "Cesarchiffre (all)" in auswahl:
st.session_state.output_text = tools.cesar_all(text)
st.session_state.map_data = None
- elif auswahl == "BW,BWW,... ermitteln":
+ elif "BW,BWW,... ermitteln" in auswahl:
st.session_state.output_text = tools.buchstabenwortwert(text)
st.session_state.map_data = None
- elif auswahl == "Buchstabenwert->Text":
+ elif "Buchstabenwert -> Text" in auswahl:
st.session_state.output_text = tools.buchstabenwert_zu_text(text)
st.session_state.map_data = None
- elif auswahl == "Zeichenzählen":
+ elif "Zeichenzählen" in auswahl:
st.session_state.output_text = tools.zeichenanzahl(text)
st.session_state.map_data = None
- elif auswahl == "Text rückwärts":
+ elif "Text rückwärts" in auswahl:
st.session_state.output_text = tools.zeichenkette_reverse(text)
st.session_state.map_data = None
- elif auswahl == "Quersumme(n)":
+ elif "Quersumme(n)" in auswahl:
st.session_state.output_text = tools.quersummen(text)
st.session_state.map_data = None
- elif auswahl == "Einschlüsse zählen":
+ elif "Einschlüsse zählen" in auswahl:
st.session_state.output_text = tools.einschluss_count(text)
st.session_state.map_data = None
- elif auswahl == "ABC -> Morse":
+ elif "ABC -> Morse" in auswahl:
st.session_state.output_text = tools.abc_to_morse(text)
st.session_state.map_data = None
- elif auswahl == "Morse -> ABC":
+ elif "Morse -> ABC" in auswahl:
st.session_state.output_text = tools.morse_to_abc(text)
st.session_state.map_data = None
- elif auswahl == "ROT5":
+ elif "ROT5" in auswahl:
st.session_state.output_text = tools.rot5(text)
st.session_state.map_data = None
- elif auswahl == "ROT13":
+ elif "ROT13" in auswahl:
st.session_state.output_text = tools.rot13(text)
st.session_state.map_data = None
- elif auswahl == "ROT18":
+ elif "ROT18" in auswahl:
st.session_state.output_text = tools.rot18(text)
st.session_state.map_data = None
- elif auswahl == "ROT47":
+ elif "ROT47" in auswahl:
st.session_state.output_text = tools.rot47(text)
st.session_state.map_data = None
- elif auswahl == "ASCII-Text->HEX":
+ elif "ASCII-Text -> HEX" in auswahl:
st.session_state.output_text = tools.ascii_to_hex(text)
st.session_state.map_data = None
- elif auswahl == "ASCII-Text->DEZ":
+ elif "ASCII-Text -> DEZ" in auswahl:
st.session_state.output_text = tools.ascii_to_dez(text)
st.session_state.map_data = None
- elif auswahl == "ASCII-Text->Octal":
+ elif "ASCII-Text -> Octal" in auswahl:
st.session_state.output_text = tools.ascii_to_octal(text)
st.session_state.map_data = None
- elif auswahl == "ASCII-Text->BIN (16bit)":
+ elif "ASCII-Text -> BIN (16bit)" in auswahl:
st.session_state.output_text = tools.ascii_to_bin16(text)
st.session_state.map_data = None
- elif auswahl == "ASCII-Text->BIN (8bit)":
+ elif "ASCII-Text -> BIN (8bit)" in auswahl:
st.session_state.output_text = tools.ascii_to_bin8(text)
st.session_state.map_data = None
- elif auswahl == "HEX->ASCII-Text":
+ elif "HEX -> ASCII-Text" in auswahl:
st.session_state.output_text = tools.hex_to_ascii(text)
st.session_state.map_data = None
- elif auswahl == "DEZ->ASCII-Text":
+ elif "DEZ -> ASCII-Text" in auswahl:
st.session_state.output_text = tools.dez_to_ascii(text)
st.session_state.map_data = None
- elif auswahl == "Octal->ASCII-Text":
+ elif "Octal -> ASCII-Text" in auswahl:
st.session_state.output_text = tools.octal_to_ascii(text)
st.session_state.map_data = None
- elif auswahl == "BIN->ASCII-Text":
+ elif "BIN -> ASCII-Text" in auswahl:
st.session_state.output_text = tools.bin_to_ascii(text)
st.session_state.map_data = None
- elif auswahl == "Zahlwortsuche-DE (0-12)":
+ elif "Zahlwortsuche-DE (0-12)" in auswahl:
st.session_state.output_text = tools.zahlwortsuche_de(text)
st.session_state.map_data = None
- elif auswahl == "Zahlwortsuche-EN (0-15)":
+ elif "Zahlwortsuche-EN (0-15)" in auswahl:
st.session_state.output_text = tools.zahlwortsuche_en(text)
st.session_state.map_data = None
- elif auswahl == "KENNYspeak kodieren":
+ elif "KENNYspeak kodieren" in auswahl:
st.session_state.output_text = tools.kenny_kodieren(text)
st.session_state.map_data = None
- elif auswahl == "KENNYspeak dekodieren":
+ elif "KENNYspeak dekodieren" in auswahl:
st.session_state.output_text = tools.kenny_dekodieren(text)
st.session_state.map_data = None
- elif auswahl == "KENNYspeak raten":
+ elif "KENNYspeak raten" in auswahl:
st.session_state.output_text = tools.kenny_raten(text)
st.session_state.map_data = None
- elif auswahl == "Primz.Alpha dekodieren":
+ elif "Primz.Alpha dekodieren" in auswahl:
st.session_state.output_text = tools.primzahlalphabet_dekodieren(text)
st.session_state.map_data = None
- elif auswahl == "ist (n.te) Primzahl?":
+ elif "ist (n.te) Primzahl?" in auswahl:
st.session_state.output_text = tools.primzahlpruefen(text)
st.session_state.map_data = None
- elif auswahl == "zeige n.te Primzahl":
+ elif "zeige n.te Primzahl" in auswahl:
st.session_state.output_text = tools.nte_primzahl(text)
st.session_state.map_data = None
- elif auswahl == "Primfaktorenzerlegung":
+ elif "Primfaktorenzerlegung" in auswahl:
st.session_state.output_text = tools.primfaktoren(text)
st.session_state.map_data = None
- elif auswahl == "HEX -> DEZ,OCT,BIN":
+ elif "HEX -> DEZ,OCT,BIN" in auswahl:
st.session_state.output_text = tools.hex_to_dez_oct_bin(text)
st.session_state.map_data = None
- elif auswahl == "DEZ -> HEX,OCT,BIN":
+ elif "DEZ -> HEX,OCT,BIN" in auswahl:
st.session_state.output_text = tools.dez_to_hex_oct_bin(text)
st.session_state.map_data = None
- elif auswahl == "OCT -> HEX,DEZ,BIN":
+ elif "OCT -> HEX,DEZ,BIN" in auswahl:
st.session_state.output_text = tools.oct_to_hex_dez_bin(text)
st.session_state.map_data = None
- elif auswahl == "BIN -> HEX,DEZ,OCT":
+ elif "BIN -> HEX,DEZ,OCT" in auswahl:
st.session_state.output_text = tools.bin_to_hex_dez_oct(text)
st.session_state.map_data = None
- elif auswahl == "Text->Tomtom":
+ elif "Text -> Tomtom" in auswahl:
st.session_state.output_text = tools.abc_to_tomtom(text)
st.session_state.map_data = None
- elif auswahl == "Tomtom->Text":
+ elif "Tomtom -> Text" in auswahl:
st.session_state.output_text = tools.tomtom_to_abc(text)
st.session_state.map_data = None
- elif auswahl == "Text->Slash and Pipe":
+ elif "Text -> Slash and Pipe" in auswahl:
st.session_state.output_text = tools.text_to_slashpipe(text)
st.session_state.map_data = None
- elif auswahl == "Slash and Pipe->Text":
+ elif "Slash and Pipe -> Text" in auswahl:
st.session_state.output_text = tools.slashpipe_to_text(text)
st.session_state.map_data = None
- elif auswahl == "PSE: O.zahl<->Symbol":
+ elif "PSE: O.zahl <-> Symbol" in auswahl:
st.session_state.output_text = tools.periodensystem(text)
st.session_state.map_data = None
- elif auswahl == "Nak-Nak -> Text":
+ elif "Nak-Nak -> Text" in auswahl:
st.session_state.output_text = tools.naknak_to_text(text)
st.session_state.map_data = None
- elif auswahl == "Navajo -> Text":
+ elif "Navajo -> Text" in auswahl:
st.session_state.output_text = tools.navajo_to_text(text)
st.session_state.map_data = None
- elif auswahl == "Kreiszahl PI":
+ elif "Kreiszahl PI" in auswahl:
st.session_state.output_text = tools.pi_suche(text)
st.session_state.map_data = None
- elif auswahl == "Eulersche Zahl":
+ elif "Eulersche Zahl" in auswahl:
st.session_state.output_text = tools.euler_suche(text)
st.session_state.map_data = None
- elif auswahl == "phi (goldener Schnitt)":
+ elif "phi (goldener Schnitt)" in auswahl:
st.session_state.output_text = tools.goldener_schnitt_suche(text)
st.session_state.map_data = None
- elif auswahl == "Anagrammsuche-DE":
+ elif "Anagrammsuche-DE" in auswahl:
st.session_state.output_text = tools.anagramm_suche_de(text)
st.session_state.map_data = None
- elif auswahl == "Anagrammsuche-EN":
+ elif "Anagrammsuche-EN" in auswahl:
st.session_state.output_text = tools.anagramm_suche_en(text)
st.session_state.map_data = None
- elif auswahl == "Wortsuche-DE":
+ elif "Wortsuche-DE" in auswahl:
st.session_state.output_text = tools.wortsuche_de(text)
st.session_state.map_data = None
- elif auswahl == "Wortsuche-EN":
+ elif "Wortsuche-EN" in auswahl:
st.session_state.output_text = tools.wortsuche_en(text)
st.session_state.map_data = None
- elif auswahl == "Re-Morse-DE":
+ elif "Re-Morse-DE" in auswahl:
st.session_state.output_text = tools.remorse_de(text)
st.session_state.map_data = None
- elif auswahl == "Re-Morse-EN":
+ elif "Re-Morse-EN" in auswahl:
st.session_state.output_text = tools.remorse_en(text)
st.session_state.map_data = None
- elif auswahl == "T9-DE dekodieren":
+ elif "T9-DE dekodieren" in auswahl:
st.session_state.output_text = tools.t9_de(text)
st.session_state.map_data = None
- elif auswahl == "T9-EN dekodieren":
+ elif "T9-EN dekodieren" in auswahl:
st.session_state.output_text = tools.t9_en(text)
st.session_state.map_data = None
- elif auswahl == "Vigenere-Chiffre":
+ elif "Vigenere-Chiffre" in auswahl:
st.session_state.output_text = tools.vigenere(text, additional_parameter)
st.session_state.map_data = None
- elif auswahl == "Wolseley-Chiffre":
+ elif "Wolseley-Chiffre" in auswahl:
st.session_state.output_text = tools.wolseley(text, additional_parameter)
st.session_state.map_data = None
- elif auswahl == "Mono.-Substitution":
+ elif "Mono.-Substitution" in auswahl:
st.session_state.output_text = tools.monoalphasubstitution(text, additional_parameter)
st.session_state.map_data = None
- elif auswahl == "Autokey-Chiffre":
+ elif "Autokey-Chiffre" in auswahl:
st.session_state.output_text = tools.autokey(text, additional_parameter)
st.session_state.map_data = None
- elif auswahl == "Polybios kodieren":
+ elif "Polybios kodieren" in auswahl:
st.session_state.output_text = tools.polybios_encode(text, additional_parameter)
st.session_state.map_data = None
- elif auswahl == "Polybios dekodieren":
+ elif "Polybios dekodieren" in auswahl:
st.session_state.output_text = tools.polybios_decode(text, additional_parameter)
st.session_state.map_data = None
- elif auswahl == "Klopfcode kodieren":
+ elif "Klopfcode kodieren" in auswahl:
st.session_state.output_text = tools.klopfcode_encode(text)
st.session_state.map_data = None
- elif auswahl == "Klopfcode dekodieren":
+ elif "Klopfcode dekodieren" in auswahl:
st.session_state.output_text = tools.klopfcode_decode(text)
st.session_state.map_data = None
- elif auswahl == "Maptiles/Kachelkoord.":
+ elif "Maptiles/Kachelkoord." in auswahl:
output, mapd = tools.maptiles_kachelkoordinaten(text)
st.session_state.output_text = output
st.session_state.map_data = mapd
- elif auswahl == "Quadtree/Quadkey":
+ elif "Quadtree/Quadkey" in auswahl:
output, mapd = tools.quadtree_koordinaten(text)
st.session_state.output_text = output
st.session_state.map_data = mapd
- elif auswahl == "Chronogramm":
+ elif "Chronogramm" in auswahl:
st.session_state.output_text = tools.chronogramm(text)
st.session_state.map_data = None
- elif auswahl == "Zahl röm.<->arabisch":
+ elif "Zahl röm. <-> arabisch" in auswahl:
st.session_state.output_text = tools.zahlen_roemisch_arabisch_umwandeln(text)
st.session_state.map_data = None
- elif auswahl == "URL decode":
+ elif "URL decode" in auswahl:
st.session_state.output_text = tools.url_decode(text)
st.session_state.map_data = None
- elif auswahl == "Reverse-Wherigo":
- st.session_state.output_text = tools.reversewig(text)
- st.session_state.map_data = None
- elif auswahl == "Base64<->ASCII":
+ elif "Reverse-Wherigo" in auswahl:
+ output, mapd = tools.reversewig(text)
+ st.session_state.output_text = output
+ st.session_state.map_data = mapd
+ elif "Base64 <-> ASCII" in auswahl:
st.session_state.output_text = tools.base64_ascii(text)
st.session_state.map_data = None
- elif auswahl == "Jägerzaun kodieren":
+ elif "Jägerzaun kodieren" in auswahl:
st.session_state.output_text = tools.jaegerzaun_encrypt(text, additional_parameter)
st.session_state.map_data = None
- elif auswahl == "Jägerzaun dekodieren":
+ elif "Jägerzaun dekodieren" in auswahl:
st.session_state.output_text = tools.jaegerzaun_decrypt(text, additional_parameter)
st.session_state.map_data = None
- elif auswahl == "ADFGX kodieren":
+ elif "ADFGX kodieren" in auswahl:
st.session_state.output_text = tools.adfgx_kodieren(text, additional_parameter)
st.session_state.map_data = None
- elif auswahl == "ADFGX dekodieren":
+ elif "ADFGX dekodieren" in auswahl:
st.session_state.output_text = tools.adfgx_dekodieren(text, additional_parameter)
st.session_state.map_data = None
- elif auswahl == "ADFGVX kodieren":
+ elif "ADFGVX kodieren" in auswahl:
st.session_state.output_text = tools.adfgvx_kodieren(text, additional_parameter)
st.session_state.map_data = None
- elif auswahl == "ADFGVX dekodieren":
+ elif "ADFGVX dekodieren" in auswahl:
st.session_state.output_text = tools.adfgvx_dekodieren(text, additional_parameter)
st.session_state.map_data = None
@@ -279,80 +291,85 @@ input_text = st.text_area('Gib deinen Text hier ein und wähle eine Funktion im
# --- Sidebar: Buttons selektieren und Aktion setzen ---
option = st.sidebar.radio("hidden_label",
+ # :color[text to be colored] -> ex.: blue[my text]
+ # supported colors: blue, green, orange, red, violet, gray/grey, rainbow, or primary
+
+ # :color-badge[text in the badge] -> ex.: blue-badge[my text]
+ # blue, green, orange, red, violet, gray/grey, or primary
options=("Wähle eine Funktion",
- "Cesarchiffre (all)",
- "BW,BWW,... ermitteln",
- "Buchstabenwert->Text",
- "Zeichenzählen",
- "Text rückwärts",
- "Quersumme(n)",
- "Einschlüsse zählen",
- "ABC -> Morse",
- "Morse -> ABC",
- "ROT5",
- "ROT13",
- "ROT18",
- "ROT47",
- "ASCII-Text->HEX",
- "ASCII-Text->DEZ",
- "ASCII-Text->Octal",
- "ASCII-Text->BIN (16bit)",
- "ASCII-Text->BIN (8bit)",
- "HEX->ASCII-Text",
- "DEZ->ASCII-Text",
- "Octal->ASCII-Text",
- "Zahlwortsuche-DE (0-12)",
- "Zahlwortsuche-EN (0-15)",
- "KENNYspeak kodieren",
- "KENNYspeak dekodieren",
- "KENNYspeak raten",
- "Primz.Alpha dekodieren",
- "ist (n.te) Primzahl?",
- "zeige n.te Primzahl",
- "Primfaktorenzerlegung",
- "HEX -> DEZ,OCT,BIN",
- "DEZ -> HEX,OCT,BIN",
- "OCT -> HEX,DEZ,BIN",
- "BIN -> HEX,DEZ,OCT",
- "Text->Tomtom",
- "Tomtom->Text",
- "Text->Slash and Pipe",
- "Slash and Pipe->Text",
- "PSE: O.zahl<->Symbol",
- "Nak-Nak -> Text",
- "Navajo -> Text",
- "Kreiszahl PI",
- "Eulersche Zahl",
- "phi (goldener Schnitt)",
- "Anagrammsuche-DE",
- "Anagrammsuche-EN",
- "Wortsuche-DE",
- "Wortsuche-EN",
- "Re-Morse-DE",
- "Re-Morse-EN",
- "T9-DE dekodieren",
- "T9-EN dekodieren",
- "Vigenere-Chiffre",
- "Wolseley-Chiffre",
- "Mono.-Substitution",
- "Autokey-Chiffre",
- "Polybios kodieren",
- "Polybios dekodieren",
- "Klopfcode kodieren",
- "Klopfcode dekodieren",
- "Maptiles/Kachelkoord.",
- "Quadtree/Quadkey",
- "Chronogramm",
- "Zahl röm.<->arabisch",
- "URL decode",
- "Reverse-Wherigo",
- "Base64<->ASCII",
- "Jägerzaun kodieren",
- "Jägerzaun dekodieren",
- "ADFGX kodieren",
- "ADFGX dekodieren",
- "ADFGVX kodieren",
- "ADFGVX dekodieren",
+ ":orange[Cesarchiffre (all)]",
+ ":orange[BW,BWW,... ermitteln]",
+ ":blue[Buchstabenwert -> Text]",
+ ":orange[Zeichenzählen]",
+ ":orange[Text rückwärts]",
+ ":blue[Quersumme(n)]",
+ ":orange[Einschlüsse zählen]",
+ ":green[ABC -> Morse]",
+ ":green[Morse -> ABC]",
+ ":green[ROT5]",
+ ":green[ROT13]",
+ ":green[ROT18]",
+ ":green[ROT47]",
+ ":orange[ASCII-Text -> HEX]",
+ ":orange[ASCII-Text -> DEZ]",
+ ":orange[ASCII-Text -> Octal]",
+ ":orange[ASCII-Text -> BIN (16bit)]",
+ ":orange[ASCII-Text -> BIN (8bit)]",
+ ":blue[HEX -> ASCII-Text]",
+ ":blue[DEZ -> ASCII-Text]",
+ ":blue[Octal -> ASCII-Text]",
+ ":orange-badge[Zahlwortsuche-DE (0-12)]",
+ ":orange-badge[Zahlwortsuche-EN (0-15)]",
+ ":green[KENNYspeak kodieren]",
+ ":green[KENNYspeak dekodieren]",
+ ":green-badge[KENNYspeak raten]",
+ ":green[Primz.Alpha dekodieren]",
+ ":blue[ist (n.te) Primzahl?]",
+ ":blue[zeige n.te Primzahl]",
+ ":blue[Primfaktorenzerlegung]",
+ ":blue[HEX -> DEZ,OCT,BIN]",
+ ":blue[DEZ -> HEX,OCT,BIN]",
+ ":blue[OCT -> HEX,DEZ,BIN]",
+ ":blue[BIN -> HEX,DEZ,OCT]",
+ ":green[Text -> Tomtom]",
+ ":green[Tomtom -> Text]",
+ ":green[Text -> Slash and Pipe]",
+ ":green[Slash and Pipe -> Text]",
+ ":green[PSE: O.zahl <-> Symbol]",
+ ":green[Nak-Nak -> Text]",
+ ":green[Navajo -> Text]",
+ ":blue[Kreiszahl PI]",
+ ":blue[Eulersche Zahl]",
+ ":blue[phi (goldener Schnitt)]",
+ ":orange-badge[Anagrammsuche-DE]",
+ ":orange-badge[Anagrammsuche-EN]",
+ ":orange-badge[Wortsuche-DE]",
+ ":orange-badge[Wortsuche-EN]",
+ ":green-badge[Re-Morse-DE]",
+ ":green-badge[Re-Morse-EN]",
+ ":green-badge[T9-DE dekodieren]",
+ ":green-badge[T9-EN dekodieren]",
+ ":green[Vigenere-Chiffre]",
+ ":green[Wolseley-Chiffre]",
+ ":green[Mono.-Substitution]",
+ ":green[Autokey-Chiffre]",
+ ":green[Polybios kodieren]",
+ ":green[Polybios dekodieren]",
+ ":green[Klopfcode kodieren]",
+ ":green[Klopfcode dekodieren]",
+ ":violet[Maptiles/Kachelkoord.]",
+ ":violet[Quadtree/Quadkey]",
+ ":orange[Chronogramm]",
+ ":blue[Zahl röm. <-> arabisch]",
+ ":orange[URL decode]",
+ ":violet[Reverse-Wherigo]",
+ ":green[Base64 <-> ASCII]",
+ ":green[Jägerzaun kodieren]",
+ ":green[Jägerzaun dekodieren]",
+ ":green[ADFGX kodieren]",
+ ":green[ADFGX dekodieren]",
+ ":green[ADFGVX kodieren]",
+ ":green[ADFGVX dekodieren]",
),
key='option',
on_change=auswahl_verarbeiten,
diff --git a/app/hilfetexte.py b/app/hilfetexte.py
index 10cfc3d..9fee15c 100644
--- a/app/hilfetexte.py
+++ b/app/hilfetexte.py
@@ -517,8 +517,9 @@ reversewig = ('### Reverse Wherigo zu Koordinaten\n'
' Leider??? Ja leider denn das führt auch dazu, das es inzwischen so extrem viele dieser '
'Reverse-Wherigos gibt wo sich die Owner anscheinend auch denken "Die spielt doch sowieso keiner '
'mehr normal..." anders kann ich mir ganze Trails mit Reverse-Wherigos nicht erklären. Um die '
- 'Funktion zu nutzen braucht man nur die 3 Zahlen durch ein entsprechendes Trennzeichen: '
- '| , _ / ; , oder Leerzeichen eingeben und auf den Knopp klicken und bekommt Koordinaten.')
+ 'Funktion zu nutzen braucht man nur die 3 Zahlen getrennt durch ein entsprechendes Trennzeichen: '
+ '| , _ / ; , oder Leerzeichen eingeben und auf den Knopp klicken und bekommt Koordinaten und eine '
+ 'ungefähre Vorschau auf einer Karte.')
base64_ascii = ('### Base64 <-> ASCII\n'
'Base64 ist ein Kodierungsverfahren, welches dazu verwendet wird um beliebige Binärdaten nur Hilfe '
diff --git a/app/images/gitea.png b/app/images/gitea.png
deleted file mode 100644
index dfd2125..0000000
Binary files a/app/images/gitea.png and /dev/null differ
diff --git a/app/tools.py b/app/tools.py
index 27b4e7e..4bc8fd5 100644
--- a/app/tools.py
+++ b/app/tools.py
@@ -2209,7 +2209,7 @@ def reversewig(eingabetext):
seperator = ("|,", "_", "/", ";", ",")
eingabetext = eingabetext.rstrip()
if eingabetext == "":
- return hilfetexte.reversewig
+ return hilfetexte.reversewig, None
else:
se = ""
for s in seperator:
@@ -2218,26 +2218,26 @@ def reversewig(eingabetext):
if se == "" and " " in eingabetext:
se = " "
if se == "":
- return "Keine gültiges Trennzeichen (, ; / _ | oder Leerzeichen) erkannt!"
+ return ":red[Keine gültiges Trennzeichen (, ; / _ | oder Leerzeichen) erkannt!]" , None
else:
txt = eingabetext.split(se)
if len(txt) == 3:
- ausgabetext = ""
- error = 0
for z in txt:
try:
int(z)
except ValueError:
- ausgabetext += "Bitte die Eingabezahlen überprüfen \n"
- error += 1
- if error == 0:
- final = helper.rwig_to_coords(txt[0], txt[1], txt[2])
- ausgabetext += "WIG: " + txt[0] + ", " + txt[1] + ", " + txt[2] + " \n"
- ausgabetext += "DEC: " + str(final[0]) + " " + str(final[1]) + " \n"
- ausgabetext += "DEG: " + helper.dec_to_deg(final[0], final[1]) + " \n"
- return ausgabetext
+ return ":red[Bitte die Eingabezahlen überprüfen!]", None
+ la, lo = helper.rwig_to_coords(txt[0], txt[1], txt[2])
+ if (not la < -85.05113 and not la > 85.05113 and not lo < -180 and not lo > 180 and
+ not (la == 0 and lo == 0)):
+ ausgabetext = f":blue[WIG:] {txt[0]}, {txt[1]}, {txt[2]} \n"
+ ausgabetext += f":blue[DEC:] {round(la, 5)} {round(lo, 5)} \n"
+ ausgabetext += f":blue[DEG:] {helper.dec_to_deg(la, lo)} \n"
+ return ausgabetext, pd.DataFrame({'lat': [la], 'lon': [lo]})
+ else:
+ return f":red[Die Zahlen ergeben keine sinnvolle Koordinate!!! {la, lo}]", None
else:
- return "Es wurden nicht 3 Zahlen erkannt. \n"
+ return ":red[Es wurden nicht 3 Zahlen erkannt.]", None
def base64_ascii(eingabetext):
eingabetext = eingabetext.rstrip()
diff --git a/readme.md b/readme.md
index 02a1a33..5b8633e 100644
--- a/readme.md
+++ b/readme.md
@@ -4,7 +4,7 @@ Dies ist die Umsetzung der [Desktop-App Mysteryhelfer](https://mysteryhelfer.teb
Für die Umsetzung kommt das Python-Framework [Streamlit](https://streamlit.io/) zum Einsatz, durch welches es mir möglich war, dieselben Funktionen zu implementieren wie sie für die Desktop-App genutzt werden. (Für die Funktionen war hier primär nur die Ausgabe anzupassen.)
-Der einfachst Weg, um die App lokal laufen zu lassen, ist mit Docker, wobei ich hier mal 3 Möglichkeiten aufzeige:
+Der einfachst Weg, um die App lokal laufen zu lassen, ist mit Docker, wobei ich hier mal 3 Möglichkeiten aufzeigen (_das vorgebaute Image ist als Multi-Arch-Image für linux/amd64,linux/arm64 gebaut und sollte somit z.B. auch auf Mac's und neueren Raspberry's mit 64 bit Betriebssystem laufen_):
1. mit vorgebautem Image:
- `docker run --rm -d -p 8501:8501 gitea.tebarius.duckdns.org/tebarius/mysteryhelfer`