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

47 lines
979 B

<template>
<Dialog
:modal="true"
:style="{ width: '450px' }"
:visible="isVisible"
class="p-fluid"
@update:visible="$emit('update:isVisible', $event)"
>
<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>
<script setup>
import Dialog from "primevue/dialog";
import {iconValidator} from "./validators";
import BaseIcon from "./BaseIcon.vue";
defineProps({
title: {
type: String,
required: true,
},
isVisible: {
type: Boolean,
required: true,
},
headerIcon: {
type: String,
default: '',
validator: (value) => {
if (value === '') { return true }
return iconValidator(value);
},
},
});
defineEmits(["update:isVisible"]);
</script>