All files / publisher/pages/Snaps PublishedSnapsTable.tsx

100% Statements 5/5
64.28% Branches 9/14
100% Functions 2/2
100% Lines 5/5

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60                  13x                       25x 25x 25x     25x                                                                  
import { format, parseISO } from "date-fns";
 
import type { Snap } from "../../types/shared";
import { MainTable } from "@canonical/react-components";
type Props = {
  snapsInStore: Array<Snap>;
};
 
function PublishedSnapsTable({ snapsInStore }: Props): React.JSX.Element {
  return (
    <>
      {snapsInStore.length > 0 ? (
        <MainTable
          sortable
          headers={[
            { content: "Name", sortKey: "name" },
            { content: "Latest release", sortKey: "latestRelease" },
            { content: "Release date", sortKey: "releaseDate" },
            { content: "Publisher", sortKey: "publisher" },
          ]}
          rows={snapsInStore.map((snap: Snap) => {
            let releaseDate = null;
            Eif (snap["latest-release"] && snap["latest-release"].timestamp) {
              releaseDate = parseISO(snap["latest-release"].timestamp);
            }
 
            return {
              columns: [
                { content: snap.name },
                {
                  content:
                    snap["latest-release"] && snap["latest-release"].version
                      ? snap["latest-release"].version
                      : "-",
                },
                {
                  content: releaseDate
                    ? format(releaseDate, "dd/MM/yyyy")
                    : "-",
                },
                { content: snap.users[0].displayname },
              ],
              sortData: {
                name: snap.name,
                latestRelease: snap["latest-release"].version,
                releaseDate: releaseDate || "-",
                publisher: snap.users[0].displayname,
              },
            };
          })}
        />
      ) : (
        <p>There are currently no snaps in this store</p>
      )}
    </>
  );
}
 
export default PublishedSnapsTable;