feat(ShareSheet): no longer rely on CDN images (#10469)

This commit is contained in:
neverland 2022-04-05 09:50:26 +08:00 committed by GitHub
parent c4535ef77c
commit 800d9a6af9
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 68 additions and 19 deletions

View File

@ -12,6 +12,7 @@ import {
import { popupSharedProps, popupSharedPropKeys } from '../popup/shared'; import { popupSharedProps, popupSharedPropKeys } from '../popup/shared';
// Components // Components
import { Icon } from '../icon';
import { Popup } from '../popup'; import { Popup } from '../popup';
export type ShareSheetOption = { export type ShareSheetOption = {
@ -23,17 +24,6 @@ export type ShareSheetOption = {
export type ShareSheetOptions = ShareSheetOption[] | ShareSheetOption[][]; export type ShareSheetOptions = ShareSheetOption[] | ShareSheetOption[][];
const PRESET_ICONS = [
'qq',
'link',
'weibo',
'wechat',
'poster',
'qrcode',
'weapp-qrcode',
'wechat-moments',
];
const popupInheritKeys = [ const popupInheritKeys = [
...popupSharedPropKeys, ...popupSharedPropKeys,
'round', 'round',
@ -41,12 +31,16 @@ const popupInheritKeys = [
'safeAreaInsetBottom', 'safeAreaInsetBottom',
] as const; ] as const;
function getIconURL(icon: string) { const iconMap: Record<string, string> = {
if (PRESET_ICONS.includes(icon)) { qq: 'qq',
return `https://img.yzcdn.cn/vant/share-sheet-${icon}.png`; link: 'link-o',
} weibo: 'weibo',
return icon; qrcode: 'qr',
} poster: 'photo-o',
wechat: 'wechat',
'weapp-qrcode': 'miniprogram-o',
'wechat-moments': 'wechat-moments',
};
const [name, bem, t] = createNamespace('share-sheet'); const [name, bem, t] = createNamespace('share-sheet');
@ -98,6 +92,17 @@ export default defineComponent({
} }
}; };
const renderIcon = (icon: string) => {
if (iconMap[icon]) {
return (
<div class={bem('icon', [icon])}>
<Icon name={iconMap[icon] || icon} />
</div>
);
}
return <img src={icon} class={bem('image-icon')} />;
};
const renderOption = (option: ShareSheetOption, index: number) => { const renderOption = (option: ShareSheetOption, index: number) => {
const { name, icon, className, description } = option; const { name, icon, className, description } = option;
return ( return (
@ -107,7 +112,7 @@ export default defineComponent({
class={[bem('option'), className, HAPTICS_FEEDBACK]} class={[bem('option'), className, HAPTICS_FEEDBACK]}
onClick={() => onSelect(option, index)} onClick={() => onSelect(option, index)}
> >
<img src={getIconURL(icon)} class={bem('icon')} /> {renderIcon(icon)}
{name && <span class={bem('name')}>{name}</span>} {name && <span class={bem('name')}>{name}</span>}
{description && ( {description && (
<span class={bem('option-description')}>{description}</span> <span class={bem('option-description')}>{description}</span>

View File

@ -65,12 +65,56 @@
user-select: none; user-select: none;
} }
&__icon { &__icon,
&__image-icon {
width: var(--van-share-sheet-icon-size); width: var(--van-share-sheet-icon-size);
height: var(--van-share-sheet-icon-size); height: var(--van-share-sheet-icon-size);
margin: 0 var(--van-padding-md); margin: 0 var(--van-padding-md);
} }
&__icon {
display: flex;
align-items: center;
justify-content: center;
color: var(--van-gray-7);
border-radius: 100%;
background-color: var(--van-gray-2);
&--link,
&--poster,
&--qrcode {
font-size: 26px;
}
&--weapp-qrcode {
font-size: 28px;
}
&--qq,
&--weibo,
&--wechat,
&--wechat-moments {
font-size: 30px;
color: var(--van-white);
}
&--qq {
background-color: #38b9fa;
}
&--wechat {
background-color: #0bc15f;
}
&--weibo {
background-color: #ee575e;
}
&--wechat-moments {
background-color: #7bc845;
}
}
&__name { &__name {
margin-top: var(--van-padding-xs); margin-top: var(--van-padding-xs);
padding: 0 var(--van-padding-base); padding: 0 var(--van-padding-base);