import pandas as pd
import streamlit as st
from utils import df_to_html, render_svg, combine_json_files, render_metadata
data = combine_json_files('./languages')
@st.cache_data
def render_home_table():
"""Renders home table."""
# Compute number of unique domains/urls
for key in data.keys():
data[key]['Number of Sites'] = len(data[key].get('Sites', []))
data[key]["Number of Links"] = sum(len(url_data["Links"]) for url_data in data[key].get('Sites', []))
# Convert dict to df
df_data = pd.DataFrame(data).transpose()
df_data['ISO Code'] = df_data.index
# Sort by ISO Code
df_data = df_data.sort_values(by='ISO Code')
df_data['Number of Sites'] = df_data['Number of Sites'].astype(str) # Convert to string
df_data['ISO Code'] = df_data['ISO Code'].astype(str) # Convert to string
df_data['Number of Sites'] = df_data.apply(lambda row: '{}'.format(row['ISO Code'], row['Number of Sites']), axis=1)
df_data['Number of Links'] = df_data.apply(lambda row: '{}'.format(row['ISO Code'], row['Number of Links']), axis=1)
# Display the table
df_data = df_data[['ISO Code', 'Language Name', 'Family', 'Subgrouping', 'Number of Sites', 'Number of Links', 'Number of Speakers', 'Supported by allenai/MADLAD-400 or facebook/flores']]
st.write(df_to_html(df_data), unsafe_allow_html=True)
@st.cache_data
def render_site_table(isocode):
# back
back_text = '[Back]'
st.markdown(back_text, unsafe_allow_html=True)
st.write({'Language Name': data[isocode]['Language Name'], 'ISO Code': isocode})
# site
urls = data[isocode].get('Sites', [])
df_urls = pd.DataFrame(urls)
df_urls['Number of Links'] = df_urls['Links'].apply(len)
df_urls = df_urls.sort_values(by='Number of Links', ascending=False)
df_urls = df_urls.reset_index(drop=True)
df_urls['Number of Links'] = df_urls.apply(lambda row: '{}'.format(isocode, row['Site URL'], row['Number of Links']), axis=1)
df_urls['Site URL'] = df_urls['Site URL'].apply(lambda url: f'{url}')
# Display the table
df_urls = df_urls[['Site Name', 'Site URL', 'Category', 'Number of Links', 'Possible Parallel Languages']]
st.write(df_to_html(df_urls), unsafe_allow_html=True)
@st.cache_data
def render_siteurl_table(isocode, url):
# back
back_text = '[Back]'.format(isocode)
st.markdown(back_text, unsafe_allow_html=True)
# Find selected domain
urls = data[isocode].get('Sites', [])
selected_domain = next((d for d in urls if 'Site URL' in d and d['Site URL'] == url), None)
if selected_domain:
st.write({'Language Name': data[isocode]['Language Name'], 'ISO Code': isocode, 'Site URL': url, 'Links': selected_domain['Links']})
@st.cache_data
def render_links_table(isocode):
# back
back_text = '[Back]'
st.markdown(back_text, unsafe_allow_html=True)
# output
urls = data[isocode].get('Sites', [])
lang_name = data[isocode]['Language Name']
all_urls = [{'Site URL': du['Site URL'], 'Links': du['Links']} for du in urls]
st.write({'Language Name': lang_name, 'ISO Code': isocode, 'URLs': all_urls})
# show logo
render_svg(open("assets/glotweb_logo.svg").read())
def main():
params = st.query_params
if 'isocode' in params:
if 'siteurl' in params:
render_siteurl_table(params['isocode'], params['siteurl'])
if 'site' in params:
render_site_table(params['isocode'])
if 'links' in params:
render_links_table(params['isocode'])
else:
# show home
render_metadata()
st.markdown("**GlotWeb** is an indexing service for low-resource languages. It indexes sites or links written in each language. This list can be used to create raw text or parallel corpora and to study low-resource languages on the web.\n")
render_home_table()
main()