Chamilo is a learning management system focused on ease of use and accessibility
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
chamilo-lms/assets/vue/components/basecomponents/BaseDialog.vue

50 lines
937 B

<script setup>
import Dialog from "primevue/dialog"
import { iconValidator } from "./validators"
import BaseIcon from "./BaseIcon.vue"
const isVisible = defineModel("isVisible", {
required: true,
type: Boolean,
})
defineProps({
title: {
type: String,
required: true,
},
headerIcon: {
type: String,
default: "",
validator: (value) => {
if (value === "") {
return true
}
return iconValidator(value)
},
},
})
</script>
<template>
<Dialog
v-model:visible="isVisible"
:modal="true"
class="p-fluid"
>
<template #header>
<div class="text-left">
<BaseIcon
v-if="headerIcon"
:icon="headerIcon"
class="mr-2"
/>
<span class="font-semibold">{{ title }}</span>
</div>
</template>
<slot></slot>
<template #footer>
<slot name="footer"></slot>
</template>
</Dialog>
</template>