326 lines
		
	
	
		
			6.5 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
			
		
		
	
	
			326 lines
		
	
	
		
			6.5 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
| <template>
 | |
| 	<view class="uni-file-picker__files">
 | |
| 		<view v-if="!readonly" class="files-button" @click="choose">
 | |
| 			<slot></slot>
 | |
| 		</view>
 | |
| 		<!-- :class="{'is-text-box':showType === 'list'}" -->
 | |
| 		<view v-if="list.length > 0" class="uni-file-picker__lists is-text-box" :style="borderStyle">
 | |
| 			<!-- ,'is-list-card':showType === 'list-card' -->
 | |
| 
 | |
| 			<view class="uni-file-picker__lists-box" v-for="(item ,index) in list" :key="index" :class="{
 | |
| 				'files-border':index !== 0 && styles.dividline}"
 | |
| 			 :style="index !== 0 && styles.dividline &&borderLineStyle">
 | |
| 				<view class="uni-file-picker__item">
 | |
| 					<!-- :class="{'is-text-image':showType === 'list'}" -->
 | |
| 					<!-- 	<view class="files__image is-text-image">
 | |
| 						<image class="header-image" :src="item.logo" mode="aspectFit"></image>
 | |
| 					</view> -->
 | |
| 					<view class="files__name">{{item.name}}</view>
 | |
| 					<view v-if="delIcon&&!readonly" class="icon-del-box icon-files" @click="delFile(index)">
 | |
| 						<view class="icon-del icon-files"></view>
 | |
| 						<view class="icon-del rotate"></view>
 | |
| 					</view>
 | |
| 				</view>
 | |
| 				<view v-if="(item.progress && item.progress !== 100) ||item.progress===0 " class="file-picker__progress">
 | |
| 					<progress class="file-picker__progress-item" :percent="item.progress === -1?0:item.progress" stroke-width="4"
 | |
| 					 :backgroundColor="item.errMsg?'#ff5a5f':'#EBEBEB'" />
 | |
| 				</view>
 | |
| 				<view v-if="item.status === 'error'" class="file-picker__mask" @click.stop="uploadFiles(item,index)">
 | |
| 					点击重试
 | |
| 				</view>
 | |
| 			</view>
 | |
| 
 | |
| 		</view>
 | |
| 	</view>
 | |
| </template>
 | |
| 
 | |
| <script>
 | |
