Skip to content

Commit

Permalink
内建组件补充
Browse files Browse the repository at this point in the history
  • Loading branch information
hooray committed Jul 4, 2024
1 parent 74a7214 commit d5d41ad
Show file tree
Hide file tree
Showing 2 changed files with 85 additions and 0 deletions.
1 change: 1 addition & 0 deletions src/types/components.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@ declare module 'vue' {
AuthAll: typeof import('./../components/AuthAll/index.vue')['default']
HBadge: typeof import('./../ui-kit/HBadge.vue')['default']
HButton: typeof import('./../ui-kit/HButton.vue')['default']
HDialog: typeof import('./../ui-kit/HDialog.vue')['default']
HInput: typeof import('./../ui-kit/HInput.vue')['default']
HSlideover: typeof import('./../ui-kit/HSlideover.vue')['default']
HTabList: typeof import('./../ui-kit/HTabList.vue')['default']
Expand Down
84 changes: 84 additions & 0 deletions src/ui-kit/HDialog.vue
Original file line number Diff line number Diff line change
@@ -0,0 +1,84 @@
<script setup lang="ts">
import { Dialog, DialogDescription, DialogPanel, DialogTitle, TransitionChild, TransitionRoot } from '@headlessui/vue'
withDefaults(
defineProps<{
appear?: boolean
title?: string
noTitle?: boolean
preventClose?: boolean
overlay?: boolean
}>(),
{
appear: false,
noTitle: false,
preventClose: false,
overlay: false,
},
)
const emits = defineEmits<{
close: []
}>()
const isOpen = defineModel<boolean>({
default: false,
})
const slots = useSlots()
const overlayTransitionClass = ref({
enter: 'ease-in-out duration-500',
enterFrom: 'opacity-0',
enterTo: 'opacity-100',
leave: 'ease-in-out duration-500',
leaveFrom: 'opacity-100',
leaveTo: 'opacity-0',
})
const transitionClass = computed(() => {
return {
enter: 'ease-out duration-300',
enterFrom: 'opacity-0 translate-y-4 lg-translate-y-0 lg-scale-95',
enterTo: 'opacity-100 translate-y-0 lg-scale-100',
leave: 'ease-in duration-200',
leaveFrom: 'opacity-100 translate-y-0 lg-scale-100',
leaveTo: 'opacity-0 translate-y-4 lg-translate-y-0 lg-scale-95',
}
})
function close() {
isOpen.value = false
emits('close')
}
</script>

<template>
<TransitionRoot as="template" :appear="appear" :show="isOpen">
<Dialog class="fixed inset-0 z-2000 flex" @close="!preventClose && close()">
<TransitionChild as="template" :appear="appear" v-bind="overlayTransitionClass">
<div class="fixed inset-0 bg-stone-2/75 transition-opacity dark-bg-stone-8/75" :class="{ 'backdrop-blur-sm': overlay }" />
</TransitionChild>
<div class="fixed inset-0 overflow-y-auto">
<div class="min-h-full flex items-end justify-center p-4 text-center lg-items-center">
<TransitionChild as="template" :appear="appear" v-bind="transitionClass">
<DialogPanel class="relative w-full flex flex-col overflow-hidden rounded-xl bg-white text-left shadow-xl lg-my-8 lg-max-w-lg dark-bg-stone-8">
<div v-if="!noTitle" flex="~ items-center justify-between" px-4 py-3 border-b="~ solid stone/15" text-6>
<DialogTitle m-0 text-lg text-dark dark-text-white>
{{ title }}
</DialogTitle>
<SvgIcon name="i-carbon:close" cursor-pointer @click="close" />
</div>
<DialogDescription m-0 overflow-y-auto p-4 text-start>
<slot />
</DialogDescription>
<div v-if="!!slots.footer" flex="~ items-center justify-end" px-4 py-3 border-t="~ solid stone/15">
<slot name="footer" />
</div>
</DialogPanel>
</TransitionChild>
</div>
</div>
</Dialog>
</TransitionRoot>
</template>

0 comments on commit d5d41ad

Please sign in to comment.