ucToast 支持position:top/bottom
This commit is contained in:
		
							parent
							
								
									7bec07d04b
								
							
						
					
					
						commit
						a2d4c4b9af
					
				@ -9,11 +9,21 @@ based on
 | 
				
			|||||||
 *duration: 消失时间(Number),默认2000
 | 
					 *duration: 消失时间(Number),默认2000
 | 
				
			||||||
 *distance: 弹窗间距,默认128,可设为0代表重叠
 | 
					 *distance: 弹窗间距,默认128,可设为0代表重叠
 | 
				
			||||||
 *clickable: 是否点击消失(Boolean),默认false
 | 
					 *clickable: 是否点击消失(Boolean),默认false
 | 
				
			||||||
 | 
					 *position: top|bottom, 出现在屏幕顶部或底部,默认为 top
 | 
				
			||||||
 -->
 | 
					 -->
 | 
				
			||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <view class="popup_list">
 | 
					  <view class="popup_list">
 | 
				
			||||||
    <view v-for="(toast, index) of popup_list" :id="toast.uuid" :key="toast.uuid">
 | 
					    <view v-for="(toast, index) of popup_list" :id="toast.uuid" :key="toast.uuid">
 | 
				
			||||||
			<view class="mpopup" :style="{ background: toast.color ,top:index*toast.distance+50+'px'}" :class="[toast.animator,'mpopup-'+toast.type]" @click="close(toast.uuid,index)">
 | 
					      <view
 | 
				
			||||||
 | 
					        class="mpopup"
 | 
				
			||||||
 | 
					        :style="{
 | 
				
			||||||
 | 
					          background: toast.color,
 | 
				
			||||||
 | 
					          top: toast.position === 'top' ? index * toast.distance + 50 + 'px' : 'initial',
 | 
				
			||||||
 | 
					          bottom: toast.position === 'bottom' ? index * toast.distance + 50 + 'px' : 'initial',
 | 
				
			||||||
 | 
					        }"
 | 
				
			||||||
 | 
					        :class="[toast.animator, 'mpopup-' + toast.type]"
 | 
				
			||||||
 | 
					        @click="close(toast.uuid, index)"
 | 
				
			||||||
 | 
					      >
 | 
				
			||||||
        <view class="icon"></view>
 | 
					        <view class="icon"></view>
 | 
				
			||||||
        <text class="text">{{ toast.content }}</text>
 | 
					        <text class="text">{{ toast.content }}</text>
 | 
				
			||||||
      </view>
 | 
					      </view>
 | 
				
			||||||