| 	export default {
 | |
| 		name: "uploadFile",
 | |
| 		emits:['uploadFiles','choose','delFile'],
 | |
| 		props: {
 | |
| 			filesList: {
 | |
| 				type: Array,
 | |
| 				default () {
 | |
| 					return []
 | |
| 				}
 | |
| 			},
 | |
| 			delIcon: {
 | |
| 				type: Boolean,
 | |
| 				default: true
 | |
| 			},
 | |
| 			limit: {
 | |
| 				type: [Number, String],
 | |
| 				default: 9
 | |
| 			},
 | |
| 			showType: {
 | |
| 				type: String,
 | |
| 				default: ''
 | |
| 			},
 | |
| 			listStyles: {
 | |
| 				type: Object,
 | |
| 				default () {
 | |
| 					return {
 | |
| 						// 是否显示边框
 | |
| 						border: true,
 | |
| 						// 是否显示分隔线
 | |
| 						dividline: true,
 | |
| 						// 线条样式
 | |
| 						borderStyle: {}
 | |
| 					}
 | |
| 				}
 | |
| 			},
 | |
| 			readonly:{
 | |
| 				type:Boolean,
 | |
| 				default:false
 | |
| 			}
 | |
| 		},
 | |
| 		computed: {
 | |
| 			list() {
 | |
| 				let files = []
 | |
| 				this.filesList.forEach(v => {
 | |
| 					files.push(v)
 | |
| 				})
 | |
| 				return files
 | |
| 			},
 | |
| 			styles() {
 | |
| 				let styles = {
 | |
| 					border: true,
 | |
| 					dividline: true,
 | |
| 					'border-style': {}
 | |
| 				}
 | |
| 				return Object.assign(styles, this.listStyles)
 | |
| 			},
 | |
| 			borderStyle() {
 | |
| 				let {
 | |
| 					borderStyle,
 | |
| 					border
 | |
| 				} = this.styles
 | |
| 				let obj = {}
 | |
| 				if (!border) {
 | |
| 					obj.border = 'none'
 | |
| 				} else {
 | |
| 					let width = (borderStyle && borderStyle.width) || 1
 | |
| 					width = this.value2px(width)
 | |
| 					let radius = (borderStyle && borderStyle.radius) || 5
 | |
| 					radius = this.value2px(radius)
 | |
| 					obj = {
 | |
| 						'border-width': width,
 | |
| 						'border-style': (borderStyle && borderStyle.style) || 'solid',
 | |
| 						'border-color': (borderStyle && borderStyle.color) || '#eee',
 | |
| 						'border-radius': radius
 | |
| 					}
 | |
| 				}
 | |
| 				let classles = ''
 | |
| 				for (let i in obj) {
 | |
| 					classles += `${i}:${obj[i]};`
 | |
| 				}
 | |
| 				return classles
 | |
| 			},
 | |
| 			borderLineStyle() {
 | |
| 				let obj = {}
 | |
| 				let {
 | |
| 					borderStyle
 | |
| 				} = this.styles
 | |
| 				if (borderStyle && borderStyle.color) {
 | |
| 					obj['border-color'] = borderStyle.color
 | |
| 				}
 | |
| 				if (borderStyle && borderStyle.width) {
 | |
| 					let width = borderStyle && borderStyle.width || 1
 | |
| 					let style = borderStyle && borderStyle.style || 0
 | |
| 					if (typeof width === 'number') {
 | |
| 						width += 'px'
 | |
| 					} else {
 | |
| 						width = width.indexOf('px') ? width : width + 'px'
 | |
| 					}
 | |
| 					obj['border-width'] = width
 | |
| 
 | |
| 					if (typeof style === 'number') {
 | |
| 						style += 'px'
 | |
| 					} else {
 | |
| 						style = style.indexOf('px') ? style : style + 'px'
 | |
| 					}
 | |
| 					obj['border-top-style'] = style
 | |
| 				}
 | |
| 				let classles = ''
 | |
| 				for (let i in obj) {
 | |
| 					classles += `${i}:${obj[i]};`
 | |
| 				}
 | |
| 				return classles
 | |
| 			}
 | |
| 		},
 | |
| 
 | |
| 		methods: {
 | |
| 			uploadFiles(item, index) {
 | |
| 				this.$emit("uploadFiles", {
 | |
| 					item,
 | |
| 					index
 | |
| 				})
 | |
| 			},
 | |
| 			choose() {
 | |
| 				this.$emit("choose")
 | |
| 			},
 | |
| 			delFile(index) {
 | |
| 				this.$emit('delFile', index)
 | |
| 			},
 | |
| 			value2px(value) {
 | |
| 				if (typeof value === 'number') {
 | |
| 					value += 'px'
 | |
| 				} else {
 | |
| 					value = value.indexOf('px') !== -1 ? value : value + 'px'
 | |
| 				}
 | |
| 				return value
 | |
| 			}
 | |
| 		}
 | |
| 	}
 | |
| </script>
 | |
| 
 | |
| <style lang="scss">
 | |
| 	.uni-file-picker__files {
 | |
| 		/* #ifndef APP-NVUE */
 | |
| 		display: flex;
 | |
| 		/* #endif */
 | |
| 		flex-direction: column;
 | |
| 		justify-content: flex-start;
 | |
| 	}
 | |
| 
 | |
| 	.files-button {
 | |
| 		// border: 1px red solid;
 | |
| 	}
 | |
| 
 | |
| 	.uni-file-picker__lists {
 | |
| 		position: relative;
 | |
| 		margin-top: 5px;
 | |
| 		overflow: hidden;
 | |
| 	}
 | |
| 
 | |
| 	.file-picker__mask {
 | |
| 		/* #ifndef APP-NVUE */
 | |
| 		display: flex;
 | |
| 		/* #endif */
 | |
| 		justify-content: center;
 | |
| 		align-items: center;
 | |
| 		position: absolute;
 | |
| 		right: 0;
 | |
| 		top: 0;
 | |
| 		bottom: 0;
 | |
| 		left: 0;
 | |
| 		color: #fff;
 | |
| 		font-size: 14px;
 | |
| 		background-color: rgba(0, 0, 0, 0.4);
 | |
| 	}
 | |
