Move roster builder button to member list

master
John Montagu, the 4th Earl of Sandvich 2024-11-14 14:08:39 -08:00
parent 5f45a8ebda
commit 6821447c74
Signed by: sandvich
GPG Key ID: 9A39BE37E602B22D
2 changed files with 68 additions and 21 deletions

View File

@ -1,25 +1,77 @@
<script setup lang="ts"> <script setup lang="ts">
import { useScheduleStore } from "../stores/schedule"; import { useScheduleStore } from "../stores/schedule";
import SchedulePlayerListItem from "./SchedulePlayerListItem.vue"; import SchedulePlayerListItem from "./SchedulePlayerListItem.vue";
import { useRouter } from "vue-router";
import { computed } from "vue";
const scheduleStore = useScheduleStore(); const scheduleStore = useScheduleStore();
const router = useRouter();
const selectedTimeTz = computed(() =>
props.selectedTime.clone().tz(scheduleStore.team?.tzTimezone));
const isTeamTzLocal = computed(() => {
return selectedTimeTz.value.utcOffset() == props.selectedTime.utcOffset();
});
const props = defineProps({
selectedTime: Object
});
function scheduleRoster() {
router.push({
name: "roster-builder",
params: {
teamId: scheduleStore.team.id,
startTime: props.selectedTime.unix(),
}
});
}
</script> </script>
<template> <template>
<div class="schedule-player-list"> <div class="schedule-player-list">
<h3>{{ scheduleStore.team?.teamName }}</h3> <h3>{{ scheduleStore.team?.teamName }}</h3>
<div>
<SchedulePlayerListItem <SchedulePlayerListItem
v-for="record in scheduleStore.playerAvailability" v-for="record in scheduleStore.playerAvailability"
:player="record" :player="record"
/> />
</div> </div>
<h4>
<template v-if="selectedTime">
<div>
{{ selectedTime.format("L LT z") }}
</div>
<div v-if="!isTeamTzLocal">
{{ selectedTimeTz.format("L LT z") }}
</div>
</template>
</h4>
<button @click="scheduleRoster" v-if="selectedTime">
Schedule for {{ selectedTime.format("L LT") }}
</button>
</div>
</template> </template>
<style scoped> <style scoped>
h3 { h3, h4 {
font-weight: 700; font-weight: 700;
} }
h4, h4 > div {
font-weight: 700;
font-size: 10pt;
min-height: 1em;
}
.schedule-player-list {
display: flex;
flex-direction: column;
gap: 1em;
}
.player:hover { .player:hover {
background-color: var(--mantle); background-color: var(--mantle);
} }

View File

@ -54,16 +54,6 @@ function copyPreviousWeek() {
}); });
} }
function scheduleRoster() {
router.push({
name: "roster-builder",
params: {
teamId: selectedTeam.value.id,
startTime: selectedTime.value.unix(),
}
});
}
onMounted(() => { onMounted(() => {
teamsStore.fetchTeams() teamsStore.fetchTeams()
.then((teamsList) => { .then((teamsList) => {
@ -74,7 +64,6 @@ onMounted(() => {
if (queryTeam) { if (queryTeam) {
selectedTeam.value = queryTeam; selectedTeam.value = queryTeam;
schedule.team = queryTeam; schedule.team = queryTeam;
schedule.fetchTeamSchedule();
} else { } else {
selectedTeam.value = options.value[0]; selectedTeam.value = options.value[0];
} }
@ -141,9 +130,6 @@ onMounted(() => {
<button @click="copyPreviousWeek"> <button @click="copyPreviousWeek">
Copy previous week Copy previous week
</button> </button>
<button @click="scheduleRoster" v-if="selectedTime">
Schedule for {{ selectedTime.format("L LT") }}
</button>
<button class="accent" @click="isEditing = true"> <button class="accent" @click="isEditing = true">
<i class="bi bi-pencil-fill"></i> <i class="bi bi-pencil-fill"></i>
</button> </button>
@ -155,7 +141,9 @@ onMounted(() => {
You currently are not in any team to schedule for. You currently are not in any team to schedule for.
</div> </div>
<div class="player-list"> <div class="player-list">
<SchedulePlayerList /> <SchedulePlayerList
:selected-time="selectedTime"
/>
</div> </div>
</main> </main>
</template> </template>
@ -163,7 +151,6 @@ onMounted(() => {
<style scoped> <style scoped>
main { main {
flex-direction: row; flex-direction: row;
gap: 8px;
display: flex; display: flex;
justify-content: space-evenly; justify-content: space-evenly;
} }
@ -233,4 +220,12 @@ button.right.radio.selected {
width: auto; width: auto;
min-width: 11em; min-width: 11em;
} }
.schedule-view-container {
flex-basis: 75%;
}
.player-list {
flex-basis: 25%;
}
</style> </style>