123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115 |
- <template>
- <view>
- <van-overlay v-if="overlay" :show="show" :z-index="zIndex" :custom-style="overlayStyle" :duration="duration" @click="onClickOverlay" />
- <view
- v-if="inited"
- :class="'custom-class ' + classes + ' ' + utils.bem('popup', [position, { round, safe: safeAreaInsetBottom, safeTop: safeAreaInsetTop }])"
- :style="
- 'z-index: ' +
- zIndex +
- '; -webkit-transition-duration:' +
- currentDuration +
- 'ms; transition-duration:' +
- currentDuration +
- 'ms; ' +
- (display ? '' : 'display: none;') +
- ';' +
- customStyle
- "
- @transitionend="onTransitionEnd"
- >
- <slot />
- <van-icon
- v-if="closeable"
- :name="closeIcon"
- :class="'close-icon-class van-popup__close-icon van-popup__close-icon--' + closeIconPosition"
- @tap.native="onClickCloseIcon"
- />
- </view>
- </view>
- </template>
- <script module="utils" lang="wxs" src="@/miniprogram_npm/@vant/weapp/wxs/utils.wxs"></script>
- <script>
- 'use strict';
- Object.defineProperty(exports, '__esModule', {
- value: true
- });
- var component_1 = require('../common/component');
- var transition_1 = require('../mixins/transition');
- component_1.VantComponent({
- classes: ['enter-class', 'enter-active-class', 'enter-to-class', 'leave-class', 'leave-active-class', 'leave-to-class', 'close-icon-class'],
- mixins: [transition_1.transition(false)],
- props: {
- round: Boolean,
- closeable: Boolean,
- customStyle: String,
- overlayStyle: String,
- transition: {
- type: String,
- observer: 'observeClass'
- },
- zIndex: {
- type: Number,
- value: 100
- },
- overlay: {
- type: Boolean,
- value: true
- },
- closeIcon: {
- type: String,
- value: 'cross'
- },
- closeIconPosition: {
- type: String,
- value: 'top-right'
- },
- closeOnClickOverlay: {
- type: Boolean,
- value: true
- },
- position: {
- type: String,
- value: 'center',
- observer: 'observeClass'
- },
- safeAreaInsetBottom: {
- type: Boolean,
- value: true
- },
- safeAreaInsetTop: {
- type: Boolean,
- value: false
- }
- },
- created: function () {
- this.observeClass();
- },
- methods: {
- onClickCloseIcon: function () {
- this.$emit('close');
- },
- onClickOverlay: function () {
- this.$emit('click-overlay');
- if (this.closeOnClickOverlay) {
- this.$emit('close');
- }
- },
- observeClass: function () {
- var _a = this;
- var transition = _a.transition;
- var position = _a.position;
- var updateData = {
- name: transition || position
- };
- if (transition === 'none') {
- updateData.duration = 0;
- }
- this.setData(updateData);
- }
- }
- });
- </script>
- <style>
- @import './index.css';
- </style>
|