| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566 |
- import {VantComponent} from '../common/component';
- import {WHITE} from '../common/color';
- import {getSystemInfoSync} from '../common/utils';
- VantComponent({
- props: {
- message: String,
- background: String,
- type: {
- type: String,
- value: 'danger',
- },
- color: {
- type: String,
- value: WHITE,
- },
- duration: {
- type: Number,
- value: 3000,
- },
- zIndex: {
- type: Number,
- value: 110,
- },
- safeAreaInsetTop: {
- type: Boolean,
- value: false,
- },
- top: null,
- },
- data: {
- show: false,
- onOpened: null,
- onClose: null,
- onClick: null,
- },
- created() {
- const {statusBarHeight} = getSystemInfoSync();
- this.setData({statusBarHeight});
- },
- methods: {
- show() {
- const {duration, onOpened} = this.data;
- clearTimeout(this.timer);
- this.setData({show: true});
- wx.nextTick(onOpened);
- if (duration > 0 && duration !== Infinity) {
- this.timer = setTimeout(() => {
- this.hide();
- }, duration);
- }
- },
- hide() {
- const {onClose} = this.data;
- clearTimeout(this.timer);
- this.setData({show: false});
- wx.nextTick(onClose);
- },
- onTap(event) {
- const {onClick} = this.data;
- if (onClick) {
- onClick(event.detail);
- }
- },
- },
- });
|