| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377 | 
							- import CALENDAR from './calendar.js'
 
- import moment from '../../static/moment.min.js'
 
- class Calendar {
 
- 	constructor({
 
- 		date,
 
- 		selected,
 
- 		startDate,
 
- 		endDate,
 
- 		range
 
- 	} = {}) {
 
- 		// 当前日期
 
- 		this.date = this.getDate(new Date()) // 当前初入日期
 
- 		// 打点信息
 
- 		this.selected = selected || [];
 
- 		// 范围开始
 
- 		this.startDate = startDate
 
- 		// 范围结束
 
- 		this.endDate = endDate
 
- 		this.range = range
 
- 		// 多选状态
 
- 		this.cleanMultipleStatus()
 
- 		// 每周日期
 
- 		this.weeks = {}
 
- 		// this._getWeek(this.date.fullDate)
 
- 	}
 
- 	/**
 
- 	 * 设置日期
 
- 	 * @param {Object} date
 
- 	 */
 
- 	setDate(date) {
 
- 		this.selectDate = this.getDate(date)
 
- 		this._getWeek(this.selectDate.fullDate)
 
- 		// // console.log("设置日期");
 
- 	}
 
- 	/**
 
- 	 * 清理多选状态
 
- 	 */
 
- 	cleanMultipleStatus() {
 
- 		this.multipleStatus = {
 
- 			before: '',
 
- 			after: '',
 
- 			data: []
 
- 		}
 
- 		// // console.log("清理多选状态");
 
- 	}
 
- 	/**
 
- 	 * 重置开始日期
 
- 	 */
 
- 	resetSatrtDate(startDate) {
 
- 		// 范围开始
 
- 		this.startDate = startDate
 
- 		// // console.log("重置开始日期");
 
- 	}
 
- 	/**
 
- 	 * 重置结束日期
 
- 	 */
 
- 	resetEndDate(endDate) {
 
- 		// 范围结束
 
- 		this.endDate = endDate
 
- 		// // console.log("重置结束日期");
 
- 	}
 
- 	/**
 
- 	 * 获取任意时间
 
- 	 */
 
- 	getDate(date, AddDayCount = 0, str = 'day') {
 
- 		
 
- 		// // console.log("获取任意时间", date, AddDayCount,str);
 
- 		if (!date) {
 
- 			date = new Date()
 
- 		}
 
- 		if (typeof date !== 'object') {
 
- 			date = date.replace(/-/g, '/')
 
- 		}
 
- 		const dd = new Date(date)
 
- 		switch (str) {
 
- 			case 'day':
 
- 				dd.setDate(dd.getDate() + AddDayCount) // 获取AddDayCount天后的日期
 
- 				break
 
- 			case 'month':
 
- 				if (dd.getDate() === 31) {
 
- 					dd.setDate(dd.getDate() + AddDayCount)
 
- 				} else {
 
- 					dd.setMonth(dd.getMonth() + AddDayCount) // 获取AddDayCount天后的日期
 
- 				}
 
- 				break
 
- 			case 'year':
 
- 				dd.setFullYear(dd.getFullYear() + AddDayCount) // 获取AddDayCount天后的日期
 
- 				break
 
- 		}
 
- 		const y = dd.getFullYear()
 
- 		const m = dd.getMonth() + 1 < 10 ? '0' + (dd.getMonth() + 1) : dd.getMonth() + 1 // 获取当前月份的日期,不足10补0
 
- 		const d = dd.getDate() < 10 ? '0' + dd.getDate() : dd.getDate() // 获取当前几号,不足10补0
 
- 		return {
 
- 			fullDate: y + '-' + m + '-' + d,
 
- 			year: y,
 
- 			month: m,
 
- 			date: d,
 
- 			day: dd.getDay()
 
- 		}
 
- 	}
 
- 	/**
 
- 	 * 获取上月剩余天数
 
- 	 */
 
- 	_getLastMonthDays(firstDay, full) {
 
- 		// // console.log("获取上月剩余天数", firstDay, full);
 
- 		let dateArr = []
 
- 		for (let i = firstDay; i > 0; i--) {
 
- 			const beforeDate = new Date(full.year, full.month - 1, -i + 1).getDate()
 
- 			dateArr.push({
 
- 				date: beforeDate,
 
- 				month: full.month - 1,
 
- 				lunar: this.getlunar(full.year, full.month - 1, beforeDate),
 
- 				disable: true
 
- 			})
 
- 		}
 
- 		return dateArr
 
- 	}
 
- 	/**
 
- 	 * 获取本月天数
 
- 	 */
 
- 	_currentMonthDys(dateData, full) {
 
- 		// // console.log("获取本月天数",dateData, full);
 
- 		let dateArr = []
 
- 		let fullDate = this.date.fullDate
 
- 		for (let i = 1; i <= dateData; i++) {
 
- 			let isinfo = false
 
- 			let nowDate = full.year + '-' + (full.month < 10 ?
 
- 				full.month : full.month) + '-' + (i < 10 ?
 
- 				'0' + i : i)
 
- 			// 是否今天
 
- 			let isDay = fullDate === nowDate
 
- 			// 获取打点信息
 
- 			let info = this.selected && this.selected.find((item) => {
 
- 				if (this.dateEqual(nowDate, item.date)) {
 
- 					return item
 
- 				}
 
- 			})
 
- 			// 日期禁用
 
- 			let disableBefore = true
 
- 			let disableAfter = true
 
- 			if (this.startDate) {
 
- 				// let dateCompBefore = this.dateCompare(this.startDate, fullDate)
 
- 				// // console.log("XXXXXXXXXX", this.startDate, fullDate, dateCompBefore, nowDate);
 
- 				disableBefore = this.dateCompare(this.startDate, nowDate)
 
- 			}
 
- 			if (this.endDate) {
 
- 				// let dateCompAfter = this.dateCompare(fullDate, this.endDate)
 
- 				// // console.log("!!!!!!!!!!!", fullDate, this.endDate,  dateCompAfter, nowDate);
 
- 				disableAfter = this.dateCompare(nowDate, this.endDate)
 
- 			}
 
- 			let multiples = this.multipleStatus.data
 
- 			let checked = false
 
- 			let multiplesStatus = -1
 
- 			if (this.range) {
 
- 				if (multiples) {
 
- 					multiplesStatus = multiples.findIndex((item) => {
 
- 						return this.dateEqual(item, nowDate)
 
- 					})
 
- 				}
 
- 				if (multiplesStatus !== -1) {
 
- 					checked = true
 
- 				}
 
- 			}
 
- 			let data = {
 
- 				fullDate: nowDate,
 
- 				year: full.year,
 
- 				date: i,
 
- 				multiple: this.range ? checked : false,
 
- 				beforeMultiple: this.dateEqual(this.multipleStatus.before, nowDate),
 
- 				afterMultiple: this.dateEqual(this.multipleStatus.after, nowDate),
 
- 				month: full.month,
 
- 				lunar: this.getlunar(full.year, full.month, i),
 
- 				disable: !disableBefore || !disableAfter,
 
- 				isDay
 
- 			}
 
- 			if (info) {
 
- 				data.extraInfo = info
 
- 			}
 
- 			dateArr.push(data)
 
- 		}
 
- 		return dateArr
 
- 	}
 
- 	/**
 
- 	 * 获取下月天数
 
- 	 */
 
- 	_getNextMonthDays(surplus, full) {
 
- 		let dateArr = []
 
- 		for (let i = 1; i < surplus + 1; i++) {
 
- 			dateArr.push({
 
- 				date: i,
 
- 				month: Number(full.month) + 1,
 
- 				lunar: this.getlunar(full.year, Number(full.month) + 1, i),
 
- 				disable: true
 
- 			})
 
- 		}
 
- 		return dateArr
 
- 	}
 
- 	/**
 
- 	 * 获取当前日期详情
 
- 	 * @param {Object} date
 
- 	 */
 
- 	getInfo(date) {
 
- 		if (!date) {
 
- 			date = new Date()
 
- 		}
 
- 		const dateInfo = this.canlender.find(item => item.fullDate === this.getDate(date).fullDate)
 
- 		return dateInfo
 
- 	}
 
- 	/**
 
- 	 * 比较时间大小
 
- 	 */
 
- 	dateCompare(startDate, endDate) {
 
- 		// 计算截止时间
 
- 		startDate = new Date(startDate.replace('-', '/').replace('-', '/'))
 
- 		// 计算详细项的截止时间
 
- 		endDate = new Date(endDate.replace('-', '/').replace('-', '/'))
 
- 		if (startDate <= endDate) {
 
- 			return true
 
- 		} else {
 
- 			return false
 
- 		}
 
- 	}
 
- 	/**
 
- 	 * 比较时间是否相等
 
- 	 */
 
- 	dateEqual(before, after) {
 
- 		// 计算截止时间
 
- 		before = new Date(before.replace('-', '/').replace('-', '/'))
 
- 		// 计算详细项的截止时间
 
- 		after = new Date(after.replace('-', '/').replace('-', '/'))
 
- 		if (before.getTime() - after.getTime() === 0) {
 
- 			return true
 
- 		} else {
 
- 			return false
 
- 		}
 
- 	}
 
- 	/**
 
- 	 * 获取日期范围内所有日期
 
- 	 * @param {Object} begin
 
- 	 * @param {Object} end
 
- 	 */
 
- 	geDateAll(begin, end) {
 
- 		// console.log("获取日期范围内所有日期", begin, end)
 
- 		var arr = []
 
- 		var ab = begin.split('-')
 
- 		var ae = end.split('-')
 
- 		var db = new Date()
 
- 		db.setFullYear(ab[0], ab[1] - 1, ab[2])
 
- 		var de = new Date()
 
- 		de.setFullYear(ae[0], ae[1] - 1, ae[2])
 
- 		var unixDb = db.getTime() - 24 * 60 * 60 * 1000
 
- 		var unixDe = de.getTime() - 24 * 60 * 60 * 1000
 
- 		for (var k = unixDb; k <= unixDe;) {
 
- 			k = k + 24 * 60 * 60 * 1000
 
- 			arr.push(this.getDate(new Date(parseInt(k))).fullDate)
 
- 		}
 
- 		return arr
 
- 	}
 
- 	/**
 
- 	 * 计算阴历日期显示
 
- 	 */
 
- 	getlunar(year, month, date) {
 
- 		return CALENDAR.solar2lunar(year, month, date)
 
- 	}
 
- 	/**
 
- 	 * 设置打点
 
- 	 */
 
- 	setSelectInfo(data, value) {
 
- 		this.selected = value
 
- 		this._getWeek(data)
 
- 	}
 
- 	/**
 
- 	 *  获取多选状态
 
- 	 */
 
- 	setMultiple(fullDate) {
 
- 		let {
 
- 			before,
 
- 			after
 
- 		} = this.multipleStatus
 
- 		// // console.log("获取多选状态", fullDate)
 
- 		// // console.log("获取多选状态before",before)
 
- 		// // console.log("获取多选状态after", after)
 
- 		// // console.log("获取多选状态range", this.range)
 
- 		if(!before && !after){
 
- 			// const start = moment(fullDate).day(-365).format('YYYY-MM-DD');
 
- 			// const end = moment(fullDate).day(365).format('YYYY-MM-DD');
 
- 			const start = moment(fullDate).add(-1, 'years').format("YYYY-MM-DD");//.day(-365).format('YYYY-MM-DD');
 
- 			const end = moment(fullDate).add(1, 'years').format("YYYY-MM-DD");//.day(365).format('YYYY-MM-DD');
 
- 			// console.log("计算开始结算时间",fullDate ,start, end);
 
- 			this.resetSatrtDate(start);
 
- 			this.resetEndDate(end);
 
- 		}
 
- 		if (!this.range) return
 
- 		if (before && after) {
 
- 			this.multipleStatus.before = ''
 
- 			this.multipleStatus.after = ''
 
- 			this.multipleStatus.data = []
 
- 			this.resetSatrtDate('');
 
- 			this.resetEndDate('');
 
- 		} else {
 
- 			if (!before) {
 
- 				this.multipleStatus.before = fullDate
 
- 			} else {
 
- 				this.multipleStatus.after = fullDate
 
- 				if (this.dateCompare(this.multipleStatus.before, this.multipleStatus.after)) {
 
- 					this.multipleStatus.data = this.geDateAll(this.multipleStatus.before, this.multipleStatus.after);
 
- 				} else {
 
- 					this.multipleStatus.data = this.geDateAll(this.multipleStatus.after, this.multipleStatus.before);
 
- 				}
 
- 			}
 
- 		}
 
- 		this._getWeek(fullDate)
 
- 	}
 
- 	/**
 
- 	 * 获取每周数据
 
- 	 * @param {Object} dateData
 
- 	 */
 
- 	_getWeek(dateData) {
 
- 		const {
 
- 			fullDate,
 
- 			year,
 
- 			month,
 
- 			date,
 
- 			day
 
- 		} = this.getDate(dateData)
 
- 		let firstDay = new Date(year, month - 1, 1).getDay()
 
- 		let currentDay = new Date(year, month, 0).getDate()
 
- 		let dates = {
 
- 			lastMonthDays: this._getLastMonthDays(firstDay, this.getDate(dateData)), // 上个月末尾几天
 
- 			currentMonthDys: this._currentMonthDys(currentDay, this.getDate(dateData)), // 本月天数
 
- 			nextMonthDays: [], // 下个月开始几天
 
- 			weeks: []
 
- 		}
 
- 		let canlender = []
 
- 		const surplus = 42 - (dates.lastMonthDays.length + dates.currentMonthDys.length)
 
- 		dates.nextMonthDays = this._getNextMonthDays(surplus, this.getDate(dateData))
 
- 		canlender = canlender.concat(dates.lastMonthDays, dates.currentMonthDys, dates.nextMonthDays)
 
- 		let weeks = {}
 
- 		// 拼接数组  上个月开始几天 + 本月天数+ 下个月开始几天
 
- 		for (let i = 0; i < canlender.length; i++) {
 
- 			if (i % 7 === 0) {
 
- 				weeks[parseInt(i / 7)] = new Array(7)
 
- 			}
 
- 			weeks[parseInt(i / 7)][i % 7] = canlender[i]
 
- 		}
 
- 		this.canlender = canlender
 
- 		this.weeks = weeks
 
- 	}
 
- 	//静态方法
 
- 	// static init(date) {
 
- 	// 	if (!this.instance) {
 
- 	// 		this.instance = new Calendar(date);
 
- 	// 	}
 
- 	// 	return this.instance;
 
- 	// }
 
- }
 
- export default Calendar
 
 
  |