# THIS SOFTWARE IS A PART OF FREE COMPETITOR PROJECT
# THE FOLLOWING SOURCE CODE I UNDER THE GNU
# AGPL LICENSE V3 OR ANY LATER VERSION.

# This project is not for simple users, but for
# web-masters and a like, so we are counting on
# your ability to set it up and running.

import os
from modules import search


def html(page, json):

    # This function adds a rendering of the json into the page

    free = search.is_free(json)
    page = page + "\n <h1>"
    try:
        page = page + '\n<img src="'+ json["links"]["icon"] + '" alt="Logo" style="height:50px;">'
    except:
        pass
    name = json.get("names",["Unknown"])[0]
    page = page + "\n" + name 
    page = page + "</h1>"
        
    # Few words about it
    comment = json.get("comment","")
    not_foss = ['open source', 'open-source']
    if "open source" or "open-source" in comment.lower():
        # Well... Here is a thing. Free Software, not open source.
        where = comment.lower().find("open source")
        # In case it has a slash in it.
        if where == -1:
            where = comment.lower().find("open-source")
        ops = comment[where:where+11]
        comment = comment.replace(ops,
        "<a href=\"https://www.gnu.org/philosophy/open-source-misses-the-point.en.html\">"+ops+"</a>")
    page = page + "<p>"+comment+"</p>"

    # I want to show nothing else from if it's proprietary
    issues_files = list(os.listdir("data/issues"))
    if "issues" in json:
        l = json.get("issues", [])
        page = page +"<h2>Anti-Features / Problems:</h2>"

        for i in l:
            if i+".html" not in issues_files:
                page = page + "&nbsp;&nbsp;"+i+"<br>"
            else:
                page = page + '<details title="Read about '+i+'">'
                page = page + "<summary>&nbsp;&nbsp"+i+"</summary>"
                issuefile = open("data/issues/"+i+".html")                
                page = page + "<span><p>"+issuefile.read()+"</p></span>"
                page = page + "</details>"
    if not free:
        return page

    
    # Links

    # <table>
    #  <tr>
    #   <th>Company</th>
    #  <th>Contact</th>
    # <th>Country</th>
    #</tr>

    page = page + """
    <style>
    table, th, td {
    border-right:none;
    border-left:none;
    border-bottom:none;
    border-top:none
    }</style>
    """
    
    page = page + "<table><tr>"
    linksfilter = {"git":"source"}
    links = json.get("links", {})
    for website in links:
        if website in ["icon"]:
            continue
        link = links[website]
        page = page + """
        <th><form action=\""""+link+"""\">
            <button title=\""""+link+"""\" type="submit">"""+linksfilter.get(website,website).upper()+"""</button>
        </form></th>
       """

    page = page + "</tr></table>"

    # Details

    categories = {"generic_name":"Features",
                  "licenses":"License(s)",
                  "platforms":"Platforms",
                  "networks_read":"Accesses Data from",
                  "networks_write":"Interacts / Publishes to",
                  "formats_read":"Opens from File-Formats",
                  "formats_write":"Saves to File-Formats",
                  "interface":"Interface",
                  "languages":"Programming Languages"}

    for c in categories:

        l = json.get(c, [])
        if not l:
            continue

        # I want to look whether this category has a list of files
        alldata = list(os.listdir("data"))
        allfiles = []
        for folder in alldata:
            if c.startswith(folder):
                try:
                    allfiles = list(os.listdir("data/"+folder))
                    break
                except:
                    pass
        # Count matches
        matches = 0
        for i in l:
            if i.startswith("*"):
                matches += 1
        if matches:
            matchtext = "<i>( "+str(matches)+" )</i>"
        else:
            matchtext = ""
        page = page + "<details>"
        page = page +"<summary>"+categories[c]+": "+matchtext+"</summary>"

        for i in l:
            matchtext = ""
            if i.startswith("*"):
                i = i[1:]
                matchtext = "&nbsp;&nbsp;&nbsp;&nbsp;<i>( match )</i> "
            if i+".html" in allfiles:
                datapage = open("data/"+folder+"/"+i+".html")
                page = page + "<details><summary>&nbsp;&nbsp;&nbsp;&nbsp;"+matchtext+i+"</summary><span><p>"+datapage.read()+"<p></span></details>"
            else:
                page = page + "&nbsp;&nbsp;&nbsp;&nbsp;"+matchtext+i+"<br>"
        page = page + "<span><br></span></details>"
        
    
    return page

def suggestions(page, json):

    # This function will render suggestions

    page = page + "<h1>Free Competitors:</h1>"
    
    found = search.suggest(json)

    biggest = 0
    for i in found:
        if i[0] > biggest:
            biggest = i[0]
    more = False
    for i in found:
        free = search.is_free(i[-1])
    
        if not i[0] or i[-1]["names"] == json["names"] or not free:
            continue
        try:
            frac = int(i[0]/biggest*100)
        except:
            frac = 0

        if frac < 20 and not more: # Below 40% features match
            page = page + """<hr><details>
            <summary><h1 title="Click to show more / less.">Problematic Competitors:</h1></summary>"""
            more = True
        
        page = page + "<hr><br>Suggestion score: " + str(frac) + "%"
        page = html(page, i[-1])
        
    if more:
        page = page + "</details>"
    return page

def search_widget(page, address):

    # Adds a search bar to the page

    page = page + """
    <form action="""
    page = page + address
    page = page + """search method="GET">
    <input type="text" name="item" class="search" placeholder="Name of Software">
    <button type="submit">Search</button>
    </form>
    """
    #page = page.format(ADDRESS)
    
    return page

def source_code_link(page):

    # Adds a source code link

    page = page + "<br><br><hr><p>This website is under the GNU AGPL license.</p>"
    page = page + """
    <style>
    table, th, td {
    border-right:none;
    border-left:none;
    border-bottom:none;
    border-top:none
    }</style>
    <table><tr>

        <th><form action=https://notabug.org/jyamihud/FreeCompetitors>
            <button title="See the full source code of the software that powers this website." type="submit">SOURCE</button>
        </form></th>

        <th><form action=/faq>
            <button title="Frequently Asked Questions" type="submit">FAQ</button>
        </form></th>
    
        <th><form action=https://notabug.org/jyamihud/FreeCompetitors/issues>
            <button title="Report a bug." type="submit">BUG?</button>
        </form></th>
    
        <th><form action=https://notabug.org/jyamihud/FreeCompetitors/issues/25>
            <button title="Report a piece of software that's missing from the catalogue." type="submit">MISSING?</button>
        </form></th>
    
        <th><form action=https://notabug.org/jyamihud/FreeCompetitors/issues/24>
            <button title="Report a mistake in data about software." type="submit">MISTAKE?</button>
        </form></th></tr></table><br><br>
    

       """
    

    
    return page