<template>
	<div class="content">
		<div class="body">
			<div class="head-body">
				<span class="prev" @click='prevDeta'><img src="../assets/imgs/flow/prev.png" alt=""></span>
				<span class="date-head">{{swiperData.year}}年{{swiperData.month}}月</span>
				<span class="next" @click='nextDate'><img src="../assets/imgs/flow/next.png" alt=""></span>
				<!-- <div>
					<div class='pr40' style="display: inline-block;"><span></span><uni-icon type="arrowup" size='26' color='#fff' @click='prevDeta'/></div>
					<div style="display: inline-block;"><uni-icon type="arrowdown" size='26' color='#fff' @click='nextDate' /></div>
				</div> -->
			</div>
			<div class="mian-body">
				<!-- 星期 -->
				<div  class="mian-bolck"> <span class="yellow">Sun</span> </div>
				<div  class="mian-bolck"> <span class="yellow">Mon</span> </div>
				<div  class="mian-bolck"> <span class="yellow">Tue</span> </div>
				<div  class="mian-bolck"> <span class="yellow">Wed</span> </div>
				<div  class="mian-bolck"> <span class="yellow">Thu</span> </div>
				<div  class="mian-bolck"> <span class="yellow">Fri</span> </div>
				<div  class="mian-bolck"> <span class="yellow">Sat</span> </div>
				<!-- 日 -->
				<div v-for="(val, index) in swiperData.dateDay"  class="mian-bolck" :class="val.disable == true ? 'disable' : val.Choice == true ? 'Choice' : ''"
				 @click="ChoiceDate(index, val.disable)" :key='index'>
					<div class="border">
						<span class="day">{{val.day}}</span>
					</div>
				</div>
			</div>
			<div class="foot">
				<button class="confirm" @click="confirm">确定选择</button>
				<button class="cancle" @click="cancle">取消</button>
			</div>
		</div>
	</div>
</template>

<script>
	export default {
		data() {
			return {
				swiperData: {},
				year: '',
				month: '',
				day: '',
				storageDate: []
			}
		},
		props: {
			//下一个月
			nextMonth: {
				type: String,
				default: ''
			},
			// 当前日期
			date: {
				type: String,
				default: () => {
					let _dateData = new Date(),
						_date = `${_dateData.getFullYear()}-${_dateData.getMonth() + 1}-${_dateData.getDate()}`
					return _date
				}
			},
			// 禁用开始之前日期
			startDate: {
				type: String,
				default: ''
			},
			// 禁用开始之后日期
			endDate: {
				type: String,
				default: ''
			},
			// 是否禁用今天之前的日期
			disableBefore: {
				type: Boolean,
				default: false
			},
			// 价格
			price: {
				type: Object,
				default: () => {
					return {type: false, data: []}
				}
			},
			// 是否选择默认日期
			isNowDate: {
				type: Boolean,
				default: true
			},
			// 单选或多选
			singleElection: {
				type: Boolean,
				default: true
			}
		},
		computed: {
			PriceData: {
				get() {
					return this.price.data
				}
			}
		},
		created() {
			let dateArr = this.date.split('-')
			if (this.date != '' && dateArr.length == 3) {
				// 初始化年月日
				this.year = Number(dateArr[0])
				this.month = Number(dateArr[1])
				this.day = Number(dateArr[2])
				this.InitializationHomeDate(true).then((val) => {
					this.Preprocessing(dateArr)
					if(this.nextMonth){
						this.nextDate()
					}
				})
			} else {
				console.error('error 请检查传入日期是否正确,如: 2019-5-12')
			}
			
		},
		methods: {
			// 是否添加初始化日期
			InitializationHomeDate(type) {
				// 指定日期
				let ThisDate = this.compareDate(this.date)
				// 禁用开始时间
				let startDate = this.compareDate(this.startDate)
				// 禁用结束时间
				let endDate = this.compareDate(this.endDate)
				// 当前日期
				let _date = new Date()
				let currDate = this.compareDate(`${_date.getFullYear()}-${_date.getMonth() + 1}-${_date.getDate()}`)
				return new Promise((resolve, reject) => {
					let judge = (this.disableBefore == false && this.startDate == '' && this.endDate == '') || // 没有任何禁止
											(this.disableBefore == true && ThisDate >= currDate) || // 是否禁用今天之前的日期
											(ThisDate >= startDate && this.disableBefore == false && this.startDate != '') || // 禁用只有开始时间,没有结束时间
											(ThisDate <= endDate && this.disableBefore == false && this.endDate != '') || // 禁用只有结束时间,没有开始时间
											(ThisDate <= endDate && this.disableBefore == false && ThisDate >= startDate && this.startDate != '' &&this.endDate != '') // 禁用结束时间,开始时间
					if (this.isNowDate == false) {
						resolve(true)
						return false
					} else if (judge && type) {
						//this.storageDate.push({date: this.date})
					}
					resolve(true)
				})
			},
			// 时间转换为时间戳
			compareDate(s1) {
				let curTime = new Date();
				//把字符串格式转化为日期类
				return s1 ? new Date(s1).valueOf() : false
			},
			// 上一个月
			prevDeta() {
				let dateLen = new Date(this.year, this.month - 1, 0).getDate()
				this.month = Number(this.month) - 1
				if (this.month == 0) {
					this.month = 12
					this.year = Number(this.year) - 1
				}
				this.Preprocessing([this.year, this.month, this.day])
				if (this.price.type) {
					this.$emit('changeMonth', [this.year, this.month, dateLen])
				}
			},
			// 下一个月
			nextDate() {
				let dateLen = new Date(this.year, this.month - 1, 0).getDate()
				this.month = 1 + Number(this.month)
				if (this.month == 13) {
					this.month = 1
					this.year = 1 + Number(this.year)
				}
				this.Preprocessing([this.year, this.month, this.day])
				if (this.price.type) {
					this.$emit('changeMonth', [this.year, this.month, dateLen])
				}
			},
			//将日期小于10的转为两位数,  9-> 09
			numberDouble(num) {
				return num < 10 ? '0' + num : num;
			},
			// 数据发布
			ChoiceDate(index, disable) {
				let day = this.swiperData.dateDay[index].day

				let _Choice = this.swiperData.dateDay[index].Choice
				let _id = this.swiperData.dateDay[index].id||''
				let _date = {}
				if (this.price.type == true) {
					_date = {date: `${this.swiperData.year}-${this.swiperData.month}-${day}`, price:  this.swiperData.dateDay[index].price, _id}
				} else {
					_date = {date: `${this.swiperData.year}-${this.swiperData.month}-${day}`, _id}
				}
				if (disable != true) {
					// 添加数据
					if (JSON.stringify(this.storageDate).indexOf(_date.date) == -1) {
						// 单选还是多选
						if (this.singleElection == true) {
							this.storageDate = []
							this.swiperData.dateDay.forEach((val, inde) => {
								val.Choice = false
							})
						// 多选
						}
						this.storageDate.push(_date)
					// 删除数据
					} else {
						this.storageDate = this.storageDate.filter((val, index) => {
							if (val.date != _date.date) {
								return val
							}
						})
					}
					this.swiperData.dateDay[index].Choice = !_Choice
					this.$emit('changeDay', this.storageDate)
				}
			},
			// 日期初始化
			Preprocessing(arr) {
				let swiperData = {}
				this.getDay(`${arr[0]}-${arr[1]}-${arr[2]}`).then((val) => {
					swiperData = val
					this.$emit('changeDay', this.storageDate)
					this.$set(this, 'swiperData', swiperData)
				})
			},
			// 判断当前是 安卓还是ios ,传入不容的日期格式
			judgeDate(dateData) {
				if (typeof dateData !== 'object') {
					dateData = dateData.replace(/-/g, '/')
				}
				return dateData
			},
			// 循环上个月末尾几天添加到数组
			getDay(dateData) {
				dateData = this.judgeDate(dateData)
				// 获取年,月,日,星期
				let _date = new Date(dateData),
					year = _date.getFullYear(),
					month = _date.getMonth() + 1,
					date = _date.getDate(),
					day = _date.getDay()

				return new Promise((resolve, reject) => {
					//获取上个月末尾几天
					let prevDayArr = [],
						prevDayLength = new Date(year, month - 1, 1).getDay()
					for (let i = prevDayLength; i > 0; i--) {
						let prevDay = new Date(year, month - 1, -i + 1).getDate()
						prevDayArr.push({
							day: prevDay,
							disable: true,
							Choice: false
						})
					}

					// 获取本月
					let thisDayArr = [],
						thisDaylength = new Date(year, month - 1, 0).getDate()
					for (let i = 1; i <= new Date(year, month, 0).getDate(); i++) {
						thisDayArr.push({
							day: i,
							disable: false,
							Choice: false,
							price: this.price.data[i-1],
							priceType: this.price.type
						})
						// 重绘已选择日期
						this.storageDate.forEach((val, index) => {
							let valArr = val.date.split('-');
							if (year == valArr[0] && month == valArr[1] && i == valArr[2]) {
								thisDayArr[i - 1].Choice = false
								val.price = this.price.data[i-1]
							}
						})
					}
					

					// 获取下个月开始几天
					let nextDayArr = [],
						nextDaylength = 42 - (prevDayArr.length + thisDayArr.length)
					for (let i = 1; i < nextDaylength + 1; i++) {
						nextDayArr.push({
							day: i,
							disable: true,
							Choice: false
						})
					}

					// 数据合并
					let dateShow = []
					dateShow = dateShow.concat(prevDayArr, thisDayArr, nextDayArr)

					// 禁用今天之前的日期
					if (this.disableBefore) {
						let __beForeDeta = new Date(),
							dDate = `${__beForeDeta.getFullYear()}-${__beForeDeta.getMonth() + 1}-${__beForeDeta.getDate()}`
						this.disableDatePrevFn(dateShow, dDate.split('-'), year, month).then((val) => {
							resolve({
								dateDay: val,
								year: year,
								month: month
							})
						})
						// 禁用双向指定范围可用
					} else if (this.startDate != '' && this.endDate != '') {
						let startDateArr = this.startDate.split('-')
						let endDateArr = this.endDate.split('-')
						if (startDateArr.length == 3 && endDateArr.length == 3) {
							this.disableDatePrevFn(dateShow, startDateArr, year, month).then((val) => {
								return this.disableDateNextFn(val, endDateArr, year, month)
							}).then((val) => {
								resolve({
									dateDay: val,
									year: year,
									month: month
								})
							})
						} else if (endDateArr.length != 3) {
							console.error('error 日期选择范围-结束日期错误,如: 2019-5-12')
							if (startDateArr.length != 3) {
								console.error('error 日期选择范围-开始日期错误,如: 2019-5-12')
							}
						}
						// 禁用开始日期之前
					} else if (this.startDate != '') {
						let startDateArr = this.startDate.split('-')
						if (startDateArr.length == 3) {
							this.disableDatePrevFn(dateShow, startDateArr, year, month).then((val) => {
								resolve({
									dateDay: val,
									year: year,
									month: month
								})
							})
						} else {
							console.error('error 日期选择范围-开始日期错误,如: 2019-5-12')
						}
						// 禁用结束日期之前
					} else if (this.endDate != '') {
						let endDateArr = this.endDate.split('-')
						if (endDateArr.length == 3) {
							this.disableDateNextFn(dateShow, endDateArr, year, month).then((val) => {
								resolve({
									dateDay: val,
									year: year,
									month: month
								})
							})
						} else {
							console.error('error 日期选择范围-结束日期错误,如: 2019-5-12')
						}
						// 不禁用
					} else {
						this.disableDatePrevFn(dateShow, new Array(3), year, month).then((val) => {
							resolve({
								dateDay: val,
								year: year,
								month: month
							})
						})
					}
				})
			},
			// 禁用指定日期之前的日期
			disableDatePrevFn() {
				let DateObj = arguments,
					dateShow = DateObj[0],
					dDate = DateObj[1],
					year = DateObj[2],
					month = DateObj[3]
				return new Promise((resolve, reject) => {
					dateShow = dateShow.map((val, index) => {
						if (dDate[0] > year) {
							val.disable = true
						} else if (dDate[1] > month && dDate[0] >= year) {
							val.disable = true
						} else if (dDate[0] >= year && dDate[2] > val.day && dDate[1] >= month) {
							val.disable = true
						}
						return val
					})
					resolve(dateShow)
				})
			},
			// 禁用指定日期之后的日期
			disableDateNextFn() {
				let DateObj = arguments,
					dateShow = DateObj[0],
					dDate = DateObj[1],
					year = DateObj[2],
					month = DateObj[3]
				return new Promise((resolve, reject) => {
					dateShow = dateShow.map((val, index) => {
						if (dDate[0] < year) {
							val.disable = true
						} else if (dDate[0] <= year && dDate[1] < month) {
							val.disable = true
						} else if (dDate[0] <= year && dDate[1] <= month && dDate[2] < val.day) {
							val.disable = true
						}
						return val
					})
					resolve(dateShow)
				})
			},
			/**重新赋值 魔改 burtyang
			 * **/
			initDate(dataAll){
				this.storageDate = [];
				this.swiperData.dateDay.forEach((item)=>{
					if(item.disable){ //不是当月的
						return;
					}
					let date = `${this.swiperData.year}-${this.swiperData.month}-${item.day}`;
					if(dataAll.hasOwnProperty(date)){
						item.Choice = true;
						item.id = dataAll[date];
						this.storageDate.push({
							date,
							id: dataAll[date]||''
						});
					}else{
						item.Choice = false;
					}
				});
			},
			// 确定
			confirm() {
				this.$emit('confirmDate', true)
			},
			// 取消
			cancle() {
				this.$emit('cancleDate', true)
			}
		},
		watch: {
			'PriceData': {
				handler(newData, oldData) {
					this.InitializationHomeDate(false).then((val) => {
						this.Preprocessing([this.year, this.month, this.day])
					})
				},
				immediate: false,
				deep: true
			}
		}
	}
