Created
June 19, 2024 18:45
-
-
Save rileybathurst/3ecfb4652b591f812cf243f6b4ebb496 to your computer and use it in GitHub Desktop.
grab all the version of a strapi query and loop them in gatsby
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
import * as React from "react" | |
import { Link, useStaticQuery, graphql } from 'gatsby'; | |
import { SEO } from "../components/seo"; | |
import Header from "../components/header"; | |
import Footer from "../components/footer"; | |
import Card from "../components/card"; | |
import type { CardType } from "../types/card-type"; | |
const VendorsPage = () => { | |
const { allStrapiVendor } = useStaticQuery(graphql` | |
query VendorsQuery { | |
allStrapiVendor { | |
nodes { | |
...vendorCard | |
} | |
} | |
} | |
`) | |
const vendorSet = new Set(); | |
for (const vendorService of allStrapiVendor.nodes) { | |
vendorSet.add(vendorService.service) | |
} | |
const vendorArray = Array.from(vendorSet); | |
return ( | |
<> | |
<Header /> | |
<main> | |
<div className="stork"> | |
<h1 className="mixta">Wedding Vendors</h1> | |
{/* // TODO: query this */} | |
<p>We built our business by providing outstanding quality, value, and service. We support others in Reno/Tahoe that have the same commitment.</p> | |
</div> | |
{vendorArray.map((service) => ( | |
<div | |
key={service} | |
> | |
<div className="stork"> | |
<hr /> | |
<h3 className="capitalize"> | |
<Link to={`/vendor/${service}`}>{service}</Link> | |
</h3> | |
</div> | |
<div className="deck"> | |
{allStrapiVendor.nodes | |
.filter((vendor) => vendor.service === service) | |
.map((vendor: CardType) => ( | |
<Card | |
key={vendor.id} | |
{...vendor} | |
breadcrumb="vendor" | |
/> | |
))} | |
</div> | |
</div > | |
))} | |
</main > | |
<Footer /> | |
</> | |
) | |
} | |
export default VendorsPage | |
export const Head = () => { | |
return ( | |
<SEO | |
title='Vendors' | |
description="We built our business by providing outstanding quality, value, and service. We support others in Reno/Tahoe that have the same commitment." | |
image="https://sierralighting.s3.us-west-1.amazonaws.com/og-images/vendors-og-sierra_lighting.jpg" | |
url="vendor" | |
/> | |
) | |
} | |
/* {vendorServices.map((service) => ( | |
<div | |
key={service.nodes[0].id} | |
> | |
<div className="stork"> | |
<hr /> | |
<h3 className="capitalize"> | |
<Link to={`/vendor/${service?.nodes[0].service}`}> | |
{service?.nodes[0].service} | |
</Link> | |
</h3> | |
</div> | |
<div className="deck"> | |
{service.nodes.map((vendor: CardType) => ( | |
<Card | |
key={vendor.id} | |
{...vendor} | |
breadcrumb="vendor" | |
/> | |
))} | |
</div> | |
</div > | |
))} */ |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment