|
|
@ -1,9 +1,10 @@ |
|
|
|
<script setup lang="ts"> |
|
|
|
<script lang="ts" setup> |
|
|
|
interface Props { |
|
|
|
interface Props { |
|
|
|
name: string |
|
|
|
name: string |
|
|
|
date?: string |
|
|
|
date?: string |
|
|
|
color?: string |
|
|
|
color?: string |
|
|
|
showDate?: boolean |
|
|
|
showDate?: boolean |
|
|
|
|
|
|
|
invalid?: boolean |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
const props = withDefaults(defineProps<Props>(), { |
|
|
|
const props = withDefaults(defineProps<Props>(), { |
|
|
@ -11,27 +12,38 @@ const props = withDefaults(defineProps<Props>(), { |
|
|
|
date: '', |
|
|
|
date: '', |
|
|
|
color: 'blue', |
|
|
|
color: 'blue', |
|
|
|
showDate: true, |
|
|
|
showDate: true, |
|
|
|
|
|
|
|
invalid: false, |
|
|
|
}) |
|
|
|
}) |
|
|
|
</script> |
|
|
|
</script> |
|
|
|
|
|
|
|
|
|
|
|
<template> |
|
|
|
<template> |
|
|
|
<div class="flex border-1 cursor-pointer border-gray-200 items-center px-2 py-3 rounded-lg"> |
|
|
|
<div class="border-1 cursor-pointer border-gray-200 items-center px-2 py-3 rounded-lg"> |
|
|
|
<span |
|
|
|
<div class="flex items-center"> |
|
|
|
:class="{ |
|
|
|
<span |
|
|
|
'bg-maroon-500': props.color === 'maroon', |
|
|
|
:class="{ |
|
|
|
'bg-blue-500': props.color === 'blue', |
|
|
|
'bg-maroon-500': props.color === 'maroon', |
|
|
|
'bg-green-500': props.color === 'green', |
|
|
|
'bg-blue-500': props.color === 'blue', |
|
|
|
'bg-yellow-500': props.color === 'yellow', |
|
|
|
'bg-green-500': props.color === 'green', |
|
|
|
'bg-pink-500': props.color === 'pink', |
|
|
|
'bg-yellow-500': props.color === 'yellow', |
|
|
|
'bg-purple-500': props.color === 'purple', |
|
|
|
'bg-pink-500': props.color === 'pink', |
|
|
|
}" |
|
|
|
'bg-purple-500': props.color === 'purple', |
|
|
|
class="block h-10 w-1 rounded" |
|
|
|
}" |
|
|
|
></span> |
|
|
|
class="block h-10 w-1 rounded" |
|
|
|
<div class="flex flex-col gap-1 ml-3"> |
|
|
|
></span> |
|
|
|
<span class="text-sm font-bold text-gray-700">{{ name }}</span> |
|
|
|
<div class="flex flex-col gap-1 ml-3"> |
|
|
|
<span v-if="showDate" class="text-xs text-gray-500">{{ date }}</span> |
|
|
|
<span class="text-sm font-bold text-gray-700">{{ name }}</span> |
|
|
|
|
|
|
|
<span v-if="showDate" class="text-xs text-gray-500">{{ date }}</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> |
|
|
|
</div> |
|
|
|
</div> |
|
|
|
</template> |
|
|
|
</template> |
|
|
|
|
|
|
|
|
|
|
|
<style scoped lang="scss"></style> |
|
|
|
<style lang="scss" scoped></style> |
|
|
|