feat(Image): add previewMask prop (#5531)

* fix(Image): can not cancel previewMask

* remove redundant code

* remove redundant code

* update code
pull/5539/head
bqy_fe 2022-04-22 16:22:36 +08:00 committed by GitHub
parent 9b6e742f0c
commit bc3843b774
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 27 additions and 39 deletions

View File

@ -22,7 +22,7 @@ Previewable image.
| placeholder | Load placeholder, use default placeholder when set `true` | boolean \| slot | - | 2.0.0 | | placeholder | Load placeholder, use default placeholder when set `true` | boolean \| slot | - | 2.0.0 |
| preview | preview config, disabled when `false` | boolean \| [previewType](#previewType) | true | 2.0.0 | | preview | preview config, disabled when `false` | boolean \| [previewType](#previewType) | true | 2.0.0 |
| src | Image path | string | - | 2.0.0 | | src | Image path | string | - | 2.0.0 |
| previewMask | custom mask | slot | - | 3.2.0 | | previewMask | custom mask | boolean \| function \| slot | - | 3.2.0 |
| width | Image width | string \| number | - | 2.0.0 | | width | Image width | string \| number | - | 2.0.0 |
### events ### events

View File

@ -49,13 +49,16 @@ const Image = defineComponent<ImageProps>({
v-slots={{ v-slots={{
...slots, ...slots,
previewMask: previewMask:
slots.previewMask ?? props.previewMask === false
(() => ( ? null
<div class={`${prefixCls.value}-mask-info`}> : props.previewMask ??
<EyeOutlined /> slots.previewMask ??
{imageLocale?.preview} (() => (
</div> <div class={`${prefixCls.value}-mask-info`}>
)), <EyeOutlined />
{imageLocale?.preview}
</div>
)),
}} }}
></ImageInternal> ></ImageInternal>
); );

View File

@ -23,7 +23,7 @@ cover: https://gw.alipayobjects.com/zos/antfincdn/D1dXz9PZqa/image.svg
| placeholder | 加载占位, 为 `true` 时使用默认占位 | boolean \| slot | - | 2.0.0 | | placeholder | 加载占位, 为 `true` 时使用默认占位 | boolean \| slot | - | 2.0.0 |
| preview | 预览参数,为 `false` 时禁用 | boolean \| [previewType](#previewType) | true | 2.0.0 | | preview | 预览参数,为 `false` 时禁用 | boolean \| [previewType](#previewType) | true | 2.0.0 |
| src | 图片地址 | string | - | 2.0.0 | | src | 图片地址 | string | - | 2.0.0 |
| previewMask | 自定义 mask | slot | - | 3.2.0 | | previewMask | 自定义 mask | boolean \| function \| slot | - | 3.2.0 |
| width | 图像宽度 | string \| number | - | 2.0.0 | | width | 图像宽度 | string \| number | - | 2.0.0 |
### 事件 ### 事件

View File

@ -25,19 +25,6 @@ export type ImagePreviewType = Omit<
icons?: PreviewProps['icons']; icons?: PreviewProps['icons'];
}; };
export interface ImagePropsType extends Omit<ImgHTMLAttributes, 'placeholder' | 'onClick'> {
// Original
src?: string;
wrapperClassName?: string;
wrapperStyle?: CSSProperties;
prefixCls?: string;
previewPrefixCls?: string;
placeholder?: boolean;
fallback?: string;
preview?: boolean | ImagePreviewType;
onClick?: MouseEventHandler;
onError?: HTMLImageElement['onerror'];
}
export const imageProps = () => ({ export const imageProps = () => ({
src: String, src: String,
wrapperClassName: String, wrapperClassName: String,
@ -45,6 +32,10 @@ export const imageProps = () => ({
rootClassName: String, rootClassName: String,
prefixCls: String, prefixCls: String,
previewPrefixCls: String, previewPrefixCls: String,
previewMask: {
type: [Boolean, Function] as PropType<boolean | (() => any)>,
default: undefined,
},
placeholder: PropTypes.any, placeholder: PropTypes.any,
fallback: String, fallback: String,
preview: { preview: {
@ -103,9 +94,7 @@ const ImageInternal = defineComponent({
value: previewVisible, value: previewVisible,
onChange: onPreviewVisibleChange, onChange: onPreviewVisibleChange,
}); });
watch(previewVisible, val => {
setShowPreview(Boolean(val));
});
watch(isShowPreview, (val, preVal) => { watch(isShowPreview, (val, preVal) => {
onPreviewVisibleChange(val, preVal); onPreviewVisibleChange(val, preVal);
}); });

View File

@ -3,6 +3,7 @@ import { ref, provide, defineComponent, inject, watch, reactive, computed, watch
import { type ImagePreviewType, mergeDefaultValue } from './Image'; import { type ImagePreviewType, mergeDefaultValue } from './Image';
import Preview from './Preview'; import Preview from './Preview';
import type { PreviewProps } from './Preview'; import type { PreviewProps } from './Preview';
import useMergedState from '../../_util/hooks/useMergedState';
export interface PreviewGroupPreview export interface PreviewGroupPreview
extends Omit<ImagePreviewType, 'icons' | 'mask' | 'maskClassName'> { extends Omit<ImagePreviewType, 'icons' | 'mask' | 'maskClassName'> {
@ -85,10 +86,14 @@ const Group = defineComponent({
const current = ref<number>(); const current = ref<number>();
const previewVisible = computed(() => preview.value.visible); const previewVisible = computed(() => preview.value.visible);
const onPreviewVisibleChange = computed(() => preview.value.onVisibleChange);
const getPreviewContainer = computed(() => preview.value.getContainer); const getPreviewContainer = computed(() => preview.value.getContainer);
const onPreviewVisibleChange = (val, preval) => {
const isShowPreview = ref(!!previewVisible.value); preview.value.onVisibleChange?.(val, preval);
};
const [isShowPreview, setShowPreview] = useMergedState(!!previewVisible.value, {
value: previewVisible,
onChange: onPreviewVisibleChange,
});
const mousePosition = ref<{ x: number; y: number }>(null); const mousePosition = ref<{ x: number; y: number }>(null);
const isControlled = computed(() => previewVisible.value !== undefined); const isControlled = computed(() => previewVisible.value !== undefined);
@ -115,9 +120,6 @@ const Group = defineComponent({
const setMousePosition = (val: null | { x: number; y: number }) => { const setMousePosition = (val: null | { x: number; y: number }) => {
mousePosition.value = val; mousePosition.value = val;
}; };
const setShowPreview = (val: boolean) => {
isShowPreview.value = val;
};
const registerImage = (id: number, url: string, canPreview = true) => { const registerImage = (id: number, url: string, canPreview = true) => {
const unRegister = () => { const unRegister = () => {
@ -132,16 +134,10 @@ const Group = defineComponent({
const onPreviewClose = (e: any) => { const onPreviewClose = (e: any) => {
e?.stopPropagation(); e?.stopPropagation();
isShowPreview.value = false; setShowPreview(false);
mousePosition.value = null; setMousePosition(null);
}; };
watch(previewVisible, () => {
isShowPreview.value = !!previewVisible.value;
});
watch(isShowPreview, (val, preVal) => {
onPreviewVisibleChange.value(val, preVal);
});
watch( watch(
currentControlledKey, currentControlledKey,
val => { val => {