<template>
	<view class="upload-image">
		<view class="pull-left"  :class="itemClass" v-for="(item, index) in value" :key="item.url">
			<view class="imgwarp">
				<view style="margin-bottom: 100%;" class="text-center">
                    <!-- <u-loading-page v-if="item.loading" font-size="28" :loading="true"></u-loading-page> -->
					
					<view style="margin-top: 20px;" v-if="item.loading" class="">
						<u-loading-icon  ></u-loading-icon>
					</view>
					
					<view class="img-square-warp" v-else  @click="clickImg(index)" style="position: absolute;top: 0;right: 0;left: 0;bottom: 0;">
						<image :src="item.type=='image' ? item.url+'?x-oss-process=image/resize,m_fill,h_200,w_200,limit_0' : item.video_img" mode="widthFix" class="img-max img-square"/>
					</view>
				</view>
				<span v-if="showRemove" class="img-remove" @click="remove(index)"></span>
			</view>
		</view>
		<view class="pull-left" :class="itemClass">
			<view class="imgwarp ui-flex ui-flex-align-center ui-flex-center" v-if="max > value.length" @click="choose()">
                <u-icon name="camera-fill" size="48" ></u-icon>
			</view>
		</view>
        
        <u-popup :show="showPopup" mode="bottom" @close="showPopup = false">
            <view class="ui-flex-row u-border-bottom">
                <view class="ui-flex-1 ui-p f12 text-center u-border-right">照片</view>
                <!-- <view class="ui-flex-1 ui-p f12 text-center" v-if="chooseVideo">视频</view> -->
            </view>
            <view class="ui-flex-row">
                <view class="ui-flex-1 ui-p" @click="choose('image', 'camera')">
                    <u-icon label="拍摄照片" size="28px" space="7px" labelSize="12px" labelPos="bottom" name="camera"></u-icon>
                </view>
                <view class="ui-flex-1 ui-p u-border-right" @click="choose('image', 'album')">
                    <u-icon label="选择照片" size="28px" space="7px" labelSize="12px" labelPos="bottom" name="photo"></u-icon>
                </view>
<!--                <view class="ui-flex-1 ui-p" @click="choose('video', 'camera')" v-if="chooseVideo">
                    <u-icon label="拍摄视频" size="28px" space="7px" labelSize="12px" labelPos="bottom" name="play-circle"></u-icon>
                </view>
                <view class="ui-flex-1 ui-p" @click="choose('video', 'album')" v-if="chooseVideo">
                    <u-icon label="选择视频" size="28px" space="7px" labelSize="12px" labelPos="bottom" name="plus-circle"></u-icon>
                </view> -->
            </view>
        </u-popup>
	</view>
</template>

