You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
93 lines
3.9 KiB
Vue
93 lines
3.9 KiB
Vue
<template>
|
|
<div class="bg-zinc-100 rounded-lg m-5 grid grid-cols-2 gap-10 divide-x divide-solid divide-black py-4 mb-10">
|
|
|
|
<div class="px-5">
|
|
<p class="text-lg">performances</p>
|
|
|
|
<div v-for="(item, index) in events">
|
|
<Collapsible title='placeholder' :modelValue='index <= 10' class="leading-tight py-2 ml-3 text-sm">
|
|
<template v-slot:title>
|
|
<div class="gap-1 w-[95%] px-2">
|
|
<div>
|
|
{{ item.formatted_date }}: {{item.venue.city}}, {{item.venue.state}}
|
|
<div class="ml-4 text-[#7F7F7F]">
|
|
{{ item.venue.name }}
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</template>
|
|
<template v-slot:content>
|
|
<div v-for="performance in item.program">
|
|
<div class="italic text-sm ml-16 pt-1">{{performance.work}}</div>
|
|
<div v-if="performance.ensemble" class="ml-20">
|
|
{{ performance.ensemble }}
|
|
</div>
|
|
<div v-for="performer in performance.performers" class="ml-20">
|
|
{{ performer.name }} -
|
|
<span v-for="(instrument, index) in performer.instrument_tags">
|
|
<span v-if="index !== 0">, </span>
|
|
{{ instrument }}
|
|
</span>
|
|
</div>
|
|
</div>
|
|
<div class="italic text-sm ml-16 pt-1">{{item.legacy_program}}</div>
|
|
<div class="ml-20">{{item.legacy_performers}}</div>
|
|
</template>
|
|
</Collapsible>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="px-5">
|
|
<p class="text-lg">lectures</p>
|
|
|
|
<div class="leading-tight py-2 ml-3 text-sm" v-for="item in lectures">
|
|
<div class="gap-1">
|
|
<div>
|
|
{{ item.formatted_date }}: {{item.location}}
|
|
<div v-for="talk in item.talks" class="ml-4 text-[#7F7F7F]">
|
|
{{ talk.title }}
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</template>
|
|
|
|
|
|
<script setup>
|
|
const { data: events } = await useFetch('https://unboundedpress.org/api/events?pagesize=200', {
|
|
transform: (events) => {
|
|
for (const event of events) {
|
|
let date = new Date(event.start_date.$date)
|
|
event.formatted_date = ("0" + (date.getMonth() + 1)).slice(-2) + "." + ("0" + date.getDate()).slice(-2) + "." + date.getFullYear()
|
|
}
|
|
return events.sort((a,b) => b.start_date.$date - a.start_date.$date)
|
|
}
|
|
})
|
|
|
|
const { data: lectures } = await useFetch('https://unboundedpress.org/api/talks?pagesize=200', {
|
|
transform: (events) => {
|
|
for (const event of events) {
|
|
let date = new Date(event.date)
|
|
event.date = date
|
|
event.formatted_date = ("0" + (date.getMonth() + 1)).slice(-2) + "." + ("0" + date.getDate()).slice(-2) + "." + date.getFullYear()
|
|
if(typeof event.title === 'string' || event.title instanceof String) {event.talks = [{'title': event.title}]
|
|
} else {
|
|
let talks = []
|
|
for(const talk of event.title){
|
|
talks.push({"title": talk})
|
|
}
|
|
event.talks = talks
|
|
}
|
|
}
|
|
return events.sort((a,b) => b.date - a.date)
|
|
}
|
|
})
|
|
|
|
useHead({
|
|
titleTemplate: 'Michael Winter - Events - Performances and Lectures'
|
|
})
|
|
</script>
|
|
|