2025-01-09 11:01:35 +00:00
|
|
|
<script setup>
|
2025-01-21 03:43:27 +00:00
|
|
|
|
2025-01-09 11:01:35 +00:00
|
|
|
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',
|
2025-01-09 11:37:03 +00:00
|
|
|
validator: value => ['success', 'error', 'warning'].includes(value),
|
2025-01-09 11:01:35 +00:00
|
|
|
},
|
|
|
|
text: {
|
|
|
|
type: String,
|
2025-01-09 11:37:03 +00:00
|
|
|
default: '',
|
|
|
|
},
|
2025-01-09 11:01:35 +00:00
|
|
|
})
|
|
|
|
|
|
|
|
const typeConfig = {
|
|
|
|
success: {
|
|
|
|
imgSrc: success,
|
|
|
|
borderColor: '#C5E7D5',
|
2025-01-09 11:37:03 +00:00
|
|
|
bgColor: '#EDF7F2',
|
2025-01-09 11:01:35 +00:00
|
|
|
},
|
|
|
|
error: {
|
|
|
|
imgSrc: error,
|
|
|
|
borderColor: '#F3CBD3',
|
2025-01-09 11:37:03 +00:00
|
|
|
bgColor: '#FBEEF1',
|
2025-01-09 11:01:35 +00:00
|
|
|
},
|
|
|
|
warning: {
|
|
|
|
imgSrc: warning,
|
|
|
|
borderColor: '#FAE0B5',
|
2025-01-09 11:37:03 +00:00
|
|
|
bgColor: '#FEF7ED',
|
|
|
|
},
|
2025-01-09 11:01:35 +00:00
|
|
|
}
|
|
|
|
</script>
|
|
|
|
|
|
|
|
<template>
|
2025-01-09 11:37:03 +00:00
|
|
|
<div
|
|
|
|
class="box-border min-h-[46px] w-[343px] flex items-center border rounded-[4px] px-[15px] shadow-sm"
|
2025-01-09 11:01:35 +00:00
|
|
|
:style="{
|
|
|
|
borderColor: typeConfig[type].borderColor,
|
2025-01-09 11:37:03 +00:00
|
|
|
backgroundColor: typeConfig[type].bgColor,
|
2025-01-09 11:01:35 +00:00
|
|
|
}"
|
|
|
|
>
|
2025-01-09 11:37:03 +00:00
|
|
|
<div class="mr-[9px] h-[20px] w-[20px]">
|
|
|
|
<img
|
|
|
|
:src="typeConfig[type].imgSrc"
|
|
|
|
class="h-full w-full"
|
2025-01-09 11:01:35 +00:00
|
|
|
alt=""
|
|
|
|
>
|
|
|
|
</div>
|
2025-01-09 11:37:03 +00:00
|
|
|
<div class="text-[14px] text-black leading-normal">
|
|
|
|
{{ text }}
|
|
|
|
</div>
|
2025-01-09 11:01:35 +00:00
|
|
|
</div>
|
|
|
|
</template>
|