detail page port

This commit is contained in:
nicwands
2026-05-29 11:22:56 -04:00
parent b85d28c142
commit e22d75c50a
65 changed files with 7006 additions and 4044 deletions

37
pages/@id/+Page.vue Normal file
View File

@@ -0,0 +1,37 @@
<template>
<column-layout class="event-detail">
<template v-slot:column-one>
<event-info :event="event" :product="product" />
</template>
<template v-slot:column-two>
<slices-map :slices="slices" />
</template>
</column-layout>
</template>
<script setup>
import { computed } from 'vue'
import { useData } from 'vike-vue/useData'
import ColumnLayout from '@/components/ColumnLayout.vue'
import EventInfo from '@/components/event/Info.vue'
import SlicesMap from '@/components/slices/Map.vue'
const { event, product } = useData()
const slices = computed(() => event?.slices || [])
</script>
<style lang="scss">
main.event-detail {
.column.two {
padding-bottom: desktop-vw(75px);
.slices-full-bleed-media.diptych {
.prismic-media {
border-width: 1px 0;
}
}
}
}
</style>

29
pages/@id/+data.js Normal file
View File

@@ -0,0 +1,29 @@
import * as prismic from '@prismicio/client'
import { createStorefrontApiClient } from '@shopify/storefront-api-client'
import { GET_PRODUCT_BY_HANDLE } from '@/libs/shopify/product'
export const data = async (pageContext) => {
const { id } = pageContext.routeParams
const prismicClient = prismic.createClient('swang')
const eventDoc = await prismicClient.getByUID('event', id)
const event = eventDoc?.data
const productHandle = event?.shopify_product_handle
if (!productHandle) return { event, product: null }
const shopifyClient = createStorefrontApiClient({
storeDomain: `https://swangent.myshopify.com`,
apiVersion: '2026-04',
publicAccessToken: 'd2848b9bcde999cea878c218493cfe84',
})
const query = GET_PRODUCT_BY_HANDLE
const variables = { handle: productHandle }
const productRes = await shopifyClient.request(query, { variables })
const product = productRes?.data
return { event, product }
}