<script>
	// import Request from '@/common/base-request.js'
	// import uLoadingIcon from '@/uni_modules/uview-ui/components/u-loading-icon/u-loading-icon.vue'
	export default {
		comments : {
			
		},
		props : {
            max : {
                default : 1
            },
            dir : {
                required: false
            },
			itemClass : {
				type : String,
				default : '',
			},
            value : {
                type : Array,
                default : function(){
                	return []
                },
            },
			showRemove : {
				default : true,
			},
			crop : {
				type : [Object, undefined],
				default: undefined
			},
            type : {
                type : String,
                default : 'image'
            }
        },
        computed : {
            chooseVideo (){
                if(this.type != 'all'){
                    return false;
                }
                return true;
            }
        },
		data() {
			return {
                showPopup : false,
                video: {
                    // isVideo : true,
                    // loading : true,
                    // videoUrl : 'xxx',
                    // videoCover : 'xxx'
                }
            }
		},
		methods : {
            remove : function(index){
                this.value.splice(index, 1);
				this.$emit("input",this.value)
            },
			clickImg(index){
				if(this.showRemove){
					return 
				}
                this.selectIndex = index;
                return this.showPopup = true;
			},
            choose(type, sourceType){
                if(!type){
                    this.selectIndex = null;
                    return this.showPopup = true;
                }

                this.showPopup = false;
                if(type == 'image'){
                    uni.chooseImage({
                    	count: this.max - this.value.length, //默认9
                        sourceType : [sourceType],
                    	sizeType: ['compressed'], //可以指定是原图还是压缩图,默认二者都有
                    	crop : this.crop,
                    	// sourceType: ['album'], //从相册选择
                    	success: (fileList) => {
                            this.toUploadImgs(fileList);
                        },
                    })
                }else{
                    uni.chooseVideo({
                        sourceType: [sourceType],
                        maxDuration : 60,
                        success: (res) => {
                            // console.log(res);
                            // self.src = res.tempFilePath;
                            this.video = {
                                isVideo : true,
                                loading : true,
                                videoUrl : '',
                                videoCover : '',
                            }
                            
                            let filePath = {
                                filePath : res.tempFilePath,
                                // #ifdef H5
                                fileInfo : res.tempFile
                                // #endif
                            };
                            
							this.value.push({
								loading :true,
								type : 'video',
							})
							let index=this.value.length-1
							this.$emit("input",this.value)
							
                            this.$uploadOSS('/leapi/upload', filePath, this.dir + '/', (res) => {
                                if(res){
									let obj={
										url : res.imgurl,
										video_img : res.imgurl + '?x-oss-process=video/snapshot,t_1000,f_jpg,w_300,h_300,m_fast',
										loading : false,
										type : 'video',
									}
									this.$set(this.value,index,obj)
									// this.list[index].url = res.imgurl
									// this.list[index].video_img = res.imgurl + '?x-oss-process=video/snapshot,t_1000,f_jpg,w_300,h_300,m_fast';
									// this.list[index].loading = false
                                    this.video.loading = false,
                                    this.video.videoUrl = res.imgurl;
                                    this.video.videoCover = res.imgurl + '?x-oss-process=video/snapshot,t_1000,f_jpg,w_300,h_300,m_fast';
									this.$emit("input",this.value)
                                }
                            })
                        }
                    });
                }
            },
            toUploadImgs : function(fileList){
				console.log(fileList,"filelist");
                if(!fileList.tempFilePaths){
                	return;
                }
                fileList.tempFilePaths.forEach((filePath, index) => {
					let file={
						filePath : filePath,
						// #ifdef H5
						fileInfo : fileList.tempFiles[index]
						// #endif
					}
					
					this.value.push({
						file :file,
						loading :true,
						type : 'image',
					})
					let list_index=this.value.length-1
					console.log(list_index,"list_indexlist_index",file)
					uni.uploadFile({
						url: 'http://125.124.170.221:8000/api/upload',
						filePath: file.filePath,
						name: 'file',
						success: (myres) => {
							console.log(myres,"mures");
							let { data } = JSON.parse(myres.data);
							console.log(data,"data");
							let obj={
								url : data.url,
								loading : false,
								type : 'image'
							}
							this.$set(this.value,list_index,obj)
							this.value[list_index].url = data.url
							this.value[list_index].loading = false
							this.value[list_index].type = 'image'
							delete this.value[list_index].file
							this.$emit("input",this.value)
						},
						fail : (err=>{
							console.log(err,"err");
						})
					});
					
					// this.$uploadOSS('/leapi/upload', file, this.dir + '/', (res) => {
					//     if(res){
					// 		let obj={
					// 			url : res.imgurl,
					// 			thumburl : res.imgurl + '?x-oss-process=style%2Fsquare200',
					// 			loading : false,
					// 			type : 'image'
					// 		}
					// 		this.$set(this.value,list_index,obj)
					// 		// this.value[list_index].url = res.imgurl
					// 		// this.value[list_index].thumburl = res.imgurl + '?x-oss-process=style%2Fsquare200',
					// 		// this.value[list_index].loading = false
					// 		// this.value[list_index].type = 'image'
					// 		// delete this.value[list_index].file
					//         // this.list[index].loading = false,
					//         // this.list[index].thumburl = res.imgurl + '?x-oss-process=style%2Fsquare200';
					//         // this.list[index].imgurl = res.imgurl;
					//     }
					//     //
					// 	this.$emit("input",this.value)
					// })
                });
            }
        },
	}
</script>

<style scoped>
.upload-image .img-max{
	width: 90%;
	margin: 5%;
}
.upload-image .imgwarp{
	width: 76px;
	height: 76px;
	line-height: 76px;
	margin-right: 10px;
	margin-bottom: 10px;
	color: #ccc;
	border: 1px dashed;
	position: relative;
	box-sizing: content-box;
}
.upload-image .img-remove{
	position: absolute;
	right: -10px;
	top: -8px;
	width: 40px;
	height: 40px;
	z-index: 100;
	text-align: right;
	line-height: normal;
	background: url() no-repeat 15px 0;
	background-size: 23px auto;
}
.upload-image:after{
	content: ' ';
	display: block;
	clear: both;
}
.uloading{
	position: absolute;
	top : calc(50% - 7px);
	left: calc(50% - 7px);
	
	/* #ifndef H5 */
	top : 0;
	/* #endif */
}
</style>