Rename TimeBlock to Interva. More Interval functionality.
Some checks failed
Build BAB Application Deployment Artifact / build (push) Failing after 1m40s

This commit is contained in:
2024-05-10 09:50:04 -04:00
parent 77619b0741
commit 3a67f2fbb1
8 changed files with 293 additions and 139 deletions

View File

@@ -76,12 +76,12 @@ import CalendarHeaderComponent from './CalendarHeaderComponent.vue';
import { ref, computed } from 'vue';
import { useBoatStore } from 'src/stores/boat';
import { useScheduleStore } from 'src/stores/schedule';
import { TimeBlock } from 'src/stores/schedule.types';
import { Interval } from 'src/stores/schedule.types';
import { storeToRefs } from 'pinia';
const scheduleStore = useScheduleStore();
const { boats } = storeToRefs(useBoatStore());
const selectedBlock = defineModel<TimeBlock | null>();
const selectedBlock = defineModel<Interval | null>();
const selectedDate = ref(today());
const calendar = ref<QCalendarDay | null>(null);
@@ -103,7 +103,7 @@ function handleSwipe({ ...event }) {
// }
function blockStyles(
block: TimeBlock,
block: Interval,
timeStartPos: (t: string) => string,
timeDurationHeight: (d: number) => string
) {
@@ -154,7 +154,7 @@ interface DayBodyScope {
timestamp: Timestamp;
}
function selectBlock(event: MouseEvent, scope: DayBodyScope, block: TimeBlock) {
function selectBlock(event: MouseEvent, scope: DayBodyScope, block: Interval) {
// TODO: Disable blocks before today with updateDisabled and/or comparison
selectedBlock.value === block
? (selectedBlock.value = null)
@@ -162,12 +162,12 @@ function selectBlock(event: MouseEvent, scope: DayBodyScope, block: TimeBlock) {
}
interface BoatBlocks {
[key: string]: TimeBlock[];
[key: string]: Interval[];
}
const boatBlocks = computed((): BoatBlocks => {
return scheduleStore
.getTimeBlocksForDate(selectedDate.value)
.getIntervalsForDate(selectedDate.value)
.reduce((result, tb) => {
if (!result[tb.boatId]) result[tb.boatId] = [];
result[tb.boatId].push(tb);
@@ -175,14 +175,14 @@ const boatBlocks = computed((): BoatBlocks => {
}, <BoatBlocks>{});
});
function getBoatBlocks(scope: DayBodyScope): TimeBlock[] {
function getBoatBlocks(scope: DayBodyScope): Interval[] {
return boats.value[scope.columnIndex]
? boatBlocks.value[boats.value[scope.columnIndex].$id]
: [];
}
// function changeEvent({ start }: { start: string }) {
// const newBlocks = scheduleStore.getTimeBlocksForDate(start);
// const newBlocks = scheduleStore.getIntervalsForDate(start);
// const reservations = scheduleStore.getBoatReservations(
// parsed(start) as Timestamp
// );