55 lines
1.1 KiB
Vue
55 lines
1.1 KiB
Vue
<script setup>
|
|
import error from '../images/error.png'
|
|
import success from '../images/success.png'
|
|
import warning from '../images/warning.png'
|
|
|
|
const props = defineProps({
|
|
type: {
|
|
type: String,
|
|
default: 'success',
|
|
validator: (value) => ['success', 'error', 'warning'].includes(value)
|
|
},
|
|
text: {
|
|
type: String,
|
|
default: ''
|
|
}
|
|
})
|
|
|
|
const typeConfig = {
|
|
success: {
|
|
imgSrc: success,
|
|
borderColor: '#C5E7D5',
|
|
bgColor: '#EDF7F2'
|
|
},
|
|
error: {
|
|
imgSrc: error,
|
|
borderColor: '#F3CBD3',
|
|
bgColor: '#FBEEF1'
|
|
},
|
|
warning: {
|
|
imgSrc: warning,
|
|
borderColor: '#FAE0B5',
|
|
bgColor: '#FEF7ED'
|
|
}
|
|
}
|
|
</script>
|
|
|
|
<template>
|
|
<div
|
|
class="box-border w-[343px] min-h-[46px] rounded-[4px] border flex items-center px-[15px] shadow-sm"
|
|
:style="{
|
|
borderColor: typeConfig[type].borderColor,
|
|
backgroundColor: typeConfig[type].bgColor
|
|
}"
|
|
>
|
|
<div class="w-[20px] h-[20px] mr-[9px]">
|
|
<img
|
|
:src="typeConfig[type].imgSrc"
|
|
class="w-full h-full"
|
|
alt=""
|
|
>
|
|
</div>
|
|
<div class="text-[14px] leading-normal text-black">{{ text }}</div>
|
|
</div>
|
|
</template>
|