diff options
Diffstat (limited to 'fatcat_scholar')
-rw-r--r-- | fatcat_scholar/templates/base.html | 16 | ||||
-rw-r--r-- | fatcat_scholar/templates/search_macros.html | 234 |
2 files changed, 140 insertions, 110 deletions
diff --git a/fatcat_scholar/templates/base.html b/fatcat_scholar/templates/base.html index 7f1b2cd..354f111 100644 --- a/fatcat_scholar/templates/base.html +++ b/fatcat_scholar/templates/base.html @@ -48,13 +48,12 @@ .ui.labeled.icon.button.serp-button { padding-left: 3.0em!important; padding-right: 1em!important; - min-width: 10em; - max-width: 15em; + width: 14em; box-shadow: 1px 1px 2px 1px rgba(0, 0, 0, 0.3); } .ui.labeled.icon.button.serp-button .menu.fulltext-thumbnail { - left: calc(-100% - 1.6em); + left: calc(-100% + 0.3em); margin-top: -2.4em; background-color: black; min-width: 186px; @@ -72,7 +71,7 @@ display: flex; justify-content: center; column-gap: 0.3em; - min-width: 12em; + min-width: 14em; max-width: 15em; } @@ -210,10 +209,15 @@ color: inherit; } details.access-options .menu { - /* border: 1px solid black; */ margin: 0.5em; + margin-top: 1.5em; width: auto; - padding: 1em; + } + details.access-options .meta { + width: 100%; + overflow: hidden; + text-overflow: ellipsis; + text-decoration: underline; } details.serp-action-menu[open] > summary .ui.basic.button { diff --git a/fatcat_scholar/templates/search_macros.html b/fatcat_scholar/templates/search_macros.html index d267cdc..ca6d9f5 100644 --- a/fatcat_scholar/templates/search_macros.html +++ b/fatcat_scholar/templates/search_macros.html @@ -50,24 +50,115 @@ {% endif %} {% endmacro %} -{% macro ia_access_button(access) -%} - {% set access_alt = _('fulltext access') %} +{% macro ia_access_button(access, show_thumbnail=False, other_version=False) -%} + {% if access.file_mimetype == "application/pdf" %} + {% set access_alt = _('fulltext PDF download') %} + {% elif access.access_type == "ia_sim" %} + {% set access_alt = _('read fulltext microfilm') %} + {% else %} + {% set access_alt = _('fulltext access') %} + {% endif %} + {% if other_version %} + {% set access_alt = access_alt + " [" + other_version + "]" %} + {% endif %} <a target="_blank" rel="noopener" href="{{ access.access_url}}" title="{{ access_alt }}" {% if settings.ENABLE_GOATCOUNTER %}data-goatcounter-click="serp-fulltext-button"{% endif %}> - <button class="ui compact black labeled icon button serp-button"> + <button class="ui simple right pointing dropdown fluid compact black labeled icon button serp-button"> <i class="icon" style="background: no-repeat center / 50% url('/static/ia-favicon.ico');"></i> - {% if access.access_type in ["wayback",] %} - Wayback - {% elif access.access_type in ["ia_file",] %} - File + {% if access.access_type == "wayback" %} + Web Archive + {% elif access.access_type == "ia_file" %} + File Archive {% elif access.access_type == "ia_sim" %} Microfilm {% else %} Other {% endif %} + + {% if access.file_mimetype == "application/pdf" or (access.file_mimetype == None and access.access_type == "wayback") %} + [PDF] + {% elif access.file_mimetype == "text/html" %} + [HTML] + {% elif access.file_mimetype == "text/xml" %} + [XML] + {% endif %} + + {# + {% if access.size_bytes %} + ({{ access.size_bytes|filesizeformat }}) + {% endif %} + #} + + {% if other_version %} + <span style="color: brown;">✱</span> + {% endif %} + + {% if show_thumbnail and access.thumbnail_url %} + <div class="menu fulltext-thumbnail"> + <img src="{{ access.thumbnail_url }}" alt="fulltext thumbnail" loading="lazy"> + </div> + {% endif %} </button> </a> {% endmacro %} +{% macro doi_access_button(biblio, is_oa=False) %} + {% if biblio.doi %} + {% set publisher = "" or (biblio.publisher and biblio.publisher.lower()) %} + {% set container_name = "" or (biblio.container_name and biblio.container_name.lower()) %} + <a target="_blank" rel="external noopener noreferrer" href="https://doi.org/{{ biblio.doi }}" style="color: green;"> + <button class="ui fluid left aligned compact blue labeled icon button serp-button"> + {% if is_oa %} + <i class="unlock alternate icon" style="background-color: #fb971f;"></i> + {% else %} + <i class="external alternate icon"></i> + {% endif %} + {# TODO: detect prefix? JSTOR, biorxiv, medrxiv, zenodo, figshare, dryad, etc #} + {# helpful: https://gist.github.com/TomDemeranville/8699224 #} + {% if biblio.doi_prefix == "10.6084" %} + figshare.com + {% elif biblio.doi_prefix == "10.5281" %} + zenodo.org + {% elif biblio.doi_prefix == "10.1371" %} + plos.org + {% elif biblio.doi_prefix == "10.1101" and "biorxiv" in container_name %} + biorxiv.org + {% elif biblio.doi_prefix == "10.1101" and "medrxiv" in container_name %} + medrxiv.org + {% elif biblio.doi_prefix == "10.1016" and "elsevier" in publisher %} + elsevier.com + {% elif biblio.doi_prefix in ["10.1186", "10.1007"] and "springer" in publisher %} + springer.com + {% elif biblio.doi_prefix in ["10.1042", "10.1111", "10.1177"] and "sage" in publisher %} + sagepub.com + {% elif biblio.doi_prefix in ["10.1080"] and "taylor" in publisher %} + tandfonline.com + {% else %} + Publisher / doi.org + {% endif %} + </button> + </a> + {% endif %} +{% endmacro %} + +{% macro platform_access_button(biblio) %} + {# TODO: DOAJ, dblp #} + {% if biblio.arxiv_id %} + <a target="_blank" rel="noopener" href="https://arxiv.org/abs/{{ biblio.arxiv_id }}" title="arxiv.org access"> + <button class="ui fluid compact blue labeled icon button serp-button"> + <i class="file alternate outline icon"></i> + arxiv.org + </button> + </a> + {% elif biblio.pmcid %} + <a target="_blank" rel="noopener" href="https://www.ncbi.nlm.nih.gov/pmc/articles/{{ biblio.pmcid }}" title="pubmed link"> + <button class="ui fluid compact blue labeled icon button serp-button"> + <i class="file alternate outline icon"></i> + pubmed.gov + </button> + </a> + {% endif %} +{% endmacro %} + {% macro journal_row(biblio, paper) -%} {# NOTE: should be able to call with paper.biblio or any paper.release[] #} {% if biblio.release_year %} @@ -194,6 +285,11 @@ {% endif %} </a> </div> + <div class="meta"> + <a href="{{ paper.fulltext.access_url}}"> + {{ paper.fulltext.access_url }} + </a> + </div> <div class="description"> {% if paper.fulltext.access_type == "wayback" %} <p>A copy of this work was available on the public web and has been preserved in the Wayback Machine. The capture dates from {{ paper.fulltext.access_url.split('/')[4][:4] }}; you can also visit <a href="{{ '/'.join(paper.fulltext.access_url.split('/')[5:]) }}">the original URL</a>. @@ -204,13 +300,14 @@ {% endif %} {% if paper.fulltext.file_mimetype %} - <p>The file type is <code>{{ paper.fulltext.file_mimetype }}</code>. + {% trans mimetype = ("<code>" + paper.fulltext.file_mimetype + "</code>")|safe %} + The file type is {{ mimetype }}. + {% endtrans %} {% endif %} {% if paper.fulltext.release_ident and (paper.biblio.release_ident != paper.fulltext.release_ident) %} {# Fulltext copy is different from biblio version! #} - <p>Note that this fulltext copy is not of the "primary" version - of this work. The version it corresponds to is: + <p>{% trans %}Note that this fulltext copy is not of the "primary" version of this work. The version it corresponds to is:{% endtrans %} <div class="ui fitted divider"></div> {% for release in paper.releases if release.ident == paper.fulltext.release_ident %} {{ journal_row(release, paper) }} @@ -224,7 +321,7 @@ {# currently, ia_sim access types are not linked to specific versions #} {% for access in paper.access if access.access_type != paper.fulltext.access_type and (access.release_ident == paper.fulltext.release_ident or access.release_ident == paper.biblio.release_ident or access.access_type == 'ia_sim') %} {% if loop.first %} - <p>Additional access options for the primary version of this work: + <p>{% trans %}Additional access options for the primary version of this work:{% endtrans %} {% endif %} {{ ia_access_button(access )}} {% endfor %} @@ -242,18 +339,20 @@ {% endif %} {% if paper.releases|length > 1 %} - <h4 class="ui horizontal divider header"> - {# <i class="tag icon"></i> #} - Other Versions - </h4> {% for release in paper.releases if (release.ident != paper.biblio.release_ident and release.ident != paper.fulltext.release_ident) %} + {% if loop.first %} + <h4 class="ui horizontal divider header"> + {# <i class="tag icon"></i> #} + Other Versions + </h4> + {% endif %} <div class="biblio-record"> {{ journal_row(release, paper) }} <br> {{ external_identifiers(release) }} <br> {% for access in paper.access if access.release_ident == release.ident %} - {{ ia_access_button(access )}} + {{ ia_access_button(access)}} {% endfor %} </div> {% if not loop.last %} @@ -317,6 +416,14 @@ {{ tag_label("lang:" + paper.biblio.lang_code) }} {% endif %} + {# "Multiple Versions" disabled for now + {% if (paper.access and paper.access|length > 1) or (paper.releases and paper.releases|length > 1) %} + <span class="ui label basic blue small"> + {% trans %}Multiple Versions{% endtrans %} + </span> + {% endif %} + #} + </div> </div> @@ -326,100 +433,19 @@ {# archive links (if available) #} {% if paper.fulltext and paper.fulltext.access_url %} - {% if paper.fulltext.file_mimetype == "application/pdf" %} - {% set access_alt = _('fulltext PDF download') %} - {% elif paper.fulltext.access_type == "ia_sim" %} - {% set access_alt = _('read fulltext microfilm') %} + {% if (paper.fulltext.release_ident and paper.fulltext.release_ident != paper.biblio.release_ident) %} + {% set other_version = _("not primary version") %} {% else %} - {% set access_alt = _('fulltext access') %} + {% set other_version = "" %} {% endif %} - <a target="_blank" rel="noopener" href="{{ paper.fulltext.access_url}}" title="{{ access_alt }}" {% if settings.ENABLE_GOATCOUNTER %}data-goatcounter-click="serp-fulltext-button"{% endif %}> - <button class="ui simple right pointing dropdown fluid compact black labeled icon button serp-button"> - <i class="icon" style="background: no-repeat center / 50% url('/static/ia-favicon.ico');"></i> - {% if paper.fulltext.access_type in ["wayback", "ia_file"] %} - {% if paper.fulltext.file_mimetype == "application/pdf" or not paper.fulltext.file_mimetype %} - PDF - {% elif paper.fulltext.file_mimetype == "text/html" %} - HTML - {% elif paper.fulltext.file_mimetype == "text/xml" %} - XML - {% else %} - File - {% endif %} - {% if paper.fulltext.size_bytes %} - ({{ paper.fulltext.size_bytes|filesizeformat }}) - {% endif %} - {% elif paper.fulltext.access_type == "ia_sim" %} - Microfilm - {% else %} - Other - {% endif %} - {% if paper.fulltext and paper.fulltext.thumbnail_url %} - <div class="menu fulltext-thumbnail"> - <img src="{{ paper.fulltext.thumbnail_url }}" alt="fulltext thumbnail" loading="lazy"> - </div> - {% endif %} - </button> - </a> + {{ ia_access_button(paper.fulltext, show_thumbnail=True, other_version=other_version) }} {% endif %} - {# publisher #} - {% if paper.biblio.doi %} - <a target="_blank" rel="external noopener noreferrer" href="https://doi.org/{{paper.biblio.doi }}" style="color: green;"> - <button class="ui fluid left aligned compact blue labeled icon button serp-button"> - {% if "oa" in paper.tags %} - <i class="unlock alternate icon" style="background-color: #fb971f;"></i> - {% else %} - <i class="linkify icon"></i> - {% endif %} - {# TODO: detect prefix? JSTOR, biorxiv, medrxiv, zenodo, figshare, dryad, etc #} - {# helpful: https://gist.github.com/TomDemeranville/8699224 #} - {% if paper.biblio.doi_prefix == "10.6084" %} - figshare.com - {% elif paper.biblio.doi_prefix == "10.5281" %} - zenodo.org - {% elif paper.biblio.doi_prefix == "10.1371" %} - plos.org - {% elif paper.biblio.doi_prefix == "10.1016" %} - elsevier.com - {% elif paper.biblio.doi_prefix in ["10.1186", "10.1007"] %} - springer.com - {% elif paper.biblio.doi_prefix in ["10.1042", "10.1111", "10.1177"] %} - sagepub.com - {% elif paper.biblio.doi_prefix in ["10.1080"] %} - tandfonline.com - {% else %} - Publisher DOI - {% endif %} - </button> - </a> - {% endif %} + {# publisher / repository #} + {{ doi_access_button(paper.biblio, is_oa=("oa" in paper.tags)) }} {# trusted platform fulltext links #} - {# TODO: DOAJ, dblp #} - {% if paper.biblio.arxiv_id %} - <a target="_blank" rel="noopener" href="https://arxiv.org/abs/{{ paper.biblio.arxiv_id }}" title="arxiv.org access"> - <button class="ui fluid compact blue labeled icon button serp-button"> - <i class="file alternate outline icon"></i> - arxiv.org - </button> - </a> - {% elif paper.biblio.pmcid %} - <a target="_blank" rel="noopener" href="https://www.ncbi.nlm.nih.gov/pmc/articles/{{paper.biblio.pmcid }}" title="pubmed link"> - <button class="ui fluid compact blue labeled icon button serp-button"> - <i class="file alternate outline icon"></i> - Pubmed Central - </button> - </a> - {% endif %} - - {# ### VERSIONS #} - {% if (paper.access and paper.access|length > 1) or (paper.releases and paper.releases|length > 1) %} - <div class="ui fluid compact basic blue labeled icon button serp-button"> - <i class="ui icon add"></i> - {% trans %}Multiple Versions{% endtrans %} - </div> - {% endif %} + {{ platform_access_button(paper.biblio) }} {# ### COLLAPSED HITS #} {% if paper._collapsed_count > 0 %} |