Skip to content
Snippets Groups Projects
ZenodoResults.js 1.37 KiB
Newer Older
ghughes1066's avatar
ghughes1066 committed
import React, { useContext } from "react";
import { Table, Alert, Form } from "react-bootstrap";
import { QueryContext } from "../../../contexts/QueryContext";
import LoadingSpinner from "../../LoadingSpinner";
import Paginate from "../../Paginate";
import AddToBasket from "../../basket/AddToBasketCheckBox";

export default function ZenodoResults({ catalog }) {
  const context = useContext(QueryContext);
  const { queryMap, page, setPage } = context;
ghughes1066's avatar
ghughes1066 committed
  const regex = /(<([^>]+)>)/ig;
ghughes1066's avatar
ghughes1066 committed

  if (!context.queryMap) return null;

  if (context.queryMap.get(catalog).status === "fetched") {
    if (context.queryMap.get(catalog).results.results.length === 0)
      return <Alert variant="warning">No matching results found!</Alert>;
    else if (catalog === "zenodo") {
      const zenodoResults = queryMap.get("zenodo").results.results.map((hits, counter) => (
ghughes1066's avatar
ghughes1066 committed
        <>
        <br/>
        <br/>
Klaas Kliffen's avatar
Klaas Kliffen committed
        <h4><a href={hits.links.latest_html} target="_blank" rel="noopener noreferrer"> {hits.metadata.title.replaceAll(regex, '')} </a></h4>
        <a href={hits.links.doi} target="_blank" rel="noopener noreferrer"> <img src={hits.links.badge} alt="DOI"/> </a>
ghughes1066's avatar
ghughes1066 committed
        <br/>
ghughes1066's avatar
ghughes1066 committed
        {hits.metadata.description.replaceAll(regex, '').substring(0,200)}...
ghughes1066's avatar
ghughes1066 committed
        </>
      ));

      return (

       <>
         {zenodoResults}
       </>

Klaas Kliffen's avatar
Klaas Kliffen committed
      );
ghughes1066's avatar
ghughes1066 committed

    }
  }
  else {
    return <LoadingSpinner />;
  }
}