</script>

<style lang="less" scoped>
.content {
	width: 480px;
	border-radius: 4px;
	overflow: hidden;
	.body {
		width: 100%;
		padding: 18px 33px;
		box-sizing: border-box;
		background: #fff;
		display: flex;
		flex-direction: column;
		align-items: center;
		.head-body {
			width: 245px;
			display: flex;
			flex-direction: row;
			height: 41px;
			box-sizing: border-box;
			padding: 5px 15px 10px 15px;
			justify-content: space-between;
			align-items: center;
			color: #333;
			.date-head {
				width: 100%;
				text-align: center;
				font-size: 24px;
				font-weight: bold;
				color: #3F7FFB;
				letter-spacing: 1px;
			}
			.prev {
				img {
					transform: rotate(180deg);
				}
			}
		}

		.mian-body {
			width: 100%;
			height: calc(100% - 46px);
			color: #333;
			display: flex;
			flex-flow: row wrap;
			justify-content: center;
			align-items: center;
			.mian-bolck {
				width: 100% / 7;
				padding: 4px 0;
				box-sizing: border-box;
				font-size: 17px;
				display: flex;
				flex-flow: row wrap;
				justify-content: center;
				align-items: center;
				margin: 3px 0;
				cursor: pointer;
				user-select: none;
				.yellow {
					color:#FFCC00;
				}
				.border {
					display: flex;
					flex-flow: row wrap;
					justify-content: center;
					align-items: center;
					text-align: center;
					width: 31px;
					height: 31px;
					.price{
						font-size: 12px;
					}
					.day{
						width: 31px;
						height: 31px;
					}
					span{
						font-size: 18px;
					}
				}
			}
			.disable {
				color: #e8e3e3;
			}
			.Choice {
				display: flex;
				flex-flow: row wrap;
				justify-content: center;
				align-items: center;
				box-sizing: border-box;
				.day{
					width: 31px;
					height: 31px;
					line-height: 31px;
					background: #FFCC00;
					border-radius: 50%;
					color: #fff;
				}
			}
		}
	}
	.foot {
		width: 100%;
		display: flex;
		justify-content: space-between;
		margin-top: 58px;
		button {
			outline: none;
			border: none;
			width: 109px;
			height: 42px;
			border-radius: 4px;
		}
		.confirm {
			background: #3F7FFB;
			color: #fff;
		}
		.cancle {
			background: #ccc;
			color: #fff;
		}
	}
}
</style>