import { ComponentType } from 'react' import { StandardProps, CommonEventFunction } from './common' interface ShareElementProps extends StandardProps { /** 映射标记 * @supported weapp * @deprecated 使用mapkey替换key */ key?: string /** 映射标记 * @supported weapp * @unique */ mapkey?: string /** 映射标记 * @supported alipay */ name?: string /** 是否进行动画 * @default false * @supported weapp, alipay */ transform?: boolean /** 动画时长,单位毫秒 * @default 300 * @supported weapp, alipay */ duration?: number /** css缓动函数 * @default ease-out * @supported weapp, alipay */ easingFunction?: string /** 手势返回时是否进行动画 * @supported weapp * @default false */ transitionOnGesture?: boolean /** 指定 push 阶段的飞跃物 * @supported weapp * @default "to" */ shuttleOnPush?: 'from' | 'to' | 'from' | 'to' /** 指定 pop 阶段的飞跃物 * @supported weapp * @default "to" */ shuttleOnPop?: string /** 动画插值曲线 * @supported weapp * @default "materialRectArc" */ rectTweenType?: | 'materialRectArc' | 'materialRectCenterArc' | 'linear' | 'elasticIn' | 'elasticOut' | 'elasticInOut' | 'bounceIn' | 'bounceOut' | 'bounceInOut' | 'cubic-bezier(x1, y1, x2, y2)' /** 动画帧回调 * @supported weapp */ onFrameWorklet?: string } /** 共享元素 * * 共享元素是一种动画形式,类似于 [`flutter Hero`](https://flutterchina.club/animations/hero-animations/) 动画,表现为元素像是在页面间穿越一样。该组件需与 [`PageContainer`](/docs/components/viewContainer/page-container) 组件结合使用。 * 使用时需在当前页放置 `ShareElement` 组件,同时在 `PageContainer` 容器中放置对应的 `ShareElement` 组件,对应关系通过属性值 key 映射。当设置 `PageContainer` `显示时,transform` 属性为 `true` 的共享元素会产生动画。当前页面容器退出时,会产生返回动画。 * @classification skyline * @supported weapp, alipay * @example_react * ```tsx * // index.js * import { useState, useCallback } from 'react' * import { View, Button, PageContainer, ShareElement } from '@tarojs/components' * * import './index.scss' * * const contacts = [ * { id: 1, name: 'Frank', img: 'frank.png', phone: '0101 123456', mobile: '0770 123456', email: 'frank@emailionicsorter.com' }, * { id: 2, name: 'Susan', img: 'susan.png', phone: '0101 123456', mobile: '0770 123456', email: 'frank@emailionicsorter.com' }, * { id: 3, name: 'Emma', img: 'emma.png', phone: '0101 123456', mobile: '0770 123456', email: 'frank@emailionicsorter.com' }, * { id: 4, name: 'Scott', img: 'scott.png', phone: '0101 123456', mobile: '0770 123456', email: 'frank@emailionicsorter.com' }, * { id: 5, name: 'Bob', img: 'bob.png', phone: '0101 123456', mobile: '0770 123456', email: 'frank@emailionicsorter.com' }, * { id: 6, name: 'Olivia', img: 'olivia.png', phone: '0101 123456', mobile: '0770 123456', email: 'frank@emailionicsorter.com' }, * { id: 7, name: 'Anne', img: 'anne.png', phone: '0101 123456', mobile: '0770 123456', email: 'frank@emailionicsorter.com' }, * { id: 8, name: 'sunny', img: 'olivia.png', phone: '0101 123456', mobile: '0770 123456', email: 'frank@emailionicsorter.com' } * ] * * export default function () { * const [show, setShow] = useState(false) * const [contact, setContact] = useState(contacts[0]) * const [transformIdx, setTransformIdx] = useState(0) * * const onBeforeEnter = useCallback((res) => { * console.log('onBeforeEnter: ', res) * }, []) * const onEnter = useCallback((res) => { * console.log('onEnter: ', res) * }, []) * const onAfterEnter = useCallback((res) => { * console.log('onAfterEnter: ', res) * }, []) * const onBeforeLeave = useCallback((res) => { * console.log('onBeforeLeave: ', res) * }, []) * const onLeave = useCallback((res) => { * console.log('onLeave: ', res) * }, []) * const onAfterLeave = useCallback((res) => { * console.log('onAfterLeave: ', res) * }, []) * * const showNext = (e, index) => { * setShow(true) * setContact(contacts[index]) * setTransformIdx(index) * } * * const showPrev = useCallback(() => { * setShow(false) * }, []) * * return ( * * * { * contacts.map((item, index) => ( * showNext(e, index)}> * * {item.name} * * * Phone: {item.phone} * Mobile: {item.mobile} * Email: {item.email} * * * )) * } * * * * * * {contact.name} * * * Lorem ipsum dolor sit amet, consectetur adipiscing elit. Vivamus nisl enim, sodales non augue efficitur, sagittis * varius neque. Fusce dolor turpis, maximus eu volutpat quis, pellentesque et ligula. Ut vehicula metus in nibh * mollis ornare. Etiam aliquam lacinia malesuada. Vestibulum dignissim mollis quam a tristique. Maecenas neque * mauris, malesuada vitae magna eu, congue consectetur risus. Etiam vitae pulvinar ex. Maecenas suscipit mi ac * imperdiet pretium. Aliquam velit mauris, euismod quis elementum sed, malesuada non dui. Nunc rutrum sagittis * ligula in dapibus. Cras suscipit ut augue eget mollis. Donec auctor feugiat ipsum id viverra. Vestibulum eu nisi * risus. Vestibulum eleifend dignissim. * * * * * * * * ) * } * ``` * ```scss * \/** index.scss *\/ * page { * color: #333; * background-color: #ddd; * overflow: hidden; * } * * button { * border: 0 solid #0010ae; * background-color: #1f2afe; * color: #fff; * font-size: 120%; * padding: 8px 16px; * outline-width: 0; * -webkit-appearance: none; * box-shadow: 0 8px 17px rgba(0, 0, 0, 0.2); * } * * .screen { * position: absolute; * top: 0; * bottom: 0; * left: 0; * right: 0; * padding: 16px; * -webkit-overflow-scrolling: touch; * } * * .contact { * position: relative; * padding: 16px; * background-color: #fff; * width: 100%; * height: 100%; * box-sizing: border-box; * } * * .avatar { * position: absolute; * top: 16px; * left: 16px; * font-size: 0; * } * * .name { * height: 65px; * font-size: 2em; * font-weight: bold; * text-align: center; * margin: 10px 0; * } * * .list { * padding-top: 8px; * padding-left: 32px; * } * * .screen1 { * overflow-y: scroll; * padding: 0; * } * * .screen1 .contact { * margin: 16px; * height: auto; * width: auto; * box-shadow: 0 2px 5px 0 rgba(0, 0, 0, 0.2); * } * * .screen2-button { * display: block; * margin: 24px auto; * } * * .paragraph { * -webkit-transition: transform ease-in-out 300ms; * transition: transform ease-in-out 300ms; * -webkit-transform: scale(0.6); * transform: scale(0.6); * } * * .enter.paragraph { * transform: none; * } * ``` * @see https://developers.weixin.qq.com/miniprogram/dev/component/share-element.html */ declare const ShareElement: ComponentType export { ShareElement, ShareElementProps }