next.js/examples/with-xata/pages/index.tsx
index.tsx101 lines2.5 KB
import type { InferGetServerSidePropsType } from "next";
import Image from "next/image";
import { getXataClient } from "../utils/xata.codegen";
import xatafly from "../public/xatafly.gif";

const pushDummyData = async () => {
  const response = await fetch("/api/write-links-to-xata");

  if (response.ok) {
    window?.location.reload();
  }
};

const removeDummyItem = async (id: string) => {
  const { status } = await fetch("/api/clean-xata", {
    method: "POST",
    headers: {
      "Content-Type": "application/json",
    },
    body: JSON.stringify({ id }),
  });

  if (status === 200) {
    window?.location.reload();
  }
};

export default function IndexPage({
  links,
}: InferGetServerSidePropsType<typeof getServerSideProps>) {
  return (
    <main>
      <header>
        <Image src={xatafly} alt={"Xata"} priority />
        <h1>
          Next.js with<span aria-hidden>&#8209;</span>xata
        </h1>
      </header>
      <article>
        {links.length ? (
          <ul>
            {links.map(({ id, title, url, description }) => (
              <li key={url}>
                <a href={url} rel="noopener noreferrer" target="_blank">
                  {title}
                </a>
                <p>{description}</p>

                <button
                  type="button"
                  onClick={() => {
                    removeDummyItem(id);
                  }}
                >
                  <span role="img" aria-label="delete item">
                    🗑
                  </span>
                </button>
              </li>
            ))}
          </ul>
        ) : (
          <section>
            <h2>No records found.</h2>
            <strong>
              Create a `nextjs_with_xata_example` and push some useful links to
              see them here.
            </strong>
            <button
              type="button"
              onClick={() => {
                pushDummyData();
              }}
            >
              Push records to Xata
            </button>
          </section>
        )}
      </article>
      <footer>
        <span>
          Made by{" "}
          <a href="https://xata.io" rel="noopener noreferrer" target="_blank">
            <object data="/xatafly.svg" />
          </a>
        </span>
      </footer>
    </main>
  );
}

export const getServerSideProps = async () => {
  const xata = await getXataClient();
  const links = await xata.db.nextjs_with_xata_example.getAll();
  return {
    props: {
      links,
    },
  };
};
Quest for Codev2.0.0
/
SIGN IN