# 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 + " "+i+"<br>" else: page = page + '<details title="Read about '+i+'">' page = page + "<summary>  "+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 = " <i>( match )</i> " if i+".html" in allfiles: datapage = open("data/"+folder+"/"+i+".html") page = page + "<details><summary> "+matchtext+i+"</summary><span><p>"+datapage.read()+"<p></span></details>" else: page = page + " "+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