| ¶Ô±ÈÐÂÎļþ | 
|  |  |  | 
|---|
|  |  |  | <template> | 
|---|
|  |  |  | <el-dialog | 
|---|
|  |  |  | :class="className" | 
|---|
|  |  |  | width="525px" | 
|---|
|  |  |  | v-bind="attrs" | 
|---|
|  |  |  | :show-close="false" | 
|---|
|  |  |  | @close="() => onClose(false)" | 
|---|
|  |  |  | @open="onOpen" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <div | 
|---|
|  |  |  | :style="` | 
|---|
|  |  |  | height: ${currentHeight}; | 
|---|
|  |  |  | overflow: ${attrs.height ? 'auto' : 'initial'}; | 
|---|
|  |  |  | padding-right: 20px; | 
|---|
|  |  |  | `" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <slot></slot> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <template #header> | 
|---|
|  |  |  | <div class="cs-dialog-content"> | 
|---|
|  |  |  | <p>{{ _t(attrs.title) }}</p> | 
|---|
|  |  |  | <Icon | 
|---|
|  |  |  | style="cursor: pointer" | 
|---|
|  |  |  | :width="16" | 
|---|
|  |  |  | :height="16" | 
|---|
|  |  |  | icon="X" | 
|---|
|  |  |  | @click="onClose" | 
|---|
|  |  |  | /> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </template> | 
|---|
|  |  |  | <template #footer v-if="!attrs.isHideFooter"> | 
|---|
|  |  |  | <div class="cs-dialog-footer"> | 
|---|
|  |  |  | <slot name="footer" v-if="footer"></slot> | 
|---|
|  |  |  | <template v-else> | 
|---|
|  |  |  | <slot name="custom-btn"></slot> | 
|---|
|  |  |  | <el-button | 
|---|
|  |  |  | @click="onClose" | 
|---|
|  |  |  | type="info" | 
|---|
|  |  |  | plain | 
|---|
|  |  |  | class="dialog-btn cs-base-btn" | 
|---|
|  |  |  | >{{ _t('åæ¶') }}</el-button | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <el-button | 
|---|
|  |  |  | v-if="!attrs.hideSubmit" | 
|---|
|  |  |  | :disabled="attrs.submitDisabled" | 
|---|
|  |  |  | @click="onConfirm" | 
|---|
|  |  |  | type="primary" | 
|---|
|  |  |  | class="cs-base-btn" | 
|---|
|  |  |  | >{{ _t('确认') }}</el-button | 
|---|
|  |  |  | > | 
|---|
|  |  |  | </template> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </template> | 
|---|
|  |  |  | </el-dialog> | 
|---|
|  |  |  | </template> | 
|---|
|  |  |  | <script lang="ts" setup> | 
|---|
|  |  |  | import { useAttrs, computed, useSlots } from 'vue' | 
|---|
|  |  |  | import { _t } from '@/libs/Language/Language' | 
|---|
|  |  |  | import Icon from '../Icon/Icon' | 
|---|
|  |  |  | const footer = !!useSlots().footer | 
|---|
|  |  |  | const emit = defineEmits(['close', 'confirm', 'open']) | 
|---|
|  |  |  | const attrs = useAttrs() | 
|---|
|  |  |  | const props = defineProps<{ [key: string]: any }>() | 
|---|
|  |  |  | const className = computed(() => { | 
|---|
|  |  |  | if (attrs.class) { | 
|---|
|  |  |  | return `without-cs-dialog ${attrs.class}` | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return 'without-cs-dialog' | 
|---|
|  |  |  | }) | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // å
³éå¼¹çªé½ä¼è°è¿ä¸ªæ¹æ³ï¼æäºæ¶åç¹å»confirmçæ¶åä¸è½åæ¶è§¦åcloseçï¼å ä¸ªåæ°ï¼ç¨äºåºåæ¯ç¹å»æé®å
³éçäºä»¶è¿æ¯closeäºä»¶ | 
|---|
|  |  |  | const onClose = (isClose = true) => emit('close', isClose) | 
|---|
|  |  |  |  | 
|---|
|  |  |  | const onConfirm = () => emit('confirm') | 
|---|
|  |  |  |  | 
|---|
|  |  |  | const onOpen = () => emit('open') | 
|---|
|  |  |  |  | 
|---|
|  |  |  | const currentHeight = computed(() => { | 
|---|
|  |  |  | return attrs.height || 'auto' | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | </script> | 
|---|
|  |  |  | <style lang="scss"> | 
|---|
|  |  |  | .without-cs-dialog { | 
|---|
|  |  |  | box-shadow: 0px 3px 6px 1px rgba(0, 0, 0, 0.16); | 
|---|
|  |  |  | border-radius: 6px 6px 6px 6px; | 
|---|
|  |  |  | padding-top: 10px; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | header.cs-dialog__header { | 
|---|
|  |  |  | padding: 0; | 
|---|
|  |  |  | padding-bottom: 0; | 
|---|
|  |  |  | margin-right: 0; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | .cs-dialog__body { | 
|---|
|  |  |  | padding: 10px 20px; | 
|---|
|  |  |  | padding-right: 0; | 
|---|
|  |  |  | padding-bottom: 0; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .cs-dialog-content { | 
|---|
|  |  |  | width: 100%; | 
|---|
|  |  |  | height: 42px; | 
|---|
|  |  |  | border-radius: 6px 6px 0px 0px; | 
|---|
|  |  |  | display: flex; | 
|---|
|  |  |  | justify-content: space-between; | 
|---|
|  |  |  | align-items: center; | 
|---|
|  |  |  | padding: 10px 15px 0; | 
|---|
|  |  |  | /* padding-top: 36px; */ | 
|---|
|  |  |  |  | 
|---|
|  |  |  | p { | 
|---|
|  |  |  | /* width: 72px; */ | 
|---|
|  |  |  | /* height: 18px; */ | 
|---|
|  |  |  | margin: 0; | 
|---|
|  |  |  | font-size: 18px; | 
|---|
|  |  |  | font-family: Source Han Sans CN, Source Han Sans CN; | 
|---|
|  |  |  | font-weight: bold; | 
|---|
|  |  |  | color: #464e54; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | .cs-dialog__footer { | 
|---|
|  |  |  | padding: 0; | 
|---|
|  |  |  | padding-top: 10px; | 
|---|
|  |  |  | padding-bottom: 10px; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | .cs-dialog-footer { | 
|---|
|  |  |  | padding: 0 18px; | 
|---|
|  |  |  | padding-bottom: 10px; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .cs-base-btn { | 
|---|
|  |  |  | width: 98px; | 
|---|
|  |  |  | height: 26px; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | .dialog-btn { | 
|---|
|  |  |  | background: #efeded; | 
|---|
|  |  |  | color: #666666; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | .without-cs-dialog.is-fullscreen { | 
|---|
|  |  |  | overflow: hidden; | 
|---|
|  |  |  | .cs-dialog__body { | 
|---|
|  |  |  | height: calc(100% - 80px); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | </style> | 
|---|