mirror of
https://github.com/koel/koel
synced 2024-11-24 21:23:06 +00:00
48 lines
1 KiB
Vue
48 lines
1 KiB
Vue
<template>
|
|
<div
|
|
:class="`alert-box-${props.type}`"
|
|
class="alert-box flex items-center gap-4 bg-white/10 mb-6 p-4 rounded-md text-k-text-primary"
|
|
>
|
|
<Icon v-if="props.type === 'info' || props.type === 'default'" :icon="faInfoCircle" />
|
|
<Icon v-if="props.type === 'danger'" :icon="faExclamationCircle" />
|
|
<Icon v-if="props.type === 'success'" :icon="faCheckCircle" />
|
|
<Icon v-if="props.type === 'warning'" :icon="faExclamationTriangle" />
|
|
|
|
<div class="flex-1">
|
|
<slot />
|
|
</div>
|
|
</div>
|
|
</template>
|
|
|
|
<script lang="ts" setup>
|
|
import {
|
|
faCheckCircle,
|
|
faExclamationCircle,
|
|
faExclamationTriangle,
|
|
faInfoCircle
|
|
} from '@fortawesome/free-solid-svg-icons'
|
|
|
|
const props = withDefaults(defineProps<{ type?: 'default' | 'info' | 'danger' | 'success' | 'warning' }>(), {
|
|
type: 'default'
|
|
})
|
|
</script>
|
|
|
|
<style lang="postcss" scoped>
|
|
.alert-box {
|
|
&-info {
|
|
@apply bg-blue-500;
|
|
}
|
|
|
|
&-success {
|
|
@apply bg-green-600;
|
|
}
|
|
|
|
&-warning {
|
|
@apply bg-orange-500;
|
|
}
|
|
|
|
&-danger {
|
|
@apply bg-red-500;
|
|
}
|
|
}
|
|
</style>
|