|
|
|
<script lang="ts" setup>
|
|
|
|
interface Props {
|
|
|
|
fromDate?: string
|
|
|
|
toDate?: string
|
|
|
|
color?: string
|
|
|
|
showDate?: boolean
|
|
|
|
invalid?: boolean
|
|
|
|
}
|
|
|
|
|
|
|
|
const props = withDefaults(defineProps<Props>(), {
|
|
|
|
fromDate: '',
|
|
|
|
color: 'blue',
|
|
|
|
showDate: true,
|
|
|
|
invalid: false,
|
|
|
|
})
|
|
|
|
</script>
|
|
|
|
|
|
|
|
<template>
|
|
|
|
<div class="border-1 cursor-pointer h-14 border-gray-200 flex gap-2 items-center rounded-lg">
|
|
|
|
<div class="flex items-center pl-2 gap-2">
|
|
|
|
<span
|
|
|
|
:class="{
|
|
|
|
'bg-maroon-500': props.color === 'maroon',
|
|
|
|
'bg-blue-500': props.color === 'blue',
|
|
|
|
'bg-green-500': props.color === 'green',
|
|
|
|
'bg-yellow-500': props.color === 'yellow',
|
|
|
|
'bg-pink-500': props.color === 'pink',
|
|
|
|
'bg-purple-500': props.color === 'purple',
|
|
|
|
}"
|
|
|
|
class="block h-10 w-1 rounded"
|
|
|
|
></span>
|
|
|
|
<slot name="image" />
|
|
|
|
<div class="flex gap-1 flex-col">
|
|
|
|
<span class="text-[13px] leading-4 max-w-56 font-medium truncate text-gray-800">
|
|
|
|
<slot />
|
|
|
|
</span>
|
|
|
|
<span v-if="showDate" class="text-xs font-medium leading-4 text-gray-600"
|
|
|
|
>{{ fromDate }} {{ toDate ? ` - ${toDate}` : '' }}</span
|
|
|
|
>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div v-if="invalid" class="gap-3 bg-yellow-50 mt-2 border-gray-200 border-1 rounded-lg p-2 flex">
|
|
|
|
<component :is="iconMap.warning" class="text-yellow-500 h-4 w-4" />
|
|
|
|
<div class="flex flex-col gap-1">
|
|
|
|
<h1 class="text-gray-800 text-bold">Date mismatch</h1>
|
|
|
|
<p class="text-gray-500">Selected End date is before Start date.</p>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</template>
|
|
|
|
|
|
|
|
<style lang="scss" scoped></style>
|