@ -28,17 +38,13 @@ based on
 | 
				
			|||||||
      popup_list: [], //弹窗数组
 | 
					      popup_list: [], //弹窗数组
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
		props:{
 | 
					  props: {},
 | 
				
			||||||
		},
 | 
					 | 
				
			||||||
  methods: {
 | 
					  methods: {
 | 
				
			||||||
    open: function (toast) {
 | 
					    open: function (toast) {
 | 
				
			||||||
				//生成uuid
 | 
					      toast.uuid = this.guid() //生成uuid
 | 
				
			||||||
				let uuid=this.guid()
 | 
					      toast.animator = 'fade_Down' //添加动画
 | 
				
			||||||
				toast.uuid=uuid
 | 
					      toast.clickable = toast.clickable || false //判断是否可点击消失
 | 
				
			||||||
				//添加动画
 | 
					      toast.position = toast.position || 'top'
 | 
				
			||||||
				toast.animator='fade_Down'
 | 
					 | 
				
			||||||
        
 | 
					 | 
				
			||||||
				toast.clickable = toast.clickable || false //判断是否可点击消失/可控制消失
 | 
					 | 
				
			||||||
      toast.duration = toast.duration || 1500
 | 
					      toast.duration = toast.duration || 1500
 | 
				
			||||||
      toast.distance = toast.distance || 128 // 弹窗间距
 | 
					      toast.distance = toast.distance || 128 // 弹窗间距
 | 
				
			||||||
      toast.type = toast.type || 'info'
 | 
					      toast.type = toast.type || 'info'
 | 
				
			||||||
@ -48,15 +54,15 @@ based on
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
      if (!toast.clickable) {
 | 
					      if (!toast.clickable) {
 | 
				
			||||||
        this.disappear(toast.uuid, toast.duration, toast.complete)
 | 
					        this.disappear(toast.uuid, toast.duration, toast.complete)
 | 
				
			||||||
				}else{ //可点击消失
 | 
					      } else {
 | 
				
			||||||
 | 
					        //可点击消失
 | 
				
			||||||
        this.$emit('uuidCallback', toast.uuid)
 | 
					        this.$emit('uuidCallback', toast.uuid)
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
				
 | 
					 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    //自动消失
 | 
					    //自动消失
 | 
				
			||||||
    disappear: function (uuid, duration, complete) {
 | 
					    disappear: function (uuid, duration, complete) {
 | 
				
			||||||
      //退出动画之后,短暂延迟后移除本元素
 | 
					      //退出动画之后,短暂延迟后移除本元素
 | 
				
			||||||
				this.fade_out_animator(uuid,duration).then(res=>{
 | 
					      this.fade_out_animator(uuid, duration).then((res) => {
 | 
				
			||||||
        setTimeout(() => {
 | 
					        setTimeout(() => {
 | 
				
			||||||
          for (let i = 0; i < this.popup_list.length; i++) {
 | 
					          for (let i = 0; i < this.popup_list.length; i++) {
 | 
				
			||||||
            if (this.popup_list[i].uuid == res) {
 | 
					            if (this.popup_list[i].uuid == res) {
 | 
				
			||||||
@ -65,7 +71,7 @@ based on
 | 
				
			|||||||
              this.$forceUpdate()
 | 
					              this.$forceUpdate()
 | 
				
			||||||
            }
 | 
					            }
 | 
				
			||||||
          }
 | 
					          }
 | 
				
			||||||
            if (typeof(complete)==='function'){
 | 
					          if (typeof complete === 'function') {
 | 
				
			||||||
            complete()
 | 
					            complete()
 | 
				
			||||||
          }
 | 
					          }
 | 
				
			||||||
        }, 250)
 | 
					        }, 250)
 | 
				
			||||||
@ -73,8 +79,10 @@ based on
 | 
				
			|||||||
    },
 | 
					    },
 | 
				
			||||||
    fade_out_animator: function (uuid, duration) {
 | 
					    fade_out_animator: function (uuid, duration) {
 | 
				
			||||||
      //duration秒后退出
 | 
					      //duration秒后退出
 | 
				
			||||||
				if(!duration||typeof(duration)!='number'){duration=1500}
 | 
					      if (!duration || typeof duration != 'number') {
 | 
				
			||||||
				return new Promise(res=>{
 | 
					        duration = 1500
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					      return new Promise((res) => {
 | 
				
			||||||
        setTimeout(() => {
 | 
					        setTimeout(() => {
 | 
				
			||||||
          for (let i = 0; i < this.popup_list.length; i++) {
 | 
					          for (let i = 0; i < this.popup_list.length; i++) {
 | 
				
			||||||
            if (this.popup_list[i].uuid == uuid) {
 | 
					            if (this.popup_list[i].uuid == uuid) {
 | 
				
			||||||
@ -89,7 +97,9 @@ based on
 | 
				
			|||||||
    //可控制关闭的弹出框
 | 
					    //可控制关闭的弹出框
 | 
				
			||||||
    close: function (uuid, ind) {
 | 
					    close: function (uuid, ind) {
 | 
				
			||||||
      if (ind) {
 | 
					      if (ind) {
 | 
				
			||||||
					if(!this.popup_list[ind].clickable){return}
 | 
					        if (!this.popup_list[ind].clickable) {
 | 
				
			||||||
 | 
					          return
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
      this.remove_element(uuid).then((res) => {
 | 
					      this.remove_element(uuid).then((res) => {
 | 
				
			||||||
        setTimeout(() => {
 | 
					        setTimeout(() => {
 | 
				
			||||||
@ -106,7 +116,7 @@ based on
 | 
				
			|||||||
    },
 | 
					    },
 | 
				
			||||||
    //控制移除元素
 | 
					    //控制移除元素
 | 
				
			||||||
    remove_element: function (uuid) {
 | 
					    remove_element: function (uuid) {
 | 
				
			||||||
				return new Promise(res=>{
 | 
					      return new Promise((res) => {
 | 
				
			||||||
        for (var i = 0; i < this.popup_list.length; i++) {
 | 
					        for (var i = 0; i < this.popup_list.length; i++) {
 | 
				
			||||||
          if (this.popup_list[i].uuid == uuid) {
 | 
					          if (this.popup_list[i].uuid == uuid) {
 | 
				
			||||||
            this.popup_list[i].animator = 'fade_Top'
 | 
					            this.popup_list[i].animator = 'fade_Top'
 | 
				
			||||||
@ -115,13 +125,12 @@ based on
 | 
				
			|||||||
          }
 | 
					          }
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
      })
 | 
					      })
 | 
				
			||||||
				
 | 
					 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    //更新
 | 
					    //更新
 | 
				
			||||||
    update: function (update_list) {
 | 
					    update: function (update_list) {
 | 
				
			||||||
      for (var i = 0; i < this.popup_list.length; i++) {
 | 
					      for (var i = 0; i < this.popup_list.length; i++) {
 | 
				
			||||||
        if (this.popup_list[i].uuid == update_list.uuid) {
 | 
					        if (this.popup_list[i].uuid == update_list.uuid) {
 | 
				
			||||||
						this.popup_list[i].type=update_list.type;
 | 
					          this.popup_list[i].type = update_list.type
 | 
				
			||||||
          this.init(this.popup_list[i])
 | 
					          this.init(this.popup_list[i])
 | 
				
			||||||
          this.popup_list[i].content = update_list.content
 | 
					          this.popup_list[i].content = update_list.content
 | 
				
			||||||
          break
 | 
					          break
 | 
				
			||||||
@ -131,11 +140,12 @@ based on
 | 
				
			|||||||
    //生成uuid
 | 
					    //生成uuid
 | 
				
			||||||
    guid: function () {
 | 
					    guid: function () {
 | 
				
			||||||
      return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function (c) {
 | 
					      return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function (c) {
 | 
				
			||||||
			        var r = Math.random()*16|0, v = c == 'x' ? r : (r&0x3|0x8)
 | 
					        var r = (Math.random() * 16) | 0,
 | 
				
			||||||
 | 
					          v = c == 'x' ? r : (r & 0x3) | 0x8
 | 
				
			||||||
        return v.toString(16)
 | 
					        return v.toString(16)
 | 
				
			||||||
      })
 | 
					      })
 | 
				
			||||||
			}
 | 
					    },
 | 
				
			||||||
		}
 | 
					  },
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
</script>
 | 
					</script>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -148,14 +158,16 @@ based on
 | 
				
			|||||||
  align-items: center;
 | 
					  align-items: center;
 | 
				
			||||||
  min-height: 45px;
 | 
					  min-height: 45px;
 | 
				
			||||||
  max-width: 80%;
 | 
					  max-width: 80%;
 | 
				
			||||||
		transition :all .5s;
 | 
					  transition: all 0.5s;
 | 
				
			||||||
  position: fixed;
 | 
					  position: fixed;
 | 
				
			||||||
  right: 0;
 | 
					  right: 0;
 | 
				
			||||||
  left: 0;
 | 
					  left: 0;
 | 
				
			||||||
  margin: 0 auto;
 | 
					  margin: 0 auto;
 | 
				
			||||||
  border-radius: 5px;
 | 
					  border-radius: 5px;
 | 
				
			||||||
  z-index: 998;
 | 
					  z-index: 998;
 | 
				
			||||||
    @media screen and (min-width: 751px) { max-width: 500px }
 | 
					  @media screen and (min-width: 751px) {
 | 
				
			||||||
 | 
					    max-width: 500px;
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  .icon {
 | 
					  .icon {
 | 
				
			||||||
    display: flex;
 | 
					    display: flex;
 | 
				
			||||||
@ -194,7 +206,6 @@ based on
 | 
				
			|||||||
  .icon {
 | 
					  .icon {
 | 
				
			||||||
    background-image: url('');
 | 
					    background-image: url('');
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
					 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
.mpopup-info {
 | 
					.mpopup-info {
 | 
				
			||||||
  background: #edf2fc;
 | 
					  background: #edf2fc;
 | 
				
			||||||
@ -220,8 +231,7 @@ based on
 | 
				
			|||||||
  animation: fadeInTop 0.5s forwards;
 | 
					  animation: fadeInTop 0.5s forwards;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
/*从上到下*/
 | 
					/*从上到下*/
 | 
				
			||||||
	@keyframes fadeInDown
 | 
					@keyframes fadeInDown {
 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
  from {
 | 
					  from {
 | 
				
			||||||
    opacity: 0;
 | 
					    opacity: 0;
 | 
				
			||||||
    -webkit-transform: translate(0, -100px);
 | 
					    -webkit-transform: translate(0, -100px);
 | 
				
			||||||
@ -234,22 +244,19 @@ based on
 | 
				
			|||||||
  }
 | 
					  }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
/*从下到上*/
 | 
					/*从下到上*/
 | 
				
			||||||
	@keyframes fadeInTop
 | 
					@keyframes fadeInTop {
 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
  from {
 | 
					  from {
 | 
				
			||||||
    opacity: 1;
 | 
					    opacity: 1;
 | 
				
			||||||
    -webkit-transform: translate(0, 10px);
 | 
					    -webkit-transform: translate(0, 10px);
 | 
				
			||||||
    transform: stranslate(0, 10px);
 | 
					    transform: stranslate(0, 10px);
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
  to {
 | 
					  to {
 | 
				
			||||||
	
 | 
					 | 
				
			||||||
    opacity: 0;
 | 
					    opacity: 0;
 | 
				
			||||||
    -webkit-transform: translate(0, -100px);
 | 
					    -webkit-transform: translate(0, -100px);
 | 
				
			||||||
    transform: stranslate(0, -100px);
 | 
					    transform: stranslate(0, -100px);
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
	@keyframes rotate360
 | 
					@keyframes rotate360 {
 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
  from {
 | 
					  from {
 | 
				
			||||||
    transform: rotate(0);
 | 
					    transform: rotate(0);
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
				
			|||||||
@ -112,7 +112,7 @@ module.exports = {
 | 
				
			|||||||
      cloudPath = tempFiles[0].name
 | 
					      cloudPath = tempFiles[0].name
 | 
				
			||||||
      // #endif
 | 
					      // #endif
 | 
				
			||||||
    } else if (mediaType === 'video') {
 | 
					    } else if (mediaType === 'video') {
 | 
				
			||||||
      let [errorChoose, { tempFilePath, tempFile, name }] = await uni.chooseVideo({ sourceType })
 | 
					      let [errorChoose, { tempFilePath, tempFile, duration, size, width, height, name }] = await uni.chooseVideo({ sourceType })
 | 
				
			||||||
      filePath = tempFilePath
 | 
					      filePath = tempFilePath
 | 
				
			||||||
      cloudPath = 'cloud.mp4'
 | 
					      cloudPath = 'cloud.mp4'
 | 
				
			||||||
      // #ifdef H5
 | 
					      // #ifdef H5
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
		Reference in New Issue
	
	Block a user