80 lines
2.0 KiB
Vue
80 lines
2.0 KiB
Vue
<script setup lang="ts">
|
|
import type { InputProps } from 'element-plus';
|
|
|
|
import type { FileUploadProps } from './typing';
|
|
|
|
import { computed } from 'vue';
|
|
|
|
import { useVModel } from '@vueuse/core';
|
|
import { ElInput } from 'element-plus';
|
|
|
|
import FileUpload from './file-upload.vue';
|
|
|
|
const props = defineProps<{
|
|
defaultValue?: number | string;
|
|
fileUploadProps?: FileUploadProps;
|
|
inputProps?: InputProps;
|
|
inputType?: 'input' | 'textarea';
|
|
modelValue?: number | string;
|
|
textareaProps?: InputProps;
|
|
}>();
|
|
|
|
const emits = defineEmits<{
|
|
(e: 'change', payload: number | string): void;
|
|
(e: 'update:value', payload: number | string): void;
|
|
(e: 'update:modelValue', payload: number | string): void;
|
|
}>();
|
|
|
|
const modelValue = useVModel(props, 'modelValue', emits, {
|
|
defaultValue: props.defaultValue,
|
|
passive: true,
|
|
});
|
|
|
|
/** 处理文件内容返回 */
|
|
function handleReturnText(text: string) {
|
|
modelValue.value = text;
|
|
emits('change', modelValue.value);
|
|
emits('update:value', modelValue.value);
|
|
emits('update:modelValue', modelValue.value);
|
|
}
|
|
|
|
/** 计算输入框属性 */
|
|
const inputProps = computed(() => {
|
|
return {
|
|
...props.inputProps,
|
|
modelValue: modelValue.value,
|
|
};
|
|
});
|
|
|
|
/** 计算文本域属性 */
|
|
const textareaProps = computed(() => {
|
|
return {
|
|
...props.textareaProps,
|
|
modelValue: modelValue.value,
|
|
};
|
|
});
|
|
|
|
/** 计算文件上传属性 */
|
|
const fileUploadProps = computed(() => {
|
|
return {
|
|
...props.fileUploadProps,
|
|
};
|
|
});
|
|
</script>
|
|
|
|
<template>
|
|
<div class="w-full">
|
|
<ElInput v-if="inputType === 'input'" readonly v-bind="inputProps">
|
|
<template #suffix>
|
|
<FileUpload v-bind="fileUploadProps" @return-text="handleReturnText" />
|
|
</template>
|
|
</ElInput>
|
|
<div v-else class="relative w-full">
|
|
<ElInput readonly :rows="4" type="textarea" v-bind="textareaProps" />
|
|
<div class="absolute bottom-0 right-2">
|
|
<FileUpload v-bind="fileUploadProps" @return-text="handleReturnText" />
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</template>
|