| 
 | |
| 	.uni-file-picker__lists-box {
 | |
| 		position: relative;
 | |
| 	}
 | |
| 
 | |
| 	.uni-file-picker__item {
 | |
| 		/* #ifndef APP-NVUE */
 | |
| 		display: flex;
 | |
| 		/* #endif */
 | |
| 		align-items: center;
 | |
| 		padding: 8px 10px;
 | |
| 		padding-right: 5px;
 | |
| 		padding-left: 10px;
 | |
| 	}
 | |
| 
 | |
| 	.files-border {
 | |
| 		border-top: 1px #eee solid;
 | |
| 	}
 | |
| 
 | |
| 	.files__name {
 | |
| 		flex: 1;
 | |
| 		font-size: 14px;
 | |
| 		color: #666;
 | |
| 		margin-right: 25px;
 | |
| 		/* #ifndef APP-NVUE */
 | |
| 		word-break: break-all;
 | |
| 		word-wrap: break-word;
 | |
| 		/* #endif */
 | |
| 	}
 | |
| 
 | |
| 	.icon-files {
 | |
| 		/* #ifndef APP-NVUE */
 | |
| 		position: static;
 | |
| 		background-color: initial;
 | |
| 		/* #endif */
 | |
| 	}
 | |
| 
 | |
| 	// .icon-files .icon-del {
 | |
| 	// 	background-color: #333;
 | |
| 	// 	width: 12px;
 | |
| 	// 	height: 1px;
 | |
| 	// }
 | |
| 
 | |
| 
 | |
| 	.is-list-card {
 | |
| 		border: 1px #eee solid;
 | |
| 		margin-bottom: 5px;
 | |
| 		border-radius: 5px;
 | |
| 		box-shadow: 0 0 2px 0px rgba(0, 0, 0, 0.1);
 | |
| 		padding: 5px;
 | |
| 	}
 | |
| 
 | |
| 	.files__image {
 | |
| 		width: 40px;
 | |
| 		height: 40px;
 | |
| 		margin-right: 10px;
 | |
| 	}
 | |
| 
 | |
| 	.header-image {
 | |
| 		width: 100%;
 | |
| 		height: 100%;
 | |
| 	}
 | |
| 
 | |
| 	.is-text-box {
 | |
| 		border: 1px #eee solid;
 | |
| 		border-radius: 5px;
 | |
| 	}
 | |
| 
 | |
| 	.is-text-image {
 | |
| 		width: 25px;
 | |
| 		height: 25px;
 | |
| 		margin-left: 5px;
 | |
| 	}
 | |
| 
 | |
| 	.rotate {
 | |
| 		position: absolute;
 | |
| 		transform: rotate(90deg);
 | |
| 	}
 | |
| 
 | |
| 	.icon-del-box {
 | |
| 		/* #ifndef APP-NVUE */
 | |
| 		display: flex;
 | |
| 		margin: auto 0;
 | |
| 		/* #endif */
 | |
| 		align-items: center;
 | |
| 		justify-content: center;
 | |
| 		position: absolute;
 | |
| 		top: 0px;
 | |
| 		bottom: 0;
 | |
| 		right: 5px;
 | |
| 		height: 26px;
 | |
| 		width: 26px;
 | |
| 		// border-radius: 50%;
 | |
| 		// background-color: rgba(0, 0, 0, 0.5);
 | |
| 		z-index: 2;
 | |
| 		transform: rotate(-45deg);
 | |
| 	}
 | |
| 
 | |
| 	.icon-del {
 | |
| 		width: 15px;
 | |
| 		height: 1px;
 | |
| 		background-color: #333;
 | |
| 		// border-radius: 1px;
 | |
| 	}
 | |
| 
 | |
| 	/* #ifdef H5 */
 | |
| 	@media all and (min-width: 768px) {
 | |
| 		.uni-file-picker__files {
 | |
| 			max-width: 375px;
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	/* #endif */
 | |
| </style>
 |