diff --git a/packages/ui-vue/components/avatar/src/avatar.component.tsx b/packages/ui-vue/components/avatar/src/avatar.component.tsx index 4b63715b1067b47d174851c328dc1103ec3a3c73..120fb7f04fa435c5eab6f873709786351ce15606 100644 --- a/packages/ui-vue/components/avatar/src/avatar.component.tsx +++ b/packages/ui-vue/components/avatar/src/avatar.component.tsx @@ -2,65 +2,64 @@ import { defineComponent, computed, ref, SetupContext } from 'vue'; import { avatarProps, AvatarProps } from './avatar.props'; export default defineComponent({ - name: 'Avatar', - props: avatarProps, - emits: ['change'], - setup(props: AvatarProps, context: SetupContext) { - const avatarClass = computed(() => ({ - 'f-avatar': true, - 'f-avatar-readonly': props.readonly, - 'f-avatar-circle': props.shape === 'circle', - 'f-avatar-square': props.shape === 'square', - })); + name: 'Avatar', + props: avatarProps, + emits: ['change'], + setup(props: AvatarProps, context: SetupContext) { + const avatarClass = computed(() => ({ + 'f-avatar': true, + 'f-avatar-readonly': props.readonly, + 'f-avatar-circle': props.shape === 'circle', + 'f-avatar-square': props.shape === 'square' + })); - const avatarStyle = computed(() => ({ - width: props.avatarWidth + 'px', - height: props.avatarHeight + 'px', - })); + const avatarStyle = computed(() => ({ + width: props.avatarWidth + 'px', + height: props.avatarHeight + 'px' + })); - let showLoading = false; - let imgSrc = ''; + let showLoading = false; + let imgSrc = ''; - const currentImgType = ['image/image', 'image/webp', 'image/png', 'image/svg', 'image/gif', 'image/jpg', 'image/jpeg', 'image/bmp']; + const currentImgType = ['image/image', 'image/webp', 'image/png', 'image/svg', 'image/gif', 'image/jpg', 'image/jpeg', 'image/bmp']; - function errorSrc() { - return ''; - } - - function getfiledata() {} + function errorSrc() { + return ''; + } - const defaultImgSrc = - ''; - const errorImgSrc = - ''; + function getfiledata() {} - const imageType = computed(() => props.type.join()); + const defaultImgSrc = + ''; + const errorImgSrc = + ''; + const imageType = computed(() => props.type.join()); - return () => { - return ( -
- {showLoading && ( -
-
加载中
-
- )} - - {!props.readonly && ( -
- -
- )} - -
- ); - }; - }, + return () => { + return ( +
+ {showLoading && ( +
+
加载中
+
+ )} + + {!props.readonly && ( +
+ +
+ )} + +
+ ); + }; + } }); diff --git a/packages/ui-vue/components/avatar/src/composition/types.ts b/packages/ui-vue/components/avatar/src/composition/types.ts index 0e54c3e6821a9709dddc847166782be7f851837a..79e7e233c6a30cbea339fe2f245b23de8e6ef8ea 100644 --- a/packages/ui-vue/components/avatar/src/composition/types.ts +++ b/packages/ui-vue/components/avatar/src/composition/types.ts @@ -1,19 +1,19 @@ import { ComputedRef } from 'vue'; export interface UseImage { - acceptTypes: ComputedRef; + acceptTypes: ComputedRef; - imageSrc: ComputedRef; + imageSrc: ComputedRef; - imageTitle: ComputedRef; + imageTitle: ComputedRef; } export interface ImageFile { - size: number; - name: string; - type: string; - lastModified?: string; - lastModifiedDate?: Date; - state?: string; - base64?: string; + size: number; + name: string; + type: string; + lastModified?: string; + lastModifiedDate?: Date; + state?: string; + base64?: string; } diff --git a/packages/ui-vue/components/avatar/src/composition/use-file.ts b/packages/ui-vue/components/avatar/src/composition/use-file.ts index be512af6b6f5e45468194d8f5e93da99a0d78c99..e3150e32751dfc82d49a8089787beb5671ed1e82 100644 --- a/packages/ui-vue/components/avatar/src/composition/use-file.ts +++ b/packages/ui-vue/components/avatar/src/composition/use-file.ts @@ -5,88 +5,88 @@ import { AvatarProps } from '../avatar.props'; import { ImageFile } from './types'; export function useFile(props: AvatarProps, context: SetupContext, allowTypes: string[]) { - function getFileData($event: Event) { - if (props.readonly) { - return; - } - const fileInput = $event.target as HTMLInputElement; - const selectedFiles = fileInput.files; - if (!selectedFiles || !selectedFiles[0]) { - return; - } - const fileType = selectedFiles[0].type; - const isLtSize = selectedFiles[0].size / 1024 / 1024 < props.maxSize; - if (allowTypes.indexOf(fileType) < 0) { - const typeErrorMessage = this.localeService.getValue('avatar.typeError'); - this.notifyService.error({ - type: 'error', - title: '', - msg: typeErrorMessage, - }); - fileInput.value = ''; - return; - } + function getFileData($event: Event) { + if (props.readonly) { + return; + } + const fileInput = $event.target as HTMLInputElement; + const selectedFiles = fileInput.files; + if (!selectedFiles || !selectedFiles[0]) { + return; + } + const fileType = selectedFiles[0].type; + const isLtSize = selectedFiles[0].size / 1024 / 1024 < props.maxSize; + if (allowTypes.indexOf(fileType) < 0) { + const typeErrorMessage = this.localeService.getValue('avatar.typeError'); + this.notifyService.error({ + type: 'error', + title: '', + msg: typeErrorMessage + }); + fileInput.value = ''; + return; + } - if (!isLtSize) { - const sizeErrorMessageTemplate = this.localeService.getValue('avatar.sizeError'); - const sizeErrorMessage: string = sizeErrorMessageTemplate + props.maxSize + 'MB!'; - this.notifyService.error({ - type: 'error', - title: '', - msg: sizeErrorMessage, - }); - fileInput.value = ''; - return; + if (!isLtSize) { + const sizeErrorMessageTemplate = this.localeService.getValue('avatar.sizeError'); + const sizeErrorMessage: string = sizeErrorMessageTemplate + props.maxSize + 'MB!'; + this.notifyService.error({ + type: 'error', + title: '', + msg: sizeErrorMessage + }); + fileInput.value = ''; + return; + } + this.transformFile(selectedFiles[0]); + fileInput.value = ''; } - this.transformFile(selectedFiles[0]); - fileInput.value = ''; - } - function readSourceFile(sourceFile: File): Promise<{ state: string; content: string | ArrayBuffer | null }> { - const result = new Promise<{ state: string; content: string | ArrayBuffer | null }>((resolve, reject) => { - const reader = new FileReader(); - reader.readAsDataURL(sourceFile); - reader.onload = () => { - resolve({ state: 'done', content: reader.result }); - }; - reader.onerror = function () { - reject({ state: 'error', content: reader.result }); - }; - }); - return result; - } + function readSourceFile(sourceFile: File): Promise<{ state: string; content: string | ArrayBuffer | null }> { + const result = new Promise<{ state: string; content: string | ArrayBuffer | null }>((resolve, reject) => { + const reader = new FileReader(); + reader.readAsDataURL(sourceFile); + reader.onload = () => { + resolve({ state: 'done', content: reader.result }); + }; + reader.onerror = function () { + reject({ state: 'error', content: reader.result }); + }; + }); + return result; + } - function updateImageSrc(imageSrc: string) {} + function updateImageSrc(imageSrc: string) {} - function removeBase64(imageSrc: string) {} + function removeBase64(imageSrc: string) {} - function transformFile(sourceFile: File) { - // const subject = new Subject(); - const imageFile: ImageFile = { - size: sourceFile.size, - name: sourceFile.name, - type: sourceFile.type, - lastModified: String(sourceFile.lastModified), - }; - readSourceFile(sourceFile) - .then((result) => { - if (result.state === 'done') { - updateImageSrc(result.content as string); - const imageFileContent = removeBase64(imageSrc); - context.emit('change', imageFileContent); - context.emit('touched'); - imageFile.state = result.state; - imageFile.base64 = result.content as string; - context.emit('imageChange', imageFile); - } - }) - .catch((reason) => { - const uploadErrorText = this.localeService.getValue('avatar.uploadError'); - this.notifyService.error({ - type: 'error', - title: '', - msg: uploadErrorText, - }); - }); - } + function transformFile(sourceFile: File) { + // const subject = new Subject(); + const imageFile: ImageFile = { + size: sourceFile.size, + name: sourceFile.name, + type: sourceFile.type, + lastModified: String(sourceFile.lastModified) + }; + readSourceFile(sourceFile) + .then((result) => { + if (result.state === 'done') { + updateImageSrc(result.content as string); + const imageFileContent = removeBase64(imageSrc); + context.emit('change', imageFileContent); + context.emit('touched'); + imageFile.state = result.state; + imageFile.base64 = result.content as string; + context.emit('imageChange', imageFile); + } + }) + .catch((reason) => { + const uploadErrorText = this.localeService.getValue('avatar.uploadError'); + this.notifyService.error({ + type: 'error', + title: '', + msg: uploadErrorText + }); + }); + } } diff --git a/packages/ui-vue/components/avatar/src/composition/use-image.ts b/packages/ui-vue/components/avatar/src/composition/use-image.ts index cef6a3089f32cb4c971e91844f4e191f5ca8f4d5..92189c985011145b9855474d6d2ae08182cca4a5 100644 --- a/packages/ui-vue/components/avatar/src/composition/use-image.ts +++ b/packages/ui-vue/components/avatar/src/composition/use-image.ts @@ -3,69 +3,69 @@ import { AvatarProps } from '../avatar.props'; import { UseImage } from './types'; export function useImage(props: AvatarProps, context: SetupContext, fileInput: HTMLInputElement): UseImage { - const defaultImage = ''; - const errorImage = ''; + const defaultImage = ''; + const errorImage = ''; - // 判断是否是图片路径 - function isUrl(url: string) { - return url.match(/\.(jpeg|jpg|gif|png|svg|bmp|webp)$/) != null; - } - - // 判断是否是完成base64 - function isBase64Image(url: string) { - return url.indexOf('data:image/') > -1; - } + // 判断是否是图片路径 + function isUrl(url: string) { + return url.match(/\.(jpeg|jpg|gif|png|svg|bmp|webp)$/) != null; + } - function appendBase64ImageHeader(val) { - if (!val) { - return ''; + // 判断是否是完成base64 + function isBase64Image(url: string) { + return url.indexOf('data:image/') > -1; } - return 'data:image/jpeg;base64,' + val; - } - const acceptTypes = computed(() => { - if (!props.type || !props.type.length) { - return ''; + function appendBase64ImageHeader(val) { + if (!val) { + return ''; + } + return 'data:image/jpeg;base64,' + val; } - const imageTypesArray = props.type.map((fileType: string) => { - if (fileType === 'jpg') { - fileType = 'jpeg'; - } - return `image/${fileType}`; + + const acceptTypes = computed(() => { + if (!props.type || !props.type.length) { + return ''; + } + const imageTypesArray = props.type.map((fileType: string) => { + if (fileType === 'jpg') { + fileType = 'jpeg'; + } + return `image/${fileType}`; + }); + if (!imageTypesArray || !imageTypesArray.length) { + return 'image/*'; + } + return imageTypesArray.join(','); }); - if (!imageTypesArray || !imageTypesArray.length) { - return 'image/*'; - } - return imageTypesArray.join(','); - }); - const imageSrc = computed(() => { - if (!props.cover) { - return defaultImage; - } - if (isUrl(props.cover)) { - return props.cover; - } - if (isBase64Image(props.cover)) { - return props.cover; - } - return appendBase64ImageHeader(props.cover); - }); + const imageSrc = computed(() => { + if (!props.cover) { + return defaultImage; + } + if (isUrl(props.cover)) { + return props.cover; + } + if (isBase64Image(props.cover)) { + return props.cover; + } + return appendBase64ImageHeader(props.cover); + }); - const imageTitle = computed(() => { - return props.readonly ? '' : props.tile; - }); + const imageTitle = computed(() => { + return props.readonly ? '' : props.tile; + }); - function onClickImage() { - if (this.readonly) { - return; + function onClickImage() { + if (this.readonly) { + return; + } + fileInput.click(); } - fileInput.click(); - } - function getImageFile() { - return this.imgFileObj; - } + function getImageFile() { + return this.imgFileObj; + } - return { acceptTypes, imageSrc, imageTitle }; + return { acceptTypes, imageSrc, imageTitle }; } diff --git a/packages/ui-vue/src/App.vue b/packages/ui-vue/src/App.vue index ec795c7c9e84330f7b75bf0b7c85864615b5e70e..369c814d7cfd863f51101e07e30ee1e7930fda9d 100644 --- a/packages/ui-vue/src/App.vue +++ b/packages/ui-vue/src/App.vue @@ -4,6 +4,7 @@ import { ref } from "vue"; import HelloWorld from './components/hello-world.vue'; import ButtonEdit from "../components/button-edit/src/button-edit.component"; +import Avatar from './components/avatar.vue'; const canEdit = ref(true); const canAutoComplete = ref(false); @@ -25,6 +26,7 @@ const canAutoComplete = ref(false); +