| ¶Ô±ÈÐÂÎļþ |
| | |
| | | <template> |
| | | <view @touchmove.stop.prevent> |
| | | <view class="l-calendar-box" :class="{'calendar-box-show': value}"> |
| | | <view class="calendar-top"> |
| | | <view>{{title}}</view> |
| | | <view class="close l-icons icon-shanchu" hover-class="l-opacity" :hover-stay-time="150" @tap="hide"> |
| | | </view> |
| | | </view> |
| | | |
| | | <view class="date-box"> |
| | | <view class=" date-arrowleft l-icons icon-youjiantou" :style="{ color: yearChangeColor }" |
| | | hover-class="l-opacity" :hover-stay-time="150" @tap="changeYear(false)"> |
| | | </view> |
| | | <view class=" date-arrowleft l-icons icon-zuojiantou" :style="{ color: monthChangeColor }" |
| | | hover-class="l-opacity" :hover-stay-time="150" @tap="changeMonth(false)"></view> |
| | | <view class="title-datetime">{{ showTitle }}</view> |
| | | <view class=" date-arrowright l-icons icon-youjiantou2" :style="{ color: monthChangeColor }" |
| | | hover-class="l-opacity" :hover-stay-time="150" @tap="changeMonth(true)"></view> |
| | | <view class=" date-arrowright l-icons icon-youjiantou1" :style="{ color: yearChangeColor }" |
| | | hover-class="l-opacity" :hover-stay-time="150" @tap="changeYear(true)"></view> |
| | | </view> |
| | | <view class="date-weekday"> |
| | | <view class="date-weekday-item">æ¥</view> |
| | | <view class="date-weekday-item">ä¸</view> |
| | | <view class="date-weekday-item">äº</view> |
| | | <view class="date-weekday-item">ä¸</view> |
| | | <view class="date-weekday-item">å</view> |
| | | <view class="date-weekday-item">äº</view> |
| | | <view class="date-weekday-item">å
</view> |
| | | </view> |
| | | <view class="date-content" :style="{ height: dateHeight * 6 + 'px' }"> |
| | | <block v-for="(item, index) in weekdayArr" :key="index"> |
| | | <view class="date-weekday-item"></view> |
| | | </block> |
| | | <view class="date-weekday-item" :class="{ |
| | | 'l-opacity': isDisable(year, month, index + 1), |
| | | 'start-date': (isRange && startDate == `${year}-${month}-${index + 1}`) || !isRange, |
| | | 'end-date': (isRange && endDate == `${year}-${month}-${index + 1}`) || !isRange |
| | | }" :style="{ backgroundColor: getColor(index, 1), height: dateHeight + 'px',padding:0}" |
| | | v-for="(item, index) in daysArr" :key="index" @tap="dateClick(index)"> |
| | | <view class="date-content-item" :style="{ color: getColor(index, 2) }"> |
| | | <view>{{ index + 1 }}</view> |
| | | <!-- åå --> |
| | | <view class="custom-desc"> |
| | | {{ getText(index, startDate, endDate) }} |
| | | </view> |
| | | </view> |
| | | <view class="date-content-item-desc" :style="{ color: activeColor }" |
| | | v-if="!lunar && isRange && startDate == `${year}-${month}-${index + 1}` && startDate != endDate"> |
| | | {{ startText }} |
| | | </view> |
| | | <view class="date-content-item-desc" :style="{ color: activeColor }" |
| | | v-if="!lunar && isRange && endDate == `${year}-${month}-${index + 1}`">{{ endText }}</view> |
| | | </view> |
| | | <view class="bg-mounth">{{ month }}</view> |
| | | </view> |
| | | |
| | | <view class="calendar-text"> |
| | | <!-- <view class="calendar-result"> |
| | | <text>{{ !isRange ? activeDate : startDate }}</text> |
| | | <text v-if="endDate">è³{{ endDate }}</text> |
| | | </view> --> |
| | | <view class="calendar-btn"> |
| | | <button :style="{opacity:disabled ? '.5' : '1'}" :size="28" :disabled="disabled" |
| | | @click="confireBtnClick(false)">ç¡®å® |
| | | </button> |
| | | </view> |
| | | </view> |
| | | </view> |
| | | |
| | | <view class="mask" :class="[value ? 'mask-show' : '']" @tap="hide"></view> |
| | | </view> |
| | | </template> |
| | | <script> |
| | | import calendar from './calendar.js'; |
| | | export default { |
| | | name: 'lCalendar', |
| | | model: { |
| | | prop: 'value', |
| | | event: 'input' |
| | | }, |
| | | props: { |
| | | //ååç»å®çå¼ ç¨äºå±ç¤º/å
³éæ¥å |
| | | value: { |
| | | type: Boolean, |
| | | default: false |
| | | }, |
| | | //æ¯å¦éæ©èå´ trueæ¯ falseéæ©åä¸ªæ¥æ |
| | | isRange: { |
| | | type: Boolean, |
| | | default: false |
| | | }, |
| | | //å¯åæ¢æå¤§å¹´ä»½ |
| | | maxYear: { |
| | | type: Number, |
| | | default: 2100 |
| | | }, |
| | | //å¯åæ¢æå°å¹´ä»½ |
| | | minYear: { |
| | | type: Number, |
| | | default: 1920 |
| | | }, |
| | | //æå°å¯éæ¥æ ä¸å¨èå´å
æ¥æç¦é |
| | | minDate: { |
| | | type: String, |
| | | default: '1920-01-01' |
| | | }, |
| | | //æå¤§å¯éæ¥æ |
| | | maxDate: { |
| | | type: String, |
| | | default: '2100-1-1' |
| | | }, |
| | | //ç»ä»¶æ é¢ |
| | | title: { |
| | | type: String, |
| | | default: 'æ¥æéæ©' |
| | | }, |
| | | //æä»½åæ¢ç®å¤´é¢è² |
| | | monthChangeColor: { |
| | | type: String, |
| | | default: '#999' |
| | | }, |
| | | //年份忢ç®å¤´é¢è² |
| | | yearChangeColor: { |
| | | type: String, |
| | | default: '#bfbfbf' |
| | | }, |
| | | //é»è®¤æ¥æåä½é¢è² |
| | | color: { |
| | | type: String, |
| | | default: '#333' |
| | | }, |
| | | |
| | | //é䏿¥æåä½é¢è² |
| | | activeColor: { |
| | | type: String, |
| | | default: '#fff' |
| | | }, |
| | | //é䏿¥æèæ¯è² |
| | | activeBgColor: { |
| | | type: String, |
| | | default: '#55BBF9' |
| | | }, |
| | | //èå´å
æ¥æèæ¯è² |
| | | rangeBgColor: { |
| | | type: String, |
| | | default: 'rgba(85, 187, 249, 0.1)' |
| | | }, |
| | | //èå´å
æ¥æåä½é¢è² |
| | | rangeColor: { |
| | | type: String, |
| | | default: '#55BBF9' |
| | | }, |
| | | |
| | | //èå´éæ©æ¶çæ å¼å§æ¥æèªå®ä¹æå |
| | | startText: { |
| | | type: String, |
| | | default: 'å¼å§' |
| | | }, |
| | | //èå´éæ©æ¶çæ ç»ææ¥æèªå®ä¹æå |
| | | endText: { |
| | | type: String, |
| | | default: 'ç»æ' |
| | | }, |
| | | //æ¯å¦æ¾ç¤ºåå |
| | | lunar: { |
| | | type: Boolean, |
| | | default: true |
| | | }, |
| | | //åå§åå¼å§é䏿¥æ æ ¼å¼ï¼ 2020-06-06 æ 2020/06/06 |
| | | initStartDate: { |
| | | type: String, |
| | | default: '' |
| | | }, |
| | | //åå§åç»ææ¥æ æ ¼å¼ï¼ 2020-06-06 æ 2020/06/06 |
| | | initEndDate: { |
| | | type: String, |
| | | default: '' |
| | | } |
| | | }, |
| | | data() { |
| | | return { |
| | | weekday: 1, // ææå ,å¼ä¸º1-7 |
| | | weekdayArr: [], |
| | | days: 0, //å½åææå¤å°å¤© |
| | | daysArr: [], |
| | | showTitle: '',//å½åå¹´ææ é¢ |
| | | year: 2020, |
| | | month: 0, |
| | | day: 0, |
| | | startYear: 0, |
| | | startMonth: 0, |
| | | startDay: 0, |
| | | endYear: 0, |
| | | endMonth: 0, |
| | | endDay: 0, |
| | | today: '', //ä»å¤©çæ¥æ |
| | | activeDate: '', //å½åé䏿¥æ |
| | | startDate: '', //èå´éæ©æ¶çéä¸å¼å§æ¥æ |
| | | endDate: '', //èå´éæ©æ¶çéä¸ç»ææ¥æ |
| | | isStart: true, |
| | | min: null, |
| | | max: null, |
| | | dateHeight: 20 |
| | | }; |
| | | }, |
| | | computed: { |
| | | dataChange() { |
| | | return `${this.type}-${this.minDate}-${this.maxDate}-${this.initStartDate}-${this.initEndDate}`; |
| | | }, |
| | | disabled() { |
| | | return this.isRange && (!this.startDate || !this.endDate) |
| | | } |
| | | }, |
| | | watch: { |
| | | dataChange(val) { |
| | | this.init(); |
| | | }, |
| | | }, |
| | | created() { |
| | | this.init(); |
| | | }, |
| | | methods: { |
| | | getColor(index, type) { |
| | | let color = type == 1 ? '' : this.color; |
| | | let day = index + 1; |
| | | let date = `${this.year}-${this.month}-${day}`; |
| | | let timestamp = new Date(date.replace(/\-/g, '/')).getTime(); |
| | | let start = this.startDate.replace(/\-/g, '/'); |
| | | let end = this.endDate.replace(/\-/g, '/'); |
| | | if ((this.activeDate == date) || this.startDate == date || this.endDate == date) { |
| | | color = type == 1 ? this.activeBgColor : this.activeColor; |
| | | } else if (this.endDate && timestamp > new Date(start).getTime() && timestamp < new Date(end).getTime()) { |
| | | color = type == 1 ? this.rangeBgColor : this.rangeColor; |
| | | } |
| | | return color; |
| | | }, |
| | | getText(index, startDate, endDate) { |
| | | let text = this.lunar ? this.getLunar(this.year, this.month, index + 1) : ''; |
| | | if (this.isRange) { |
| | | if (this.lunar) { |
| | | let date = `${this.year}-${this.month}-${index + 1}`; |
| | | if (startDate == date && startDate != endDate) { |
| | | text = this.startText; |
| | | } else if (endDate == date) { |
| | | text = this.endText; |
| | | } |
| | | } |
| | | } |
| | | return text; |
| | | }, |
| | | getLunar(year, month, day) { |
| | | let obj = calendar.solar2lunar(year, month, day); |
| | | if (obj.IDayCn == 'åä¸') { |
| | | return obj.IMonthCn |
| | | } |
| | | return obj.IDayCn; |
| | | }, |
| | | init() { |
| | | this.dateHeight = uni.getSystemInfoSync().windowWidth / 7; |
| | | let now = new Date(); |
| | | this.year = now.getFullYear(); |
| | | this.month = now.getMonth() + 1; |
| | | this.day = now.getDate(); |
| | | this.today = `${now.getFullYear()}-${now.getMonth() + 1}-${now.getDate()}`; |
| | | this.activeDate = this.today; |
| | | this.min = this.initDate(this.minDate); |
| | | this.max = this.initDate(this.maxDate); |
| | | if (this.isDisable(this.year, this.month, this.day)) { |
| | | this.year = this.min.year; |
| | | this.month = this.min.month; |
| | | this.day = this.min.day; |
| | | this.activeDate = `${this.min.year}-${this.min.month}-${this.min.day}`; |
| | | this.max = this.initDate(this.maxDate || this.minDate); |
| | | } |
| | | this.startDate = ''; |
| | | this.startYear = 0; |
| | | this.startMonth = 0; |
| | | this.startDay = 0; |
| | | if (this.initStartDate) { |
| | | let start = new Date(this.initStartDate.replace(/\-/g, '/')); |
| | | if (!this.isRange) { |
| | | this.year = start.getFullYear(); |
| | | this.month = start.getMonth() + 1; |
| | | this.day = start.getDate(); |
| | | this.activeDate = `${start.getFullYear()}-${start.getMonth() + 1}-${start.getDate()}`; |
| | | } else { |
| | | this.startDate = `${start.getFullYear()}-${start.getMonth() + 1}-${start.getDate()}`; |
| | | this.startYear = start.getFullYear(); |
| | | this.startMonth = start.getMonth() + 1; |
| | | this.startDay = start.getDate(); |
| | | this.activeDate = ''; |
| | | } |
| | | |
| | | } |
| | | this.endYear = 0; |
| | | this.endMonth = 0; |
| | | this.endDay = 0; |
| | | this.endDate = ''; |
| | | if (this.initEndDate && this.isRange) { |
| | | let end = new Date(this.initEndDate.replace(/\-/g, '/')); |
| | | this.endDate = `${end.getFullYear()}-${end.getMonth() + 1}-${end.getDate()}`; |
| | | this.endYear = end.getFullYear(); |
| | | this.endMonth = end.getMonth() + 1; |
| | | this.endDay = end.getDate(); |
| | | this.activeDate = ''; |
| | | this.year = end.getFullYear(); |
| | | this.month = end.getMonth() + 1; |
| | | this.day = end.getDate(); |
| | | } |
| | | this.isStart = true; |
| | | this.changeData(); |
| | | }, |
| | | //æ¥æå¤ç |
| | | initDate(date) { |
| | | let dateArr = date.split('-'); |
| | | return { |
| | | year: Number(dateArr[0] || 1920), |
| | | month: Number(dateArr[1] || 1), |
| | | day: Number(dateArr[2] || 1) |
| | | }; |
| | | }, |
| | | isDisable(year, month, day) { |
| | | let bool = true; |
| | | let date = `${year}/${month}/${day}`; |
| | | let min = `${this.min.year}/${this.min.month}/${this.min.day}`; |
| | | let max = `${this.max.year}/${this.max.month}/${this.max.day}`; |
| | | let timestamp = new Date(date).getTime(); |
| | | if (timestamp >= new Date(min).getTime() && timestamp <= new Date(max).getTime()) { |
| | | bool = false; |
| | | } |
| | | return bool; |
| | | }, |
| | | generateArray(start, end) { |
| | | return Array.from(new Array(end + 1).keys()).slice(start); |
| | | }, |
| | | formatNum(num) { |
| | | return num < 10 ? '0' + num : num + ''; |
| | | }, |
| | | //ä¸ä¸ªææå¤å°å¤© |
| | | getMonthDay(year, month) { |
| | | let days = new Date(year, month, 0).getDate(); |
| | | return days; |
| | | }, |
| | | // è·åå½åæ¥ææ¯ææå |
| | | getWeekday(year, month) { |
| | | let date = new Date(`${year}/${month}/01 00:00:00`); |
| | | return date.getDay(); |
| | | }, |
| | | changeMonth(isAdd) { |
| | | if (isAdd) { |
| | | let month = this.month + 1; |
| | | let year = month > 12 ? this.year + 1 : this.year; |
| | | if (year > this.minYear || year < this.maxYear) { |
| | | this.month = month > 12 ? 1 : month; |
| | | this.year = year; |
| | | this.changeData(); |
| | | } |
| | | } else { |
| | | let month = this.month - 1; |
| | | let year = month < 1 ? this.year - 1 : this.year; |
| | | if (year > this.minYear || year < this.maxYear) { |
| | | this.month = month < 1 ? 12 : month; |
| | | this.year = year; |
| | | this.changeData(); |
| | | } |
| | | } |
| | | }, |
| | | changeYear(isAdd) { |
| | | let year = isAdd ? this.year + 1 : this.year - 1; |
| | | if (year > this.minYear || year < this.maxYear) { |
| | | this.year = year; |
| | | this.changeData(); |
| | | } |
| | | }, |
| | | changeData() { |
| | | this.days = this.getMonthDay(this.year, this.month); |
| | | this.daysArr = this.generateArray(1, this.days); |
| | | this.weekday = this.getWeekday(this.year, this.month); |
| | | this.weekdayArr = this.generateArray(1, this.weekday); |
| | | this.showTitle = `${this.year}å¹´${this.month}æ`; |
| | | if (!this.isRange) { |
| | | this.confireBtnClick(true); |
| | | } |
| | | }, |
| | | dateClick: function(day) { |
| | | day += 1; |
| | | if (!this.isDisable(this.year, this.month, day)) { |
| | | this.day = day; |
| | | let date = `${this.year}-${this.month}-${day}`; |
| | | if (!this.isRange) { |
| | | this.activeDate = date; |
| | | } else { |
| | | let compare = new Date(date.replace(/\-/g, '/')).getTime() < new Date(this.startDate.replace( |
| | | /\-/g, '/')).getTime(); |
| | | if (this.isStart || compare) { |
| | | this.startDate = date; |
| | | this.startYear = this.year; |
| | | this.startMonth = this.month; |
| | | this.startDay = this.day; |
| | | this.endYear = 0; |
| | | this.endMonth = 0; |
| | | this.endDay = 0; |
| | | this.endDate = ''; |
| | | this.activeDate = ''; |
| | | this.isStart = false; |
| | | } else { |
| | | this.endDate = date; |
| | | this.endYear = this.year; |
| | | this.endMonth = this.month; |
| | | this.endDay = this.day; |
| | | this.isStart = true; |
| | | } |
| | | } |
| | | } |
| | | }, |
| | | hide() { |
| | | this.$emit('input', false) |
| | | }, |
| | | getWeekText(date) { |
| | | date = new Date(`${date.replace(/\-/g, '/')} 00:00:00`); |
| | | let week = date.getDay(); |
| | | return 'ææ' + ['æ¥', 'ä¸', 'äº', 'ä¸', 'å', 'äº', 'å
'][week]; |
| | | }, |
| | | confireBtnClick(show) { |
| | | if (!show) { |
| | | this.hide(); |
| | | } |
| | | if (!this.isRange) { |
| | | let arr = this.activeDate.split('-'); |
| | | let year = +arr[0]; |
| | | let month = +arr[1]; |
| | | let day = +arr[2]; |
| | | //å½åææå¤å°å¤© |
| | | let days = this.getMonthDay(year, month); |
| | | let result = `${year}-${this.formatNum(month)}-${this.formatNum(day)}`; |
| | | let weekText = this.getWeekText(result); |
| | | let isToday = false; |
| | | if (`${year}-${month}-${day}` == this.today) { |
| | | //ä»å¤© |
| | | isToday = true; |
| | | } |
| | | let lunar = calendar.solar2lunar(year, month, day); |
| | | this.$emit('change', { |
| | | year: year, |
| | | month: month, |
| | | day: day, |
| | | days: days, |
| | | result: result, |
| | | week: weekText, |
| | | isToday: isToday, |
| | | lunar: lunar |
| | | }); |
| | | } else { |
| | | if (!this.startDate || !this.endDate) return; |
| | | let startMonth = this.formatNum(this.startMonth); |
| | | let startDay = this.formatNum(this.startDay); |
| | | let startDate = `${this.startYear}-${startMonth}-${startDay}`; |
| | | let startWeek = this.getWeekText(startDate); |
| | | let startLunar = calendar.solar2lunar(this.startYear, startMonth, startDay); |
| | | |
| | | let endMonth = this.formatNum(this.endMonth); |
| | | let endDay = this.formatNum(this.endDay); |
| | | let endDate = `${this.endYear}-${endMonth}-${endDay}`; |
| | | let endWeek = this.getWeekText(endDate); |
| | | let endLunar = calendar.solar2lunar(this.endYear, endMonth, endDay); |
| | | this.$emit('change', { |
| | | startYear: this.startYear, |
| | | startMonth: this.startMonth, |
| | | startDay: this.startDay, |
| | | startDate: startDate, |
| | | startWeek: startWeek, |
| | | startLunar: startLunar, |
| | | endYear: this.endYear, |
| | | endMonth: this.endMonth, |
| | | endDay: this.endDay, |
| | | endDate: endDate, |
| | | endWeek: endWeek, |
| | | endLunar: endLunar |
| | | }); |
| | | } |
| | | } |
| | | } |
| | | }; |
| | | </script> |
| | | |
| | | <style lang="scss" scoped> |
| | | @font-face { |
| | | font-family: 'l-icons'; |
| | | src: url('data:font/ttf;charset=utf-8;base64,AAEAAAANAIAAAwBQRkZUTZa9XzsAAAjcAAAAHEdERUYAKQAOAAAIvAAAAB5PUy8yPDVJwwAAAVgAAABgY21hcMxRtw0AAAHUAAABYmdhc3D//wADAAAItAAAAAhnbHlm05h+ZAAAA0wAAAJ8aGVhZCQifFoAAADcAAAANmhoZWEHyAOSAAABFAAAACRobXR4EnYBLQAAAbgAAAAcbG9jYQKkAegAAAM4AAAAEm1heHABFgBMAAABOAAAACBuYW1lXoIBAgAABcgAAAKCcG9zdMeZtAYAAAhMAAAAaAABAAAAAQAA+jMzTF8PPPUACwQAAAAAAOCMnBkAAAAA4IycGQAA/6sD6gOAAAAACAACAAAAAAAAAAEAAAOA/4AAXAQLAAAAAAPqAAEAAAAAAAAAAAAAAAAAAAAGAAEAAAAIAEAABAAAAAAAAgAAAAoACgAAAP8AAAAAAAAABAQEAZAABQAAAokCzAAAAI8CiQLMAAAB6wAyAQgAAAIABQMAAAAAAAAAAAAAAAAAAAAAAAAAAAAAUGZFZADA5gDm8AOA/4AAAAPcAIAAAAABAAAAAAAAAAAAAAAgAAEEAAAAAAAAAAFVAAAECwAWBAsAHgQAAPkBCwAAAAAAAwAAAAMAAAAcAAEAAAAAAFwAAwABAAAAHAAEAEAAAAAMAAgAAgAE5gDmB+Yf5iPm8P//AADmAOYH5h/mI+bw//8aAxn9GeYZ4xkXAAEAAAAAAAAAAAAAAAAAAAEGAAABAAAAAAAAAAECAAAAAgAAAAAAAAAAAAAAAAAAAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAByAOAA9AEIAT4AAAAEABb/wQPiA0sAIQAkAD4APwAAAQYUFwEWHwE3Njc2JyYnJicBJwE2NzY3NicmJzEuAQYHCQE3ByU+ATc2JwEnNwE2Jy4BDwEGBw4BFwEWHwE3MQHuFhYBcRIZDAwvDQQDAwsFBf7IBQE3DgUJAgICAQQLLDET/o8BqAwM/kUbJwEBGf7HBgYBOhwGB1MiabFZFwEXAXESGAoJAbkWQxf+kBIEAgIKLQ8TDw4HBAE5BAE3DQgNDRINBQkYGAcT/o/+CAICAQIqGyIZATkEBQE6HCUsHh5psVgXRBf+kBIEAgEAAAAEAB7/tQPqAz8AIAAiADwAPQAAATY0JwEmLwEHBgcGFxYXFhcBFwEGBwYHBhcWFzEeATY3AwclDgEHBhcBFwcBBhceAT8BNjc+AScBJi8BBzECEhYW/o8SGQwMLw0EAwMLBQUBOAX+yQ4FCQICAgEECywxEzcMAccbJwEBGQE5Bgb+xhwGB1MiabFZFwEX/o8SGAoJAUcWQxcBcBIEAgIKLQ8TDw4HBP7HBP7JDQgNDRINBQkYGAcTA2kCAQIqGyIZ/scEBf7GHCUsHh5psVgXRBcBcBIEAgEAAAAAAQD5/68DSQOAAAUAADcXCQEHAflnAen+F2cBghZnAekB6Gf+fwAAAAEBC/+rAxgDVQAFAAAJARcJAQcBCwG9UP6JAWJRAYEB1Ez+dv52SgABAAD/sAPOA4AAGwAACQEWFAYiJwkBBiImNDcJASY0NjIXCQE2MhYUBwJPAWoVKzwW/pb+lhY8KxUBa/6VFSs8FgFqAWoWPCsVAZj+lRU9KxUBa/6VFSs9FQFrAWsVPSsV/pUBaxUrPRUAAAAAABIA3gABAAAAAAAAABMAKAABAAAAAAABAAgATgABAAAAAAACAAcAZwABAAAAAAADAAgAgQABAAAAAAAEAAgAnAABAAAAAAAFAAsAvQABAAAAAAAGAAgA2wABAAAAAAAKACsBPAABAAAAAAALABMBkAADAAEECQAAACYAAAADAAEECQABABAAPAADAAEECQACAA4AVwADAAEECQADABAAbwADAAEECQAEABAAigADAAEECQAFABYApQADAAEECQAGABAAyQADAAEECQAKAFYA5AADAAEECQALACYBaABDAHIAZQBhAHQAZQBkACAAYgB5ACAAaQBjAG8AbgBmAG8AbgB0AABDcmVhdGVkIGJ5IGljb25mb250AABpAGMAbwBuAGYAbwBuAHQAAGljb25mb250AABSAGUAZwB1AGwAYQByAABSZWd1bGFyAABpAGMAbwBuAGYAbwBuAHQAAGljb25mb250AABpAGMAbwBuAGYAbwBuAHQAAGljb25mb250AABWAGUAcgBzAGkAbwBuACAAMQAuADAAAFZlcnNpb24gMS4wAABpAGMAbwBuAGYAbwBuAHQAAGljb25mb250AABHAGUAbgBlAHIAYQB0AGUAZAAgAGIAeQAgAHMAdgBnADIAdAB0AGYAIABmAHIAbwBtACAARgBvAG4AdABlAGwAbABvACAAcAByAG8AagBlAGMAdAAuAABHZW5lcmF0ZWQgYnkgc3ZnMnR0ZiBmcm9tIEZvbnRlbGxvIHByb2plY3QuAABoAHQAdABwADoALwAvAGYAbwBuAHQAZQBsAGwAbwAuAGMAbwBtAABodHRwOi8vZm9udGVsbG8uY29tAAAAAAIAAAAAAAAACgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACAAAAAEAAgECAQMBBAEFAQYKeW91amlhbnRvdQt5b3VqaWFudG91MQt5b3VqaWFudG91Mgp6dW9qaWFudG91B3NoYW5jaHUAAAAB//8AAgABAAAADAAAABYAAAACAAEAAwAHAAEABAAAAAIAAAAAAAAAAQAAAADVpCcIAAAAAOCMnBkAAAAA4IycGQ==') format('truetype'); |
| | | font-weight: normal; |
| | | font-style: normal; |
| | | font-display: swap; |
| | | } |
| | | |
| | | .l-icons { |
| | | font-family: 'l-icons'; |
| | | font-size: 38rpx; |
| | | color: #333333; |
| | | font-style: normal; |
| | | -webkit-font-smoothing: antialiased; |
| | | -moz-osx-font-smoothing: grayscale |
| | | } |
| | | |
| | | .icon-shanchu:before { |
| | | content: "\e6f0"; |
| | | } |
| | | |
| | | .icon-youjiantou:before { |
| | | content: "\e600"; |
| | | } |
| | | |
| | | .icon-zuojiantou:before { |
| | | content: "\e623"; |
| | | } |
| | | |
| | | .icon-youjiantou1:before { |
| | | content: "\e607"; |
| | | } |
| | | |
| | | .icon-youjiantou2:before { |
| | | content: "\e61f"; |
| | | } |
| | | |
| | | .l-calendar-box { |
| | | width: 100%; |
| | | position: fixed; |
| | | left: 0; |
| | | right: 0; |
| | | bottom: 0; |
| | | z-index: 99999; |
| | | visibility: hidden; |
| | | transform: translate3d(0, 100%, 0); |
| | | transform-origin: center; |
| | | transition: all 0.3s ease-in-out; |
| | | min-height: 20rpx; |
| | | |
| | | .calendar-top { |
| | | width: 100%; |
| | | height: 80rpx; |
| | | padding: 0 40rpx; |
| | | display: flex; |
| | | justify-content: center; |
| | | align-items: center; |
| | | box-sizing: border-box; |
| | | font-size: 30rpx; |
| | | font-weight: bold; |
| | | background-color: #fff; |
| | | color: #333; |
| | | position: relative; |
| | | border-top-left-radius: 20rpx; |
| | | border-top-right-radius: 20rpx; |
| | | overflow: hidden; |
| | | .close { |
| | | position: absolute; |
| | | right: 30rpx; |
| | | top: 50%; |
| | | transform: translateY(-50%); |
| | | color: #999; |
| | | |
| | | } |
| | | } |
| | | |
| | | .date-box { |
| | | width: 100%; |
| | | display: flex; |
| | | align-items: center; |
| | | justify-content: center; |
| | | padding: 20rpx 0 30rpx; |
| | | background-color: #fff; |
| | | .date-arrowleft { |
| | | margin-right: 32rpx; |
| | | } |
| | | |
| | | .date-arrowright { |
| | | margin-left: 32rpx; |
| | | } |
| | | |
| | | .title-datetime { |
| | | padding: 0 16rpx; |
| | | color: #333; |
| | | font-size: 30rpx; |
| | | line-height: 30rpx; |
| | | font-weight: bold; |
| | | } |
| | | } |
| | | |
| | | .date-weekday { |
| | | width: 100%; |
| | | display: flex; |
| | | align-items: center; |
| | | background-color: #fff; |
| | | font-size: 24rpx; |
| | | line-height: 24rpx; |
| | | color: #555; |
| | | box-shadow: 0 15rpx 20rpx -15rpx #efefef; |
| | | position: relative; |
| | | z-index: 2; |
| | | .date-weekday-item { |
| | | width: 14.2857%; |
| | | display: flex; |
| | | align-items: center; |
| | | justify-content: center; |
| | | padding: 12rpx 0; |
| | | overflow: hidden; |
| | | position: relative; |
| | | z-index: 2; |
| | | } |
| | | } |
| | | .date-content { |
| | | width: 100%; |
| | | display: flex; |
| | | flex-wrap: wrap; |
| | | padding: 12rpx 0; |
| | | box-sizing: border-box; |
| | | background-color: #fff; |
| | | position: relative; |
| | | align-content: flex-start; |
| | | .date-weekday-item { |
| | | width: 14.2857%; |
| | | display: flex; |
| | | align-items: center; |
| | | justify-content: center; |
| | | padding: 12rpx 0; |
| | | overflow: hidden; |
| | | position: relative; |
| | | z-index: 2; |
| | | |
| | | .date-content-item { |
| | | width: 80rpx; |
| | | height: 80rpx; |
| | | display: flex; |
| | | align-items: center; |
| | | justify-content: center; |
| | | flex-direction: column; |
| | | font-size: 32rpx; |
| | | line-height: 32rpx; |
| | | position: relative; |
| | | border-radius: 50%; |
| | | background-color: transparent; |
| | | .custom-desc { |
| | | width: 100%; |
| | | font-size: 24rpx; |
| | | line-height: 24rpx; |
| | | transform: scale(0.8); |
| | | transform-origin: center center; |
| | | text-align: center; |
| | | } |
| | | |
| | | } |
| | | .date-content-item-desc { |
| | | width: 100%; |
| | | font-size: 24rpx; |
| | | line-height: 24rpx; |
| | | position: absolute; |
| | | left: 0; |
| | | transform: scale(0.8); |
| | | transform-origin: center center; |
| | | text-align: center; |
| | | bottom: 8rpx; |
| | | z-index: 2; |
| | | } |
| | | } |
| | | .start-date { |
| | | border-top-left-radius: 8rpx; |
| | | border-bottom-left-radius: 8rpx; |
| | | } |
| | | |
| | | .end-date { |
| | | border-top-right-radius: 8rpx; |
| | | border-bottom-right-radius: 8rpx; |
| | | } |
| | | |
| | | .bg-mounth { |
| | | position: absolute; |
| | | font-size: 260rpx; |
| | | line-height: 260rpx; |
| | | left: 50%; |
| | | top: 50%; |
| | | transform: translate(-50%, -50%); |
| | | color: #f5f5f7; |
| | | z-index: 1; |
| | | } |
| | | } |
| | | |
| | | |
| | | .calendar-text { |
| | | width: 100%; |
| | | display: flex; |
| | | align-items: center; |
| | | justify-content: center; |
| | | flex-direction: column; |
| | | background-color: #fff; |
| | | padding: 0 42rpx env(safe-area-inset-bottom); |
| | | box-sizing: border-box; |
| | | font-size: 24rpx; |
| | | color: #666; |
| | | .calendar-result { |
| | | height: 48rpx; |
| | | transform: scale(0.9); |
| | | transform-origin: center 100%; |
| | | } |
| | | |
| | | .calendar-btn { |
| | | width: 100%; |
| | | |
| | | button { |
| | | background-color: #305ED5; |
| | | color: #fff; |
| | | height: 72rpx; |
| | | line-height: 72rpx; |
| | | font-size: 32rpx |
| | | } |
| | | } |
| | | } |
| | | |
| | | |
| | | |
| | | } |
| | | .mask { |
| | | position: fixed; |
| | | top: 0; |
| | | left: 0; |
| | | right: 0; |
| | | bottom: 0; |
| | | background: rgba(0, 0, 0, 0.6); |
| | | z-index: 9996; |
| | | transition: all 0.3s ease-in-out; |
| | | opacity: 0; |
| | | visibility: hidden; |
| | | } |
| | | |
| | | .mask-show { |
| | | opacity: 1; |
| | | visibility: visible; |
| | | } |
| | | |
| | | /* @font-face { |
| | | font-family: 'tuiDateFont'; |
| | | src: url(data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAAAVgAA0AAAAACAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABGRlRNAAAFRAAAABoAAAAci0/w50dERUYAAAUkAAAAHgAAAB4AKQANT1MvMgAAAaAAAABDAAAAVjxuSNNjbWFwAAAB+AAAAEoAAAFS5iPQt2dhc3AAAAUcAAAACAAAAAj//wADZ2x5ZgAAAlQAAAFHAAABvPf29TBoZWFkAAABMAAAADAAAAA2GMsN3WhoZWEAAAFgAAAAHQAAACQHjAOFaG10eAAAAeQAAAATAAAAFgzQAPJsb2NhAAACRAAAABAAAAAQAOoBSG1heHAAAAGAAAAAHgAAACABEwA3bmFtZQAAA5wAAAFJAAACiCnmEVVwb3N0AAAE6AAAADQAAABLUwjqHHjaY2BkYGAAYp5Gj5/x/DZfGbhZGEDg1tUn7+F00P/LzOuY9YFcDgYmkCgAa0gNlHjaY2BkYGBu+N/AEMPCAALM6xgYGVABCwBT4AMaAAAAeNpjYGRgYGBn0GZgYgABEMkFhAwM/8F8BgANaAFLAAB42mNgZGFgnMDAysDA1Ml0hoGBoR9CM75mMGLkAIoysDIzYAUBaa4pDA7PGJ49ZG7438AQw9zA0AAUZgTJAQDrcAy8AHjaY2GAABYIDgLCBQx1AAcEAc8AeNpjYGBgZoBgGQZGBhDwAfIYwXwWBgMgzQGETAwMzxifcTx7+P8/kMUAYUkxS/6VVIXqAgNGNgY4lxGoB6QPBTAyDHsAADDkDYkAAAAAAAAAAAAAADQAagC2AN542m2QsU7DMBCG/Tt1bNPUiUnkSgiVtqKpxJAgVLVbeAa6MaK+B4JXgJWBjY21UtW5gpkdMTFX7dzApaJLhXU6n8+n//ttxtn458N79XJWZ8eMxS00C4wy9A1EP8PQncAlIQzS4WgsVtPpSmwzV3OFRqLetH5TSQMK939X61ptPZ2p2EAttNMLBRMrtschQblDeS34aY50cIkCzg/B2Y5C+VpyQxhFkRgu515O8jvU5mmPM2O0wJ5Z27vhX+yMsV437WvCdTM+GI40MgwKfuGammC0uURqeqFMfe9cxaJclkt5GMaB1hIR1VobOgpEiKq+sLZcIrJWhO3/Jw7qWlYj1Jf21FaCtmd5bevrlk28O/7A4spXTl4KTh9MTlqQ8PESBRstReic+sRj0Dni9fIqmNS/pXNWCvWOeYBmx5S9Bsn9Ah+5WtAAeNp9kD1OAzEQhZ/zByQSQiCoXVEA2vyUKRMp9Ailo0g23pBo1155nUg5AS0VB6DlGByAGyDRcgpelkmTImvt6PObmeexAZzjGwr/3yXuhBWO8ShcwREy4Sr1F+Ea+V24jhY+hRvUf4SbuFUD4RYu1BsdVO2Eu5vSbcsKZxgIV3CKJ+Eq9ZVwjfwqXMcVPoQb1L+EmxjjV7iFa2WpDOFhMEFgnEFjig3jAjEcLJIyBtahOfRmEsxMTzd6ETubOBso71dilwMeaDnngCntPbdmvkon/mDLgdSYbh4FS7YpjS4idCgbXyyc1d2oc7D9nu22tNi/a4E1x+xRDWzU/D3bM9JIbAyvkJI18jK3pBJTj2hrrPG7ZynW814IiU68y/SIx5o0dTr3bmniwOLn8owcfbS5kj33qBw+Y1kIeb/dTsQgil2GP5PYcRkAAAB42mNgYoAALjDJyIAO2MGiTIxMjMyMLIys7GmJeRmlmWZQ2pQ5OSORLaU0Mz2/FACDfwlbAAAAAf//AAIAAQAAAAwAAAAWAAAAAgABAAMABgABAAQAAAACAAAAAHjaY2BgYGQAgqtL1DlA9K2rT97DaABNlwiuAAA=) format('woff'); |
| | | font-weight: normal; |
| | | font-style: normal; |
| | | } |
| | | |
| | | .tui-iconfont { |
| | | font-family: 'tuiDateFont' !important; |
| | | font-size: 36rpx; |
| | | font-style: normal; |
| | | -webkit-font-smoothing: antialiased; |
| | | -moz-osx-font-smoothing: grayscale; |
| | | } |
| | | |
| | | .tui-font-close:before { |
| | | content: '\e608'; |
| | | } |
| | | |
| | | .tui-font-check:before { |
| | | content: '\e6e1'; |
| | | } |
| | | |
| | | .date-arrowright:before { |
| | | content: '\e600'; |
| | | } |
| | | |
| | | .date-arrowleft:before { |
| | | content: '\e601'; |
| | | } */ |
| | | |
| | | |
| | | // .calendar-radius { |
| | | // border-top-left-radius: 20rpx; |
| | | // border-top-right-radius: 20rpx; |
| | | // overflow: hidden; |
| | | // } |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | .tui-btn-calendar { |
| | | padding: 16rpx; |
| | | box-sizing: border-box; |
| | | text-align: center; |
| | | text-decoration: none; |
| | | } |
| | | |
| | | .l-opacity { |
| | | opacity: 0.5; |
| | | } |
| | | |
| | | |
| | | |
| | | .calendar-box-show { |
| | | transform: translate3d(0, 0, 0); |
| | | visibility: visible; |
| | | } |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | // .tui-lunar-unshow { |
| | | // position: absolute; |
| | | // left: 0; |
| | | // bottom: 8rpx; |
| | | // z-index: 2; |
| | | // } |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | </style> |