Browse Source

fix(nc-gui): style day records based on range

pull/7611/head
DarkPhoenix2704 9 months ago
parent
commit
c980e13e7d
  1. 27
      packages/nc-gui/components/smartsheet/calendar/DayView.vue
  2. 29
      packages/nc-gui/components/smartsheet/calendar/RecordCard.vue

27
packages/nc-gui/components/smartsheet/calendar/DayView.vue

@ -1,5 +1,6 @@
<script lang="ts" setup> <script lang="ts" setup>
import { UITypes } from 'nocodb-sdk' import { UITypes } from 'nocodb-sdk'
import dayjs from 'dayjs'
import { type Row, computed, ref } from '#imports' import { type Row, computed, ref } from '#imports'
interface Props { interface Props {
@ -22,6 +23,29 @@ const displayField = computed(() => meta.value?.columns?.find((c) => c.pv && fie
const { pageDate, selectedDate, calDataType, formattedData, calendarRange } = useCalendarViewStoreOrThrow() const { pageDate, selectedDate, calDataType, formattedData, calendarRange } = useCalendarViewStoreOrThrow()
const getRecordPosition = (record: Row) => {
if (!calendarRange.value || !calendarRange.value[0]) return ''
const startCol = calendarRange.value[0].fk_from_col
const endCol = calendarRange.value[0].fk_to_col
if (!endCol && startCol) {
const startDate = dayjs(record.row[startCol.title])
return startDate.isSame(selectedDate.value, 'day') ? 'rounded' : ''
} else if (endCol && startCol) {
const startDate = dayjs(record.row[startCol.title])
const endDate = dayjs(record.row[endCol.title])
if (startDate.isSame(selectedDate.value, 'day') || endDate.isSame(selectedDate.value, 'day')) {
return 'rounded'
} else if (startDate.isBefore(selectedDate.value, 'day') && endDate.isAfter(selectedDate.value, 'day')) {
return 'none'
} else if (startDate.isSame(selectedDate.value, 'day') && endDate.isAfter(selectedDate.value, 'day')) {
return 'leftRounded'
} else if (startDate.isBefore(selectedDate.value, 'day') && endDate.isSame(selectedDate.value, 'day')) {
return 'rightRounded'
}
}
}
const hours = computed(() => { const hours = computed(() => {
const hours = [] const hours = []
for (let i = 0; i < 24; i++) { for (let i = 0; i < 24; i++) {
@ -46,13 +70,14 @@ const renderData = computed(() => {
'h-calc(100vh-10.8rem) overflow-y-auto nc-scrollbar-md': !props.isEmbed, 'h-calc(100vh-10.8rem) overflow-y-auto nc-scrollbar-md': !props.isEmbed,
'border-r-1 h-full border-gray-200 hover:bg-gray-50 ': props.isEmbed, 'border-r-1 h-full border-gray-200 hover:bg-gray-50 ': props.isEmbed,
}" }"
class="flex flex-col pt-3 gap-2 h-full w-full px-1" class="flex flex-col pt-3 gap-2 h-full w-full"
> >
<LazySmartsheetRow v-for="(record, rowIndex) in renderData" :key="rowIndex" :row="record"> <LazySmartsheetRow v-for="(record, rowIndex) in renderData" :key="rowIndex" :row="record">
<LazySmartsheetCalendarRecordCard <LazySmartsheetCalendarRecordCard
:key="rowIndex" :key="rowIndex"
:date="record.row[calendarRange[0].fk_from_col.title]" :date="record.row[calendarRange[0].fk_from_col.title]"
:name="record.row[displayField.title]" :name="record.row[displayField.title]"
:position="getRecordPosition(record)"
color="blue" color="blue"
size="small" size="small"
@click="emit('expand-record', record)" @click="emit('expand-record', record)"

29
packages/nc-gui/components/smartsheet/calendar/RecordCard.vue

@ -1,10 +1,11 @@
<script setup lang="ts"> <script lang="ts" setup>
interface Props { interface Props {
name: string name: string
date?: string date?: string
color?: string color?: string
size?: 'small' | 'medium' | 'large' size?: 'small' | 'medium' | 'large'
showDate?: boolean showDate?: boolean
position?: 'leftRounded' | 'rightRounded' | 'rounded' | 'none'
} }
const props = withDefaults(defineProps<Props>(), { const props = withDefaults(defineProps<Props>(), {
@ -13,10 +14,22 @@ const props = withDefaults(defineProps<Props>(), {
color: 'blue', color: 'blue',
size: 'small', size: 'small',
showDate: true, showDate: true,
position: 'rounded',
}) })
</script> </script>
<template> <template>
<div
:class="{
'h-12': props.size === 'medium',
'h-16': props.size === 'large',
'h-8': props.size === 'small',
'pr-2': props.position === 'leftRounded',
'pl-2': props.position === 'rightRounded',
'px-2': props.position === 'rounded',
}"
class="w-full gap-2"
>
<div <div
:class="{ :class="{
'bg-maroon-50': props.color === 'maroon', 'bg-maroon-50': props.color === 'maroon',
@ -25,11 +38,12 @@ const props = withDefaults(defineProps<Props>(), {
'bg-yellow-50': props.color === 'yellow', 'bg-yellow-50': props.color === 'yellow',
'bg-pink-50': props.color === 'pink', 'bg-pink-50': props.color === 'pink',
'bg-purple-50': props.color === 'purple', 'bg-purple-50': props.color === 'purple',
'h-12': props.size === 'medium', 'rounded-l-lg': props.position === 'leftRounded',
'h-16': props.size === 'large', 'rounded-r-lg': props.position === 'rightRounded',
'h-8': props.size === 'small', 'rounded-lg': props.position === 'rounded',
'rounded-none': props.position === 'none',
}" }"
class="flex items-center w-full border-1 cursor-pointer border-gray-200 gap-2 items-center px-2 py-3 rounded-lg" class="flex items-center border-1 px-2 cursor-pointer border-gray-200 py-2"
> >
<span <span
:class="{ :class="{
@ -40,13 +54,14 @@ const props = withDefaults(defineProps<Props>(), {
'bg-pink-500': props.color === 'pink', 'bg-pink-500': props.color === 'pink',
'bg-purple-500': props.color === 'purple', 'bg-purple-500': props.color === 'purple',
}" }"
class="block h-5 w-1 rounded" class="block h-5 w-1 rounded mr-2"
></span> ></span>
<div class="flex flex-row items-baseline gap-2"> <div class="flex flex-row items-baseline gap-2">
<span class="text-sm font-bold text-gray-800">{{ name }}</span> <span class="text-sm font-bold text-gray-800">{{ name }}</span>
<span v-if="showDate" class="text-xs text-gray-600">{{ date }}</span> <span v-if="showDate" class="text-xs text-gray-600">{{ date }}</span>
</div> </div>
</div> </div>
</div>
</template> </template>
<style scoped lang="scss"></style> <style lang="scss" scoped></style>

Loading…
Cancel
Save