提交 33400eb3 编写于 作者: KK's avatar KK

日历组件

上级 9a903cc7
......@@ -52,7 +52,9 @@ export const AppComponents = {
v.component('app-list-swipe', () => import('@/components/app-list-swipe/app-list-swipe.vue'));
v.component('app-mob-rate', () => import('@/components/app-mob-rate/app-mob-rate.vue'));
v.component('app-mob-select-drop-down', () => import('@/components/app-mob-select-drop-down/app-mob-select-drop-down.vue'));
v.component('app-mob-textarea',() => import('./components/app-mob-textarea/app-mob-textarea.vue'))
v.component('app-mob-textarea',() => import('./components/app-mob-textarea/app-mob-textarea.vue'));
// 日历组件
v.component('app-calendar',() => import('@/components/app-calendar/app-calendar.vue'));
// 编辑器 BEGIN
// 图片选择
......
<template>
<div class="mpvue-calendar" ref="calendar">
<div class="calendar-tools" v-if="!isMonthRange">
<div class="calendar-prev" @click="prev">
<img :src="arrowLeft" v-if="!!arrowLeft">
<i class="iconfont icon-arrow-left" v-else></i>
</div>
<div class="calendar-next" @click="next">
<img :src="arrowRight" v-if="!!arrowRight">
<i class="iconfont icon-arrow-right" v-else></i>
</div>
<div class="calendar-info" @click.stop="changeYear">
<div class="mc-month">
<div
:class="['mc-month-inner', oversliding ? '' : 'month-transition']"
:style="{'top': monthPosition + unit}"
v-if="isIos"
>
<span v-for="(m, i) in monthsLoop" :key="i" >{{m}}</span>
</div>
<div class="mc-month-text" v-else>{{monthText}}</div>
</div>
<div class="mc-year">{{year}}</div>
</div>
</div>
<table cellpadding="5">
<div class="mc-head" :class="['mc-head', {'mc-month-range-mode-head': isMonthRange}]">
<div class="mc-head-box">
<div v-for="(week, index) in weeks" :key="index" class="mc-week">{{week}}</div>
</div>
</div>
<div
:class="['mc-body', {'mc-range-mode': range, 'week-switch': weekSwitch && !isMonthRange, 'month-range-mode': isMonthRange}]"
v-for="(days, index) in monthRangeDays"
:key='index'
>
<div class="month-rang-head" v-if="isMonthRange">{{rangeOfMonths[index][2]}}</div>
<tr v-for="(day,k1) in days" :key="k1" :class="{'gregorianStyle': !lunar}">
<td
v-for="(child,k2) in day"
:key="k2"
:class="[{'selected': child.selected, 'mc-today-element': child.isToday, 'disabled': child.disabled,
'mc-range-select-one': rangeBgHide && child.selected, 'lunarStyle': lunar, 'mc-range-row-first': k2 === 0 && child.selected,
'month-last-date': child.lastDay, 'month-first-date': 1 === child.day, 'mc-range-row-last': k2 === 6 && child.selected,
'mc-last-month': child.lastMonth, 'mc-next-month': child.nextMonth}, child.className, child.rangeClassName]"
@click="select(k1, k2, child, $event, index)"
class="mc-day"
:style="itemStyle"
>
<span v-if="showToday.show && child.isToday" class="mc-today calendar-date">{{showToday.text}}</span>
<span :class="[{'mc-date-red': k2 === (monFirst ? 5 : 0) || k2 === 6}, 'calendar-date']" v-else>{{child.day}}</span>
<div class="slot-element" v-if="!!child.content">{{child.content}}</div>
<div class="mc-text remark-text" v-if="child.eventName && !clean">{{child.eventName}}</div>
<div class="mc-dot" v-if="child.eventName && clean" />
<!-- user -->
<div class="sign" v-if="sign.date == child.date" >
<div v-for="(sigin,si) in sign.signs" :key="si" :style="{color: sigin.color}">——</div>
</div>
<div
class="mc-text"
:class="{'isLunarFestival': child.isAlmanac || child.isLunarFestival, 'isGregorianFestival': child.isGregorianFestival, 'isTerm': child.isTerm}"
v-if="lunar && (!child.eventName || clean)"
>
{{child.almanac || child.lunar}}
</div>
<div class="mc-range-bg" v-if="range && child.selected" />
</td>
</tr>
</div>
</table>
<div class="mpvue-calendar-change" :class="{'show': yearsShow}">
<div class="calendar-years" v-if="!weekSwitch">
<span v-for="y in years" :key="y" @click.stop="selectYear(y)" :class="{'active': y === year}">{{y}}</span>
</div>
<div :class="['calendar-months', {'calendar-week-switch-months': weekSwitch}]">
<span v-for="(m, i) in months" :key="m" @click.stop="changeMonth(i)" :class="{'active': i === month}">{{m}}</span>
</div>
</div>
</div>
</template>
<script>
import calendar, {defaultLunar, defaultGregorian, todayString, isBrowser} from './calendarinit.js';
import './icon.css';
export default {
props: {
multi: {
type: Boolean,
default: false
},
arrowLeft: {
type: String,
default: ''
},
arrowRight: {
type: String,
default: ''
},
clean: {
type: Boolean,
default: false
},
now: {
type: [String, Boolean],
default: true
},
range: {
type: Boolean,
default: false
},
completion: {
type: Boolean,
default: false
},
value: {
type: Array,
default() {
return [];
}
},
begin: {
type: Array,
default() {
return [];
}
},
end: {
type: Array,
default() {
return [];
}
},
zero: {
type: Boolean,
default: false
},
disabled: {
type: Array,
default() {
return [];
}
},
almanacs: {
type: Object,
default() {
return {};
}
},
tileContent: {
type: Array,
default() {
return [];
}
},
sign:{type: Object, default:{}
},
lunar: {
type: Boolean,
default: false
},
monFirst: {
type: Boolean,
default: false
},
weeks: {
type: Array,
default() {
return this.monFirst ? ['一', '二', '三', '四', '五', '六', '日'] : ['日', '一', '二', '三', '四', '五', '六'];
}
},
months: {
type: Array,
default() {
return ['一月', '二月', '三月', '四月', '五月', '六月', '七月', '八月', '九月', '十月', '十一月', '十二月'];
}
},
events: {
type: Object,
default() {
return {};
}
},
weekSwitch: {
type: Boolean,
default: false
},
monthRange: {
type: Array,
default() {
return [];
}
},
responsive: {
type: Boolean,
default: false
},
rangeMonthFormat: {
type: String,
default: ''
}
},
data() {
return {
years: [],
yearsShow: false,
year: 0,
month: 0,
monthPosition: 0,
day: 0,
days: [],
multiDays: [],
today: [],
handleMultiDay: [],
firstRender: true,
isIos: true,
showToday: {},
monthText: '',
festival: {
lunar: defaultLunar,
gregorian: defaultGregorian,
},
rangeBegin: [],
rangeEnd: [],
multiDaysData: [],
monthsLoop: [],
itemWidth: 50,
unit: isBrowser ? 'px' : 'rpx',
positionH: isBrowser ? -24 : -40,
monthIndex: 0,
oversliding: false,
rangeBgHide: false,
monthRangeDays: [],
rangeOfMonths: [],
monthDays: [],
weekIndex: 0,
startWeekIndex: 0,
positionWeek: true,
isMonthRange: false,
};
},
computed: {
itemStyle() {
return {
width: `${this.itemWidth}px`,
height: `${this.itemWidth}px`,
fontSize: `${this.itemWidth / 4}px`,
lineHeight: this.lunar ? `${this.itemWidth / 1.5}px` : `${this.itemWidth}px`
};
}
},
watch: {
events() {
if (this.isRendeRangeMode()) return;
this.render(this.year, this.month, '_WATCHRENDER_', 'events');
},
disabled() {
if (this.isRendeRangeMode()) return;
this.render(this.year, this.month, '_WATCHRENDER_', 'disabled');
},
value() {
if (this.isRendeRangeMode('_WATCHRENDERVALUE_')) return;
const {value} = this;
let year = value[0] || this.year;
let month = value[1] - 1 || this.month;
let day;
if (this.multi) {
if (this.isUserSelect) {
year = this.year;
month = this.month;
this.isUserSelect = false;
} else {
year = (value[value.length - 1] || [])[0] || this.year;
month = (value[value.length - 1]|| [])[1] - 1 || this.month;
}
} else if (this.range) {
if (this.isUserSelect) {
year = this.year;
month = this.month;
this.isUserSelect = false;
} else {
if (value.length) {
year = value[0][0];
month = value[0][1] - 1;
day = value[0][2];
}
return this.render(year, month, '_WATCHRENDERVALUE_', [year, month, day]);
}
}
this.render(year, month, '_WATCHRENDERVALUE_');
},
tileContent() {
if (this.isRendeRangeMode()) return;
this.render(this.year, this.month, '_WATCHRENDER_', 'tileContent');
},
almanacs() {
if (this.isRendeRangeMode()) return;
this.render(this.year, this.month, '_WATCHRENDER_', 'almanacs');
},
monthRange() {
if (this.isRendeRangeMode()) return;
this.render(this.year, this.month, '_WATCHRENDER_', 'almanacs');
},
responsive() {
if (this.responsive) this.addResponsiveListener();
},
weekSwitch() {
if (this.isRendeRangeMode()) return;
this.render(this.year, this.month, '_WATCHRENDER_', 'almanacs');
}
},
created() {
this.isMonthRange = !!this.monthRange.length;
const loopArray = this.months.concat();
loopArray.unshift(this.months[this.months.length - 1]);
loopArray.push(this.months[0]);
this.monthsLoop = loopArray;
this.monthsLoopCopy = this.monthsLoop.concat();
},
mounted() {
const self = this;
this.resize();
if (!isBrowser) {
wx.getSystemInfo({
success(res) {
self.isIos = (res.system.split(' ') || [])[0] === 'iOS';
}
});
} else if (this.responsive) {
this.addResponsiveListener();
}
this.oversliding = true;
this.initRender = true;
this.init();
console.log(this.monthRangeDays)
},
beforeDestroy() {
if (isBrowser) {
window.removeEventListener('resize', this.resize);
}
},
methods: {
init() {
const now = new Date();
this.year = now.getFullYear();
this.month = now.getMonth();
this.day = now.getDate();
this.monthIndex = this.month + 1;
if (this.value.length || this.multi) {
if (this.range) {
this.year = Number(this.value[0][0]);
this.month = this.value[0][1] - 1;
this.day = Number(this.value[0][2]);
const yearEnd = Number(this.value[1][0]);
const monthEnd = this.value[1][1] - 1;
const dayEnd = this.value[1][2];
this.rangeBegin = [this.year, this.month, this.day];
this.rangeEnd = [yearEnd, monthEnd, dayEnd];
} else if (this.multi) {
this.multiDays = this.value;
const {handleMultiDay} = this;
if (this.firstRender) {
this.firstRender = false;
const thatYear = (this.value[0] || [])[0];
const thatMonth = (this.value[0] || [])[1];
if (isFinite(thatYear) && isFinite(thatMonth)) {
this.month = parseInt(thatMonth, 10) - 1;
this.year = parseInt(thatYear, 10);
}
} else if (this.handleMultiDay.length) {
this.month = parseInt(handleMultiDay[handleMultiDay.length - 1][1], 10) - 1;
this.year = parseInt(handleMultiDay[handleMultiDay.length - 1][0], 10);
this.handleMultiDay = [];
} else {
this.month = parseInt(this.value[this.value.length - 1][1], 10) - 1;
this.year = parseInt(this.value[this.value.length - 1][0], 10);
}
this.day = parseInt((this.value[0] || [])[2], 10);
} else {
this.year = parseInt(this.value[0], 10);
this.month = parseInt(this.value[1], 10) - 1;
this.day = parseInt(this.value[2], 10);
}
}
this.updateHeadMonth();
if (this.isRendeRangeMode()) return;
this.render(this.year, this.month);
},
renderOption(year, month, i, playload) {
const weekSwitch = this.monthRange.length ? false : this.weekSwitch;
const {value: selectSplit} = this;
const isMonthModeCurrentMonth = !weekSwitch && !playload;
const disabledFilter = (disabled) => disabled.find(v => {
const dayArr = v.split('-');
return year === Number(dayArr[0]) && month === (dayArr[1] - 1) && i === Number(dayArr[2]);
});
if (this.range) {
const lastDay = new Date(year, month + 1, 0).getDate() === i ? {lastDay: true} : null;
const options = Object.assign(
{day: i},
this.getLunarInfo(year, month + 1, i),
this.getEvents(year, month + 1, i),
lastDay
);
const {date, day} = options;
const copyRangeBegin = this.rangeBegin.concat();
const copyRangeEnd = this.rangeEnd.concat();
copyRangeBegin[1] += 1;
copyRangeEnd[1] += 1;
if (weekSwitch || isMonthModeCurrentMonth) {
(copyRangeEnd.join('-') === date) && (options.rangeClassName = 'mc-range-end');
(copyRangeBegin.join('-') === date) && (options.rangeClassName = 'mc-range-begin');
}
if (year === copyRangeEnd[0] && (month + 1) === copyRangeEnd[1] && day === (copyRangeEnd[2] - 1)) {
options.rangeClassName = options.rangeClassName ? ['mc-range-begin', 'mc-range-second-to-last'] : 'mc-range-second-to-last';
}
if (this.rangeBegin.length) {
const beginTime = +new Date(this.rangeBegin[0], this.rangeBegin[1], this.rangeBegin[2]);
const endTime = +new Date(this.rangeEnd[0], this.rangeEnd[1], this.rangeEnd[2]);
const stepTime = +new Date(year, month, i);
if (beginTime <= stepTime && endTime >= stepTime) {
options.selected = true;
}
}
if (this.begin.length) {
const beginTime = +new Date(parseInt(this.begin[0], 10), parseInt(this.begin[1], 10) - 1, parseInt(this.begin[2], 10));
if (beginTime > +new Date(year, month, i)) {
options.disabled = true;
}
}
if (this.end.length) {
const endTime = Number(new Date(parseInt(this.end[0], 10), parseInt(this.end[1], 10) - 1, parseInt(this.end[2], 10)));
if (endTime < Number(new Date(year, month, i))) {
options.disabled = true;
}
}
if (playload && !weekSwitch) {
options.disabled = true;
} else if (this.disabled.length && disabledFilter(this.disabled)) {
options.disabled = true;
}
const monthFirstDay = `${year}-${month + 1}-1`;
const monthLastDay = `${year}-${month + 1}-${new Date(year, month + 1, 0).getDate()}`;
(monthFirstDay === date && options.selected && !options.rangeClassName) && (options.rangeClassName = 'mc-range-month-first');
(monthLastDay === date && options.selected && !options.rangeClassName) && (options.rangeClassName = 'mc-range-month-last');
this.isCurrentMonthToday(options) && (options.isToday = true);
(!weekSwitch && playload) && (options.selected = false);
return options;
}
if (this.multi) {
let options;
if (this.value.find(v => year === v[0] && (month === v[1] - 1) && i === v[2])) {
options = Object.assign(
{day: i, selected: true},
this.getLunarInfo(year, month + 1, i),
this.getEvents(year, month + 1, i)
);
} else {
options = Object.assign(
{day: i, selected: false},
this.getLunarInfo(year, month + 1, i),
this.getEvents(year, month + 1, i)
);
if (this.begin.length) {
const beginTime = +new Date(parseInt(this.begin[0], 10), parseInt(this.begin[1], 10) - 1, parseInt(this.begin[2], 10));
if (beginTime > +(new Date(year, month, i))) {
options.disabled = true;
}
}
if (this.end.length) {
const endTime = +new Date(parseInt(this.end[0], 10), parseInt(this.end[1], 10) - 1, parseInt(this.end[2], 10));
if (endTime < +(new Date(year, month, i))) {
options.disabled = true;
}
}
if (this.disabled.length && disabledFilter(this.disabled)) {
options.disabled = true;
}
}
this.isCurrentMonthToday(options) && (options.isToday = true);
if (playload && !weekSwitch) {
options.disabled = true;
options.selected = false;
}
return options;
} else {
const options = {};
const monthHuman = month + 1;
if (selectSplit[0] === year && selectSplit[1] === monthHuman && selectSplit[2] === i) {
Object.assign(
options,
{day: i, selected: true},
this.getLunarInfo(year, monthHuman, i),
this.getEvents(year, monthHuman, i)
);
} else {
Object.assign(
options,
{day: i, selected: false},
this.getLunarInfo(year, monthHuman, i),
this.getEvents(year, monthHuman, i)
);
if (this.begin.length) {
const beginTime = +new Date(parseInt(this.begin[0], 10), parseInt(this.begin[1], 10) - 1, parseInt(this.begin[2], 10));
if (beginTime > Number(new Date(year, month, i))) {
options.disabled = true;
}
}
if (this.end.length) {
const endTime = +new Date(parseInt(this.end[0], 10), parseInt(this.end[1], 10) - 1, parseInt(this.end[2], 10));
if (endTime < +(new Date(year, month, i))) {
options.disabled = true;
}
}
if (this.disabled.length && disabledFilter(this.disabled)) {
options.disabled = true;
}
}
this.isCurrentMonthToday(options) && (options.isToday = true);
if (playload && !weekSwitch) {
options.disabled = true;
options.selected = false;
}
return options;
}
},
isCurrentMonthToday(options) {
const isToday = todayString === options.date;
if (!isToday) return false;
return this.weekSwitch ? isToday : (Number(todayString.split('-')[1]) === this.month + 1);
},
watchRender(type) {
const {weekSwitch} = this;
const daysDeepCopy = JSON.parse(JSON.stringify(this.monthDays));
if (type === 'events') {
const events = this.events || {};
Object.keys(events).forEach(value => {
daysDeepCopy.some(v => v.some(vv => {
if (vv.date === value) {
vv.eventName = events[value];
return true;
}
}));
});
} else if (type === 'disabled') {
const disabled = this.disabled || [];
disabled.forEach(value => {
daysDeepCopy.some(v => v.some(vv => {
if (vv.date === value) {
vv.disabled = true;
return true;
}
}));
});
} else if (type === 'almanacs') {
const almanacs = this.almanacs || {};
Object.keys(almanacs).forEach(value => {
daysDeepCopy.some(v => v.some(vv => {
if (vv.date.slice(5, 20) === value) {
const [y, m, d] = vv.date.split('-');
Object.assign(vv, this.getLunarInfo(y, m, d));
return true;
}
}));
});
} else if (type === 'tileContent') {
const tileContent = this.tileContent || [];
tileContent.forEach(value => {
daysDeepCopy.some(v => v.some(vv => {
if (vv.date === value.date) {
vv.className = value.className;
vv.content = value.content;
return true;
}
}));
});
}
this.monthDays = daysDeepCopy;
if (weekSwitch) {
this.days = [daysDeepCopy[this.weekIndex]];
this.monthRangeDays = [this.days];
} else {
this.days = daysDeepCopy;
this.monthRangeDays = [this.days];
}
},
render(y, m, renderer, payload) {
const {weekSwitch} = this;
const isCustomRender = renderer === 'CUSTOMRENDER';
const isWatchRenderValue = renderer === '_WATCHRENDERVALUE_';
this.year = y;
this.month = m;
if (renderer === '_WATCHRENDER_') return this.watchRender(payload);
if (this.range && isWatchRenderValue) {
if (!Array.isArray((this.value || [])[0])) {
this.rangeBegin = [];
this.rangeEnd = [];
} else {
this.rangeBegin = [this.value[0][0], this.value[0][1] - 1, this.value[0][2]];
this.rangeEnd = [this.value[1][0], this.value[1][1] - 1, this.value[1][2]];
}
}
if (isWatchRenderValue && weekSwitch) {
this.positionWeek = true;
}
if (isCustomRender) {
this.year = y;
this.month = m;
this.positionWeek = true;
if (weekSwitch && !payload) {
this.startWeekIndex = 0;
this.weekIndex = 0;
}
this.updateHeadMonth();
}
const firstDayOfMonth = new Date(y, m, 1).getDay();
const lastDateOfMonth = new Date(y, m + 1, 0).getDate();
const lastDayOfLastMonth = new Date(y, m, 0).getDate();
this.year = y;
let i = 1;
let line = 0;
let nextMonthPushDays = 1;
const temp = [];
for (i; i <= lastDateOfMonth; i++) {
const day = new Date(y, m, i).getDay();
let k;
if (day === 0) {
temp[line] = [];
} else if (i === 1) {
temp[line] = [];
k = lastDayOfLastMonth - firstDayOfMonth + 1;
for (let j = 0; j < firstDayOfMonth; j++) { //generate prev month surplus option
temp[line].push(Object.assign(
this.renderOption(this.computedPrevYear(y, m), this.computedPrevMonth(false, m), k, 'prevMonth'),
{lastMonth: true}
));
k++;
}
}
temp[line].push(this.renderOption(y, m, i)); //generate current month option
if (day === 6 && i < lastDateOfMonth) {
line++;
} else if (i === lastDateOfMonth) {
let nextDay = 1;
const lastDateOfMonthLength = this.monFirst ? 7 : 6;
for (let d = day; d < lastDateOfMonthLength; d++) { //generate next month surplus option
temp[line].push(Object.assign(
this.renderOption(this.computedNextYear(y, m), this.computedNextMonth(false, m), nextDay, 'nextMonth'),
{nextMonth: true}
));
nextDay++;
}
nextMonthPushDays = nextDay;
}
}
const {completion} = this;
if (this.monFirst) {
if (!firstDayOfMonth) {
let lastMonthDay = lastDayOfLastMonth;
const LastMonthItems = [];
for (let d = 1; d <= 7; d++) {
LastMonthItems.unshift(Object.assign(
this.renderOption(this.computedPrevYear(y, m), this.computedPrevMonth(false, m), lastMonthDay, 'prevMonth'),
{lastMonth: true}
));
lastMonthDay--;
}
temp.unshift(LastMonthItems);
}
temp.forEach((item, index) => {
if (!index) {
return item.splice(0, 1);
}
temp[index - 1].length < 7 && temp[index - 1].push(item.splice(0, 1)[0]);
});
if (this.isMonthRange && temp[temp.length - 1][0].nextMonth) {
temp.splice(temp.length - 1, 1); //if the first day of last line is nextMonth, delete this line
}
if (!completion && !weekSwitch) {
const lastIndex = temp.length - 1;
const secondToLastIndex = lastIndex - 1;
const differentMonth = temp[lastIndex][0].date.split('-')[1] !== temp[secondToLastIndex][6].date.split('-')[1];
differentMonth && temp.splice(lastIndex, 1);
}
}
if (completion && !weekSwitch && temp.length <= 5 && nextMonthPushDays > 0) {
for (let completionIndex = temp.length; completionIndex <= 5; completionIndex++) {
temp[completionIndex] = [];
const start = nextMonthPushDays + (completionIndex - line - 1) * 7;
for (let d = start; d <= start + 6; d++) {
temp[completionIndex].push(Object.assign(
{day: d, disabled: true, nextMonth: true},
this.getLunarInfo(this.computedNextYear(y, m), this.computedNextMonth(true, m), d),
this.getEvents(this.computedNextYear(y, m), this.computedNextMonth(true, m), d)
));
}
}
}
if (this.tileContent.length) {
temp.forEach((item, index) => {
item.forEach(v => {
const contents = this.tileContent.find(val => val.date === v.date);
if (contents) {
const {className, content} = contents || {};
v.className = className;
v.content = content;
}
});
});
}
if (weekSwitch) {
const tempLength = temp.length;
const lastLineMonth = temp[tempLength - 1][0].date.split('-')[1]; // last line month
const secondLastMonth = temp[tempLength - 2][0].date.split('-')[1]; // second-to-last line month
lastLineMonth !== secondLastMonth && temp.splice(tempLength - 1, 1);
}
this.monthDays = temp;
if (weekSwitch && !this.isMonthRange) {
if (this.positionWeek) {
let payloadDay = '';
let searchIndex = true;
if (Array.isArray(payload)) { //range
payloadDay = [payload[0], payload[1] + 1, payload[2]].join('-');
} else if (this.multi || isWatchRenderValue) {
if (this.thisTimeSelect) {
payloadDay = this.thisTimeSelect;
} else {
payloadDay = this.multi ? this.value[this.value.length - 1].join('-') : this.value.join('-');
}
}
if (payload === 'SETTODAY') {
payloadDay = todayString;
} else if (isCustomRender) {
if (typeof payload === 'string') {
payloadDay = [y, Number(m) + 1, payload].join('-');
searchIndex = true;
} else if (typeof payload === 'number') {
const setIndex = payload > temp.length ? temp.length - 1 : payload;
this.startWeekIndex = setIndex;
this.weekIndex = setIndex;
this.positionWeek = false;
searchIndex = false;
}
}
const positionDay = payloadDay || todayString;
if (searchIndex) {
temp.some((v, index) => {
const isWeekNow = v.find(vv => vv.date === positionDay);
if (isWeekNow) {
this.startWeekIndex = index;
this.weekIndex = index;
return true;
}
});
}
this.positionWeek = false;
}
this.days = [temp[this.startWeekIndex]];
if (this.initRender) {
this.setMonthRangeofWeekSwitch();
this.initRender = false;
}
} else {
this.days = temp;
}
const todayText = '今';
if (typeof this.now === 'boolean' && !this.now) {
this.showToday = {show: false};
} else if (typeof this.now === 'string') {
this.showToday = {
show: true,
text: this.now || todayText
};
} else {
this.showToday = {
show: true,
text: todayText
};
}
this.monthRangeDays = [this.days];
isWatchRenderValue && this.updateHeadMonth();
return this.days;
},
rendeRange(renderer) {
const range = [];
const self = this;
const monthRange = this.monthRange;
function formatDateText(fYear, fMonth) {
const reg = /([y]+)(.*?)([M]+)(.*?)$/i;
const rangeMonthFormat = self.rangeMonthFormat || 'yyyy-MM';
reg.exec(rangeMonthFormat);
return String(fYear).substring(4 - RegExp.$1.length) + RegExp.$2 + String(fMonth).substring(2 - RegExp.$3.length) + RegExp.$4;
}
if (monthRange[0] === monthRange[1]) {
const [y, m] = monthRange[0].split('-');
range.push([Number(y), Number(m), formatDateText(y, m)]);
} else {
const monthRangeOfStart = monthRange[0].split('-');
const monthRangeOfEnd = monthRange[1].split('-');
let startYear = +monthRangeOfStart[0];
let startMonth = +monthRangeOfStart[1];
const endYear = +monthRangeOfEnd[0];
const endtMonth = +monthRangeOfEnd[1] > 12 ? 12 : +monthRangeOfEnd[1];
while (startYear < endYear || startMonth <= endtMonth) {
range.push([startYear, startMonth, formatDateText(startYear, startMonth)]);
if (startMonth === 12 && startYear !== endYear) {
startYear++;
startMonth = 0;
}
startMonth++;
}
}
this.rangeOfMonths = range;
const monthsRange = range.map(item => {
const [yearParam, monthParam] = item;
return this.render(yearParam, monthParam - 1, renderer);
});
this.monthRangeDays = monthsRange;
},
isRendeRangeMode(renderer) {
this.isMonthRange = !!this.monthRange.length;
if (this.isMonthRange) {
this.rendeRange(renderer);
return true;
}
},
renderer(y, m, w) {
const renderY = y || this.year;
const renderM = typeof parseInt(m, 10) === 'number' ? (m - 1) : this.month;
this.initRender = true;
this.render(renderY, renderM, 'CUSTOMRENDER', w);
!this.weekSwitch && (this.monthsLoop = this.monthsLoopCopy.concat());
},
computedPrevYear(year, month) {
let value = year;
if ((month - 1) < 0) {
value--;
}
return value;
},
computedPrevMonth(isString, month) {
let value = month;
if ((month - 1) < 0) {
value = 11;
} else {
value--;
}
if (isString) {
return value + 1;
}
return value;
},
computedNextYear(year, month) {
let value = year;
if ((month + 1) > 11) {
value++;
}
return value;
},
computedNextMonth(isString, month) {
let value = month;
if ((month + 1) > 11) {
value = 0;
} else {
value++;
}
if (isString) {
return value + 1;
}
return value;
},
getLunarInfo(y, m, d) {
const lunarInfo = calendar.solar2lunar(y, m, d);
const {Term, lMonth, lDay, lYear} = lunarInfo || {};
let yearEve = '';
if (lMonth === 12 && lDay === calendar.monthDays(lYear, 12)) {
yearEve = '除夕';
}
let lunarValue = lunarInfo.IDayCn;
let isLunarFestival = false;
let isGregorianFestival = false;
if (this.festival.lunar[`${lunarInfo.lMonth}-${lunarInfo.lDay}`]) {
lunarValue = this.festival.lunar[`${lunarInfo.lMonth}-${lunarInfo.lDay}`];
isLunarFestival = true;
} else if (this.festival.gregorian[`${m}-${d}`]) {
lunarValue = this.festival.gregorian[`${m}-${d}`];
isGregorianFestival = true;
}
const lunarInfoObj = {
date: `${y}-${m}-${d}`,
lunar: yearEve || Term || lunarValue,
isLunarFestival,
isGregorianFestival,
isTerm: !!yearEve || lunarInfo.isTerm
};
if (Object.keys(this.almanacs).length) {
Object.assign(lunarInfoObj, {
almanac: this.almanacs[`${m}-${d}`] || '',
isAlmanac: !!this.almanacs[`${m}-${d}`]
});
}
return lunarInfoObj;
},
getEvents(y, m, d) {
if (!Object.keys(this.events).length) return;
const eventName = this.events[`${y}-${m}-${d}`];
const data = {};
if (eventName) {
data.eventName = eventName;
}
return data;
},
prev(e) {
e && e.stopPropagation();
if (this.isMonthRange) return;
const weekSwitch = this.weekSwitch;
const changeMonth = (changed) => {
if (this.monthIndex === 1) {
this.oversliding = false;
this.month = 11;
this.year = parseInt(this.year, 10) - 1;
this.monthIndex = this.monthIndex - 1;
} else if (this.monthIndex === 0) {
this.oversliding = true;
this.monthIndex = 12;
setTimeout(() => this.prev(e), 50);
return this.updateHeadMonth('custom');
} else if (this.monthIndex === 13) {
this.month = 11;
this.year = parseInt(this.year, 10) - 1;
this.monthIndex = this.monthIndex - 1;
} else {
this.oversliding = false;
this.month = parseInt(this.month, 10) - 1;
this.monthIndex = this.monthIndex - 1;
}
this.updateHeadMonth('custom');
this.render(this.year, this.month);
(typeof changed === 'function') && changed();
const weekIndex = weekSwitch ? this.weekIndex : undefined;
this.$emit('prev', this.year, this.month + 1, weekIndex);
};
if (!this.weekSwitch) return changeMonth();
const changeWeek = () => {
this.weekIndex = this.weekIndex - 1;
this.days = [this.monthDays[this.weekIndex]];
this.monthRangeDays = [this.days];
this.setMonthRangeofWeekSwitch();
this.$emit('prev', this.year, this.month + 1, this.weekIndex);
};
const currentWeek = (this.days[0] || [])[0] || {};
if (currentWeek.lastMonth || currentWeek.day === 1) {
const monthChenged = () => {
const lastMonthLength = this.monthDays.length;
const startWeekIndex = currentWeek.lastMonth ? lastMonthLength - 1 : lastMonthLength;
this.startWeekIndex = startWeekIndex;
this.weekIndex = startWeekIndex;
changeWeek();
};
changeMonth(monthChenged);
} else {
changeWeek();
}
},
next(e) {
e && e.stopPropagation();
if (this.isMonthRange) return;
const weekSwitch = this.weekSwitch;
const changeMonth = () => {
if (this.monthIndex === 12) {
this.oversliding = false;
this.month = 0;
this.year = parseInt(this.year, 10) + 1;
this.monthIndex = this.monthIndex + 1;
} else if (this.monthIndex === 0 && this.month === 11) {
this.oversliding = false;
this.month = 0;
this.year = parseInt(this.year, 10) + 1;
this.monthIndex = this.monthIndex + 1;
} else if (this.monthIndex === 13) {
this.oversliding = true;
this.monthIndex = 1;
setTimeout(() => this.next(e), 50);
return this.updateHeadMonth('custom');
} else {
this.oversliding = false;
this.month = parseInt(this.month, 10) + 1;
this.monthIndex = this.monthIndex + 1;
}
this.updateHeadMonth('custom');
this.render(this.year, this.month);
const weekIndex = weekSwitch ? this.weekIndex : undefined;
this.$emit('next', this.year, this.month + 1, weekIndex);
};
if (!this.weekSwitch) return changeMonth();
const changeWeek = () => {
this.weekIndex = this.weekIndex + 1;
this.days = [this.monthDays[this.weekIndex]];
this.monthRangeDays = [this.days];
this.setMonthRangeofWeekSwitch();
this.$emit('next', this.year, this.month + 1, this.weekIndex);
};
const currentWeek = (this.days[0] || [])[6] || {};
if (currentWeek.nextMonth || currentWeek.day === (new Date(this.year, this.month + 1, 0).getDate())) {
const startWeekIndex = currentWeek.nextMonth ? 1 : 0;
this.startWeekIndex = startWeekIndex;
this.weekIndex = startWeekIndex;
changeMonth();
} else {
changeWeek();
}
},
select(k1, k2, data, e, monthIndex) {
e && e.stopPropagation();
const weekSwitch = this.weekSwitch;
if (data.lastMonth && !weekSwitch) {
return this.prev(e);
}
if (data.nextMonth && !weekSwitch) {
return this.next(e);
}
if (data.disabled) return;
(data || {}).event = (this.events || {})[data.date] || '';
const {selected, day, date} = data;
const selectedDates = date.split('-');
const selectYear = Number(selectedDates[0]);
const selectMonth = selectedDates[1] - 1;
const selectMonthHuman = Number(selectedDates[1]);
const selectDay = Number(selectedDates[2]);
if (this.range) {
this.isUserSelect = true;
const rangeDate = (dateArray) => dateArray.map((v, k) => {
const value = k === 1 ? v + 1 : v;
return this.zero ? this.zeroPad(value) : value;
});
if (this.rangeBegin.length === 0 || this.rangeEndTemp !== 0) {
this.rangeBegin = [selectYear, selectMonth, selectDay];
this.rangeBeginTemp = this.rangeBegin;
this.rangeEnd = [selectYear, selectMonth, selectDay];
this.thisTimeSelect = this.rangeEnd;
this.rangeEndTemp = 0;
this.$emit('select', rangeDate(this.rangeBegin), undefined);
} else {
this.rangeEnd = [selectYear, selectMonth, selectDay];
this.thisTimeSelect = [selectYear, selectMonth, selectDay];
if (this.rangeBegin.join('-') === this.rangeEnd.join('-')) {
return this.rangeEndTemp = 0;
}
this.rangeEndTemp = 1;
if (+new Date(this.rangeEnd[0], this.rangeEnd[1], this.rangeEnd[2]) < +new Date(this.rangeBegin[0], this.rangeBegin[1], this.rangeBegin[2])) {
this.rangeBegin = this.rangeEnd;
this.rangeEnd = this.rangeBeginTemp;
}
const begin = rangeDate(this.rangeBegin);
const end = rangeDate(this.rangeEnd);
this.value.splice(0, 1, begin);
this.value.splice(1, 1, end);
this.$emit('select', begin, end);
}
this.rangeBgHide = !this.rangeEndTemp || (this.rangeBegin.join('-') === this.rangeEnd.join('-'));
this.positionWeek = true;
if (this.isMonthRange) {
this.rendeRange();
} else {
this.render(this.year, this.month, undefined, this.thisTimeSelect);
}
} else if (this.multi) {
this.isUserSelect = true;
const filterDayIndex = this.value.findIndex(v => v.join('-') === date);
if (~filterDayIndex) {
this.handleMultiDay = this.value.splice(filterDayIndex, 1);
} else {
this.value.push([Number(Number(selectedDates[0])), Number(selectedDates[1]), day]);
}
this.monthRangeDays[monthIndex][k1][k2].selected = !selected;
this.multiDaysData = this.value.map(dateItem => {
const [year, month, d] = dateItem;
return Object.assign(
{day: d, selected: true},
this.getLunarInfo(year, month, d),
this.getEvents(year, month, d)
);
});
this.thisTimeSelect = date;
this.$emit('select', this.value, this.multiDaysData);
} else {
const valueClone = this.value.splice();
const currentSelected = valueClone.join('-');
this.monthRangeDays.some(value => value.some(v => !!v.find(vv => {
if (vv.date === currentSelected) {
vv.selected = false;
return true;
}
})));
this.monthRangeDays[monthIndex][k1][k2].selected = true;
this.day = day;
const selectDate = [selectYear, selectMonthHuman, selectDay];
this.value[0] = selectYear;
this.value[1] = selectMonthHuman;
this.value[2] = selectDay;
this.today = [k1, k2];
this.$emit('select', selectDate, data);
}
},
changeYear() {
if (this.yearsShow) {
this.yearsShow = false;
return false;
}
this.yearsShow = true;
this.years = [];
for (let i = this.year - 5; i < this.year + 7; i++) {
this.years.push(i);
}
},
changeMonth(value) {
this.oversliding && (this.oversliding = false);
this.yearsShow = false;
this.month = value;
this.render(this.year, this.month, 'CUSTOMRENDER', 0);
this.updateHeadMonth();
this.weekSwitch && this.setMonthRangeofWeekSwitch();
this.$emit('selectMonth', this.month + 1, this.year);
},
selectYear(value) {
this.yearsShow = false;
this.year = value;
this.render(this.year, this.month);
this.$emit('selectYear', value);
},
setToday() {
const now = new Date();
this.year = now.getFullYear();
this.month = now.getMonth();
this.day = now.getDate();
this.positionWeek = true;
this.render(this.year, this.month, undefined, 'SETTODAY');
this.updateHeadMonth();
},
setMonthRangeofWeekSwitch() {
this.monthsLoop = this.monthsLoopCopy.concat();
this.days[0].reduce((prev, current) => {
if (!prev) return;
const prveDate = ((prev || {}).date || '').split('-');
const prevYear = prveDate[0];
const prevMonth = prveDate[1];
const currentMonth = ((current || {}).date || '').split('-')[1];
if (prevMonth === currentMonth) {
return current;
}
const prevMonthText = this.months[prevMonth - 1];
const currentMonthText = this.months[currentMonth - 1];
this.monthsLoop[this.monthIndex] = `${prevMonthText}~${currentMonthText}`;
});
},
dateInfo(y, m, d) {
return calendar.solar2lunar(y, m, d);
},
zeroPad(n) {
return String(n < 10 ? `0${n}` : n);
},
updateHeadMonth(type) {
if (!type) this.monthIndex = this.month + 1;
this.monthPosition = this.monthIndex * this.positionH;
this.monthText = this.months[this.month];
},
addResponsiveListener() {
window.addEventListener('resize', this.resize);
},
resize() {
const calendarRef = this.$refs.calendar;
this.itemWidth = (calendarRef.clientWidth/7 - 4).toFixed(5);
}
}
};
</script>
\ No newline at end of file
.mpvue-calendar {
margin:auto;
width: 100%;
min-width:350px;
background: #fff;
user-select:none;
position: relative;
}
.calendar-tools{
height:40px;
font-size: 20px;
line-height: 40px;
color:#5e7a88;
box-shadow: 0px 4px 8px rgba(25, 47, 89, 0.1);
margin-bottom: 20px;
border-top: 1px solid rgba(200, 200, 200, .1);
}
.calendar-tools span{
cursor: pointer;
}
.calendar-prev{
width: 14.28571429%;
float:left;
text-align: center;
}
.calendar-prev img, .calendar-next img{
width: 34px;
height: 34px;
}
.calendar-info{
font-size:16px;
line-height: 1.3;
text-align: center;
width: 220px;
margin: 0 auto;
}
.calendar-info>div.mc-month{
margin:auto;
height:24px;
width:100px;
text-align: center;
color:#5e7a88;
overflow: hidden;
position: relative;
}
.calendar-info>div.mc-month .mc-month-inner{
position: absolute;
left:0;
top:0;
height:480px;
}
.month-transition{
transition:top .5s cubic-bezier(0.075, 0.82, 0.165, 1);
}
.calendar-info .mc-month-text{
display:block;
font-size:28px;
height:40px;
width:200px;
overflow:hidden;
text-align:center;
}
.calendar-info>div.mc-month .mc-month-inner>span{
display: block;
font-size: 14px;
height:24px;
line-height:24px;
width:100px;
overflow: hidden;
text-align: center;
}
.calendar-info>div.mc-year{
font-size:10px;
line-height: 1;
color:#999;
}
.calendar-next{
width: 14.28571429%;
float:right;
text-align: center;
}
.mpvue-calendar table {
clear: both;
width: 100%;
margin-bottom:10px;
border-collapse: collapse;
color: #444444;
}
.mpvue-calendar td {
margin:2px !important;
padding: 4px;
width: 14.28571429%;
box-sizing: border-box;
text-align: center;
vertical-align: middle;
font-size:14px;
cursor: pointer;
position: relative;
vertical-align: top;
}
.mpvue-calendar td.mc-week{
font-size:10px;
pointer-events:none !important;
cursor: default !important;
}
.mpvue-calendar td.disabled {
color: #ccc;
}
.mpvue-calendar td.disabled div{
color: #ccc;
}
.mpvue-calendar td span{
display:block;
height:100%;
width:100%;
margin:0px auto;
border-radius:50%;
position: relative;
z-index: 3;
}
.mpvue-calendar td:not(.disabled) span.mc-date-red{
color:#ea6151;
}
.mc-today{
color: #3b75fb;
}
.mpvue-calendar td.selected span{
background-color: #3b75fb;
color: #fff;
border-radius: 50%;
}
.mpvue-calendar td .mc-text{
box-sizing: border-box;
height: 0.7em;
overflow: hidden;
text-overflow:ellipsis;
white-space: nowrap;
position: absolute;
bottom: 0px;
left: 0;
right: 0;
text-align: center;
font-size: 0.7em;
line-height: 0.7em;
z-index: 4;
}
.mpvue-calendar td .isGregorianFestival,
.mpvue-calendar td .isTerm,
.mpvue-calendar td .isLunarFestival{
color:#ea6151;
}
.mpvue-calendar td.selected span.mc-date-red{
background-color: #3b75fb;
color: #fff;
}
.selected .mc-text {
color: #fff !important;
}
.mpvue-calendar .lunarStyle .mc-text{
overflow: visible;
bottom: 20%;
}
.mpvue-calendar thead td {
text-transform: uppercase;
height:30px;
vertical-align: middle;
}
.mc-head {
margin-bottom: 10px;
}
.mc-head div {
overflow: hidden;
}
.mc-head-box div {
flex:1;
text-align: center;
font-size: 18px;
}
.mc-head-box {
display: flex;
flex-direction: row;
justify-content: center;
align-content: space-between
}
.mc-body {
padding-bottom: 20px;
}
.mc-body tr {
display: flex;
flex-direction: row;
justify-content: center;
align-content: space-between;
}
.mc-dot {
width: 8px;
height: 8px;
background-color: #ea6151;
border-radius: 50%;
position: absolute;
bottom: -4px;
left: 50%;
margin-left: -4px;
z-index: 5;
}
.remark-text {
box-sizing: border-box;
height: 0.7em;
overflow: hidden;
text-overflow:ellipsis;
white-space: nowrap;
position: absolute;
bottom: 0px;
left: 0;
right: 0;
text-align: center;
font-size: 0.7em;
line-height: 0.7em;
z-index: 5;
}
.slot-element{
line-height: normal;
position: absolute;
z-index: 5;
}
.mpvue-calendar-change{
position: absolute;
left:0px;
top:42px;
right:0px;
bottom:0px;
background:#fff;
display: flex;
justify-content: center;
align-items: center;
flex-wrap:wrap;
overflow: auto;
transition:all .5s cubic-bezier(0.075, 0.82, 0.165, 1);
opacity: 0;
pointer-events: none;
transform: translateY(-10px);
z-index: 9;
}
.mpvue-calendar-change.show{
opacity: 1;
pointer-events: auto;
transform: translateY(0px);
}
.mpvue-calendar-change span{
margin:4px 2%;
display: inline-block;
line-height: 30px;
border-radius: 20px;
text-align:center;
color:#999;
width: 20%;
float: left;
text-align: center;
border-radius: 40px;
box-sizing: border-box;
margin-bottom: 4%;
cursor: pointer;
}
.mpvue-calendar-change span.active{
background-color: #587dff;
box-shadow: 2px 2px 2px rgba(88, 125, 255, 0.7);
color:#fff;
}
.mpvue-calendar-change .calendar-week-switch-months{
height: 100%;
}
.mpvue-calendar-change .calendar-week-switch-months span {
margin-bottom: 10px;
margin-top: 0px;
}
.calendar-years, .calendar-months{
height: 50%;
width: 100%;
padding: 10px;
box-sizing: border-box;
position: relative;
}
.calendar-years:after {
content: '';
display: block;
width: 86%;
height: 1px;
background-color: #eee;
position: absolute;
bottom: 2%;
left: 7%;
}
/*range background*/
.mc-range-mode .selected .mc-range-bg{
content: '';
display: block;
width: 150%;
height: 100%;
background-color: #01a1ed;
position: relative;
top: -100%;
left: 50%;
}
.mpvue-calendar .mc-range-mode .selected .calendar-date{
background-color: transparent;
}
.mpvue-calendar .mc-range-mode .mc-range-row-last .calendar-date, .mpvue-calendar .mc-range-mode .mc-range-row-first .calendar-date{
border-radius: 4px;
background-color: #01a1ed;
}
.mpvue-calendar .mc-range-mode .mc-range-month-first.selected .calendar-date, .mpvue-calendar .mc-range-mode .mc-range-month-last.selected .calendar-date{
background-color: #01a1ed;
border-radius: 4px;
}
.mc-range-mode .mc-range-month-last .mc-range-bg{
background-color: transparent;
border-radius: 4px;
}
.mc-range-mode .mc-range-end .mc-range-bg, .mc-range-mode .mc-range-row-last .mc-range-bg{
display: none;
}
.mc-range-row-first.mc-range-end .mc-range-bg{
display: block;
margin-left: -50%;
width: 50%;
border-radius: 4px;
}
.mpvue-calendar .mc-range-row-first.mc-range-end.month-first-date .mc-range-bg{
margin-left: 0px;
}
.mc-range-row-last.mc-range-begin .mc-range-bg{
display: block;
width: 50%;
border-radius: 4px;
}
.mpvue-calendar .mc-range-mode .selected.mc-range-second-to-last span{
background-color: #01a1ed;
border-radius: 4px;
}
.mc-range-begin.mc-range-second-to-last{
background-color: #01a1ed;
border-radius: 4px;
}
.mpvue-calendar .mc-range-mode .mc-range-end span.calendar-date, .mpvue-calendar .mc-range-mode .mc-range-begin span.calendar-date{
background-color: #3b75fb;
color: #fff;
border-radius: 50%;
}
.mpvue-calendar .mc-range-mode .month-last-date.mc-range-begin .mc-range-bg{
display: block;
width: 50%;
border-radius: 4px;
}
.mpvue-calendar .mc-range-mode .month-first-date.mc-range-end .mc-range-bg{
display: block;
width: 50%;
border-radius: 4px;
left: 0px;
}
.calendar-wrapper .mpvue-calendar .mc-range-mode .mc-range-select-one div.mc-range-bg{
display: none;
}
.mc-range-mode .mc-range-second-to-last .mc-range-bg{
border-radius: 0px 25% 25% 0px;
}
.mc-today-element .calendar-date{
background-color: rgba(25, 47, 89, 0.1);
border-radius: 4px;
}
/*week switch*/
.mpvue-calendar .mc-range-mode.week-switch .month-last-date.mc-range-begin .mc-range-bg{
width: 150%;
border-radius: 0px 20% 20% 0px;
}
.mpvue-calendar .mc-range-mode.week-switch .mc-range-month-last .mc-range-bg{
background-color: #01a1ed;
border-radius: 0px 20% 20% 0px;
}
/*month range*/
.mpvue-calendar .month-range-mode{
border-bottom: 1px solid #f2f2f2;
position: relative;
}
.mpvue-calendar .mc-month-range-mode-head{
box-shadow: 0 4px 8px rgba(25,47,89,.1);
padding: 8px 0px;
position: sticky;
top: 0px;
background-color: #fff;
z-index: 9;
}
.month-range-mode .month-rang-head {
text-align: left;
margin: 10px 0px;
padding-left: 10px;
}
.month-range-mode .mc-last-month, .month-range-mode .mc-next-month{
opacity: 0 !important;
}
.month-text-background{
position: absolute;
font-size: 140px;
width: 100%;
height: 100%;
text-align: center;
line-height: 2.4;
}
\ No newline at end of file
/* eslint-disable */
/**
* @1900-2100区间内的公历、农历互转
* @charset UTF-8
* @Author Jea杨(JJonline@JJonline.Cn)
* @Time 2014-7-21
* @Time 2016-8-13 Fixed 2033hex、Attribution Annals
* @Time 2016-9-25 Fixed lunar LeapMonth Param Bug
* @Version 1.0.2
* @公历转农历:calendar.solar2lunar(1987,11,01); //[you can ignore params of prefix 0]
* @农历转公历:calendar.lunar2solar(1987,09,10); //[you can ignore params of prefix 0]
*/
var calendar = {
/**
* 农历1900-2100的润大小信息表
* @Array Of Property
* @return Hex
*/
lunarInfo:[0x04bd8,0x04ae0,0x0a570,0x054d5,0x0d260,0x0d950,0x16554,0x056a0,0x09ad0,0x055d2,//1900-1909
0x04ae0,0x0a5b6,0x0a4d0,0x0d250,0x1d255,0x0b540,0x0d6a0,0x0ada2,0x095b0,0x14977,//1910-1919
0x04970,0x0a4b0,0x0b4b5,0x06a50,0x06d40,0x1ab54,0x02b60,0x09570,0x052f2,0x04970,//1920-1929
0x06566,0x0d4a0,0x0ea50,0x06e95,0x05ad0,0x02b60,0x186e3,0x092e0,0x1c8d7,0x0c950,//1930-1939
0x0d4a0,0x1d8a6,0x0b550,0x056a0,0x1a5b4,0x025d0,0x092d0,0x0d2b2,0x0a950,0x0b557,//1940-1949
0x06ca0,0x0b550,0x15355,0x04da0,0x0a5b0,0x14573,0x052b0,0x0a9a8,0x0e950,0x06aa0,//1950-1959
0x0aea6,0x0ab50,0x04b60,0x0aae4,0x0a570,0x05260,0x0f263,0x0d950,0x05b57,0x056a0,//1960-1969
0x096d0,0x04dd5,0x04ad0,0x0a4d0,0x0d4d4,0x0d250,0x0d558,0x0b540,0x0b6a0,0x195a6,//1970-1979
0x095b0,0x049b0,0x0a974,0x0a4b0,0x0b27a,0x06a50,0x06d40,0x0af46,0x0ab60,0x09570,//1980-1989
0x04af5,0x04970,0x064b0,0x074a3,0x0ea50,0x06b58,0x055c0,0x0ab60,0x096d5,0x092e0,//1990-1999
0x0c960,0x0d954,0x0d4a0,0x0da50,0x07552,0x056a0,0x0abb7,0x025d0,0x092d0,0x0cab5,//2000-2009
0x0a950,0x0b4a0,0x0baa4,0x0ad50,0x055d9,0x04ba0,0x0a5b0,0x15176,0x052b0,0x0a930,//2010-2019
0x07954,0x06aa0,0x0ad50,0x05b52,0x04b60,0x0a6e6,0x0a4e0,0x0d260,0x0ea65,0x0d530,//2020-2029
0x05aa0,0x076a3,0x096d0,0x04afb,0x04ad0,0x0a4d0,0x1d0b6,0x0d250,0x0d520,0x0dd45,//2030-2039
0x0b5a0,0x056d0,0x055b2,0x049b0,0x0a577,0x0a4b0,0x0aa50,0x1b255,0x06d20,0x0ada0,//2040-2049
/**Add By JJonline@JJonline.Cn**/
0x14b63,0x09370,0x049f8,0x04970,0x064b0,0x168a6,0x0ea50, 0x06b20,0x1a6c4,0x0aae0,//2050-2059
0x0a2e0,0x0d2e3,0x0c960,0x0d557,0x0d4a0,0x0da50,0x05d55,0x056a0,0x0a6d0,0x055d4,//2060-2069
0x052d0,0x0a9b8,0x0a950,0x0b4a0,0x0b6a6,0x0ad50,0x055a0,0x0aba4,0x0a5b0,0x052b0,//2070-2079
0x0b273,0x06930,0x07337,0x06aa0,0x0ad50,0x14b55,0x04b60,0x0a570,0x054e4,0x0d160,//2080-2089
0x0e968,0x0d520,0x0daa0,0x16aa6,0x056d0,0x04ae0,0x0a9d4,0x0a2d0,0x0d150,0x0f252,//2090-2099
0x0d520],//2100
/**
* 公历每个月份的天数普通表
* @Array Of Property
* @return Number
*/
solarMonth:[31,28,31,30,31,30,31,31,30,31,30,31],
/**
* 天干地支之天干速查表
* @Array Of Property trans["甲","乙","丙","丁","戊","己","庚","辛","壬","癸"]
* @return Cn string
*/
Gan:["\u7532","\u4e59","\u4e19","\u4e01","\u620a","\u5df1","\u5e9a","\u8f9b","\u58ec","\u7678"],
/**
* 天干地支之地支速查表
* @Array Of Property
* @trans["子","丑","寅","卯","辰","巳","午","未","申","酉","戌","亥"]
* @return Cn string
*/
Zhi:["\u5b50","\u4e11","\u5bc5","\u536f","\u8fb0","\u5df3","\u5348","\u672a","\u7533","\u9149","\u620c","\u4ea5"],
/**
* 天干地支之地支速查表<=>生肖
* @Array Of Property
* @trans["鼠","牛","虎","兔","龙","蛇","马","羊","猴","鸡","狗","猪"]
* @return Cn string
*/
Animals:["\u9f20","\u725b","\u864e","\u5154","\u9f99","\u86c7","\u9a6c","\u7f8a","\u7334","\u9e21","\u72d7","\u732a"],
/**
* 24节气速查表
* @Array Of Property
* @trans["小寒","大寒","立春","雨水","惊蛰","春分","清明","谷雨","立夏","小满","芒种","夏至","小暑","大暑","立秋","处暑","白露","秋分","寒露","霜降","立冬","小雪","大雪","冬至"]
* @return Cn string
*/
solarTerm:["\u5c0f\u5bd2","\u5927\u5bd2","\u7acb\u6625","\u96e8\u6c34","\u60ca\u86f0","\u6625\u5206","\u6e05\u660e","\u8c37\u96e8","\u7acb\u590f","\u5c0f\u6ee1","\u8292\u79cd","\u590f\u81f3","\u5c0f\u6691","\u5927\u6691","\u7acb\u79cb","\u5904\u6691","\u767d\u9732","\u79cb\u5206","\u5bd2\u9732","\u971c\u964d","\u7acb\u51ac","\u5c0f\u96ea","\u5927\u96ea","\u51ac\u81f3"],
/**
* 1900-2100各年的24节气日期速查表
* @Array Of Property
* @return 0x string For splice
*/
sTermInfo:['9778397bd097c36b0b6fc9274c91aa','97b6b97bd19801ec9210c965cc920e','97bcf97c3598082c95f8c965cc920f',
'97bd0b06bdb0722c965ce1cfcc920f','b027097bd097c36b0b6fc9274c91aa','97b6b97bd19801ec9210c965cc920e',
'97bcf97c359801ec95f8c965cc920f','97bd0b06bdb0722c965ce1cfcc920f','b027097bd097c36b0b6fc9274c91aa',
'97b6b97bd19801ec9210c965cc920e','97bcf97c359801ec95f8c965cc920f','97bd0b06bdb0722c965ce1cfcc920f',
'b027097bd097c36b0b6fc9274c91aa','9778397bd19801ec9210c965cc920e','97b6b97bd19801ec95f8c965cc920f',
'97bd09801d98082c95f8e1cfcc920f','97bd097bd097c36b0b6fc9210c8dc2','9778397bd197c36c9210c9274c91aa',
'97b6b97bd19801ec95f8c965cc920e','97bd09801d98082c95f8e1cfcc920f','97bd097bd097c36b0b6fc9210c8dc2',
'9778397bd097c36c9210c9274c91aa','97b6b97bd19801ec95f8c965cc920e','97bcf97c3598082c95f8e1cfcc920f',
'97bd097bd097c36b0b6fc9210c8dc2','9778397bd097c36c9210c9274c91aa','97b6b97bd19801ec9210c965cc920e',
'97bcf97c3598082c95f8c965cc920f','97bd097bd097c35b0b6fc920fb0722','9778397bd097c36b0b6fc9274c91aa',
'97b6b97bd19801ec9210c965cc920e','97bcf97c3598082c95f8c965cc920f','97bd097bd097c35b0b6fc920fb0722',
'9778397bd097c36b0b6fc9274c91aa','97b6b97bd19801ec9210c965cc920e','97bcf97c359801ec95f8c965cc920f',
'97bd097bd097c35b0b6fc920fb0722','9778397bd097c36b0b6fc9274c91aa','97b6b97bd19801ec9210c965cc920e',
'97bcf97c359801ec95f8c965cc920f','97bd097bd097c35b0b6fc920fb0722','9778397bd097c36b0b6fc9274c91aa',
'97b6b97bd19801ec9210c965cc920e','97bcf97c359801ec95f8c965cc920f','97bd097bd07f595b0b6fc920fb0722',
'9778397bd097c36b0b6fc9210c8dc2','9778397bd19801ec9210c9274c920e','97b6b97bd19801ec95f8c965cc920f',
'97bd07f5307f595b0b0bc920fb0722','7f0e397bd097c36b0b6fc9210c8dc2','9778397bd097c36c9210c9274c920e',
'97b6b97bd19801ec95f8c965cc920f','97bd07f5307f595b0b0bc920fb0722','7f0e397bd097c36b0b6fc9210c8dc2',
'9778397bd097c36c9210c9274c91aa','97b6b97bd19801ec9210c965cc920e','97bd07f1487f595b0b0bc920fb0722',
'7f0e397bd097c36b0b6fc9210c8dc2','9778397bd097c36b0b6fc9274c91aa','97b6b97bd19801ec9210c965cc920e',
'97bcf7f1487f595b0b0bb0b6fb0722','7f0e397bd097c35b0b6fc920fb0722','9778397bd097c36b0b6fc9274c91aa',
'97b6b97bd19801ec9210c965cc920e','97bcf7f1487f595b0b0bb0b6fb0722','7f0e397bd097c35b0b6fc920fb0722',
'9778397bd097c36b0b6fc9274c91aa','97b6b97bd19801ec9210c965cc920e','97bcf7f1487f531b0b0bb0b6fb0722',
'7f0e397bd097c35b0b6fc920fb0722','9778397bd097c36b0b6fc9274c91aa','97b6b97bd19801ec9210c965cc920e',
'97bcf7f1487f531b0b0bb0b6fb0722','7f0e397bd07f595b0b6fc920fb0722','9778397bd097c36b0b6fc9274c91aa',
'97b6b97bd19801ec9210c9274c920e','97bcf7f0e47f531b0b0bb0b6fb0722','7f0e397bd07f595b0b0bc920fb0722',
'9778397bd097c36b0b6fc9210c91aa','97b6b97bd197c36c9210c9274c920e','97bcf7f0e47f531b0b0bb0b6fb0722',
'7f0e397bd07f595b0b0bc920fb0722','9778397bd097c36b0b6fc9210c8dc2','9778397bd097c36c9210c9274c920e',
'97b6b7f0e47f531b0723b0b6fb0722','7f0e37f5307f595b0b0bc920fb0722','7f0e397bd097c36b0b6fc9210c8dc2',
'9778397bd097c36b0b70c9274c91aa','97b6b7f0e47f531b0723b0b6fb0721','7f0e37f1487f595b0b0bb0b6fb0722',
'7f0e397bd097c35b0b6fc9210c8dc2','9778397bd097c36b0b6fc9274c91aa','97b6b7f0e47f531b0723b0b6fb0721',
'7f0e27f1487f595b0b0bb0b6fb0722','7f0e397bd097c35b0b6fc920fb0722','9778397bd097c36b0b6fc9274c91aa',
'97b6b7f0e47f531b0723b0b6fb0721','7f0e27f1487f531b0b0bb0b6fb0722','7f0e397bd097c35b0b6fc920fb0722',
'9778397bd097c36b0b6fc9274c91aa','97b6b7f0e47f531b0723b0b6fb0721','7f0e27f1487f531b0b0bb0b6fb0722',
'7f0e397bd097c35b0b6fc920fb0722','9778397bd097c36b0b6fc9274c91aa','97b6b7f0e47f531b0723b0b6fb0721',
'7f0e27f1487f531b0b0bb0b6fb0722','7f0e397bd07f595b0b0bc920fb0722','9778397bd097c36b0b6fc9274c91aa',
'97b6b7f0e47f531b0723b0787b0721','7f0e27f0e47f531b0b0bb0b6fb0722','7f0e397bd07f595b0b0bc920fb0722',
'9778397bd097c36b0b6fc9210c91aa','97b6b7f0e47f149b0723b0787b0721','7f0e27f0e47f531b0723b0b6fb0722',
'7f0e397bd07f595b0b0bc920fb0722','9778397bd097c36b0b6fc9210c8dc2','977837f0e37f149b0723b0787b0721',
'7f07e7f0e47f531b0723b0b6fb0722','7f0e37f5307f595b0b0bc920fb0722','7f0e397bd097c35b0b6fc9210c8dc2',
'977837f0e37f14998082b0787b0721','7f07e7f0e47f531b0723b0b6fb0721','7f0e37f1487f595b0b0bb0b6fb0722',
'7f0e397bd097c35b0b6fc9210c8dc2','977837f0e37f14998082b0787b06bd','7f07e7f0e47f531b0723b0b6fb0721',
'7f0e27f1487f531b0b0bb0b6fb0722','7f0e397bd097c35b0b6fc920fb0722','977837f0e37f14998082b0787b06bd',
'7f07e7f0e47f531b0723b0b6fb0721','7f0e27f1487f531b0b0bb0b6fb0722','7f0e397bd097c35b0b6fc920fb0722',
'977837f0e37f14998082b0787b06bd','7f07e7f0e47f531b0723b0b6fb0721','7f0e27f1487f531b0b0bb0b6fb0722',
'7f0e397bd07f595b0b0bc920fb0722','977837f0e37f14998082b0787b06bd','7f07e7f0e47f531b0723b0b6fb0721',
'7f0e27f1487f531b0b0bb0b6fb0722','7f0e397bd07f595b0b0bc920fb0722','977837f0e37f14998082b0787b06bd',
'7f07e7f0e47f149b0723b0787b0721','7f0e27f0e47f531b0b0bb0b6fb0722','7f0e397bd07f595b0b0bc920fb0722',
'977837f0e37f14998082b0723b06bd','7f07e7f0e37f149b0723b0787b0721','7f0e27f0e47f531b0723b0b6fb0722',
'7f0e397bd07f595b0b0bc920fb0722','977837f0e37f14898082b0723b02d5','7ec967f0e37f14998082b0787b0721',
'7f07e7f0e47f531b0723b0b6fb0722','7f0e37f1487f595b0b0bb0b6fb0722','7f0e37f0e37f14898082b0723b02d5',
'7ec967f0e37f14998082b0787b0721','7f07e7f0e47f531b0723b0b6fb0722','7f0e37f1487f531b0b0bb0b6fb0722',
'7f0e37f0e37f14898082b0723b02d5','7ec967f0e37f14998082b0787b06bd','7f07e7f0e47f531b0723b0b6fb0721',
'7f0e37f1487f531b0b0bb0b6fb0722','7f0e37f0e37f14898082b072297c35','7ec967f0e37f14998082b0787b06bd',
'7f07e7f0e47f531b0723b0b6fb0721','7f0e27f1487f531b0b0bb0b6fb0722','7f0e37f0e37f14898082b072297c35',
'7ec967f0e37f14998082b0787b06bd','7f07e7f0e47f531b0723b0b6fb0721','7f0e27f1487f531b0b0bb0b6fb0722',
'7f0e37f0e366aa89801eb072297c35','7ec967f0e37f14998082b0787b06bd','7f07e7f0e47f149b0723b0787b0721',
'7f0e27f1487f531b0b0bb0b6fb0722','7f0e37f0e366aa89801eb072297c35','7ec967f0e37f14998082b0723b06bd',
'7f07e7f0e47f149b0723b0787b0721','7f0e27f0e47f531b0723b0b6fb0722','7f0e37f0e366aa89801eb072297c35',
'7ec967f0e37f14998082b0723b06bd','7f07e7f0e37f14998083b0787b0721','7f0e27f0e47f531b0723b0b6fb0722',
'7f0e37f0e366aa89801eb072297c35','7ec967f0e37f14898082b0723b02d5','7f07e7f0e37f14998082b0787b0721',
'7f07e7f0e47f531b0723b0b6fb0722','7f0e36665b66aa89801e9808297c35','665f67f0e37f14898082b0723b02d5',
'7ec967f0e37f14998082b0787b0721','7f07e7f0e47f531b0723b0b6fb0722','7f0e36665b66a449801e9808297c35',
'665f67f0e37f14898082b0723b02d5','7ec967f0e37f14998082b0787b06bd','7f07e7f0e47f531b0723b0b6fb0721',
'7f0e36665b66a449801e9808297c35','665f67f0e37f14898082b072297c35','7ec967f0e37f14998082b0787b06bd',
'7f07e7f0e47f531b0723b0b6fb0721','7f0e26665b66a449801e9808297c35','665f67f0e37f1489801eb072297c35',
'7ec967f0e37f14998082b0787b06bd','7f07e7f0e47f531b0723b0b6fb0721','7f0e27f1487f531b0b0bb0b6fb0722'],
/**
* 数字转中文速查表
* @Array Of Property
* @trans ['日','一','二','三','四','五','六','七','八','九','十']
* @return Cn string
*/
nStr1:["\u65e5","\u4e00","\u4e8c","\u4e09","\u56db","\u4e94","\u516d","\u4e03","\u516b","\u4e5d","\u5341"],
/**
* 日期转农历称呼速查表
* @Array Of Property
* @trans ['初','十','廿','卅']
* @return Cn string
*/
nStr2:["\u521d","\u5341","\u5eff","\u5345"],
/**
* 月份转农历称呼速查表
* @Array Of Property
* @trans ['正','一','二','三','四','五','六','七','八','九','十','冬','腊']
* @return Cn string
*/
nStr3:["\u6b63","\u4e8c","\u4e09","\u56db","\u4e94","\u516d","\u4e03","\u516b","\u4e5d","\u5341","\u51ac","\u814a"],
/**
* 返回农历y年一整年的总天数
* @param lunar Year
* @return Number
* @eg:var count = calendar.lYearDays(1987) ;//count=387
*/
lYearDays:function(y) {
var i, sum = 348;
for(i=0x8000; i>0x8; i>>=1) { sum += (calendar.lunarInfo[y-1900] & i)? 1: 0; }
return(sum+calendar.leapDays(y));
},
/**
* 返回农历y年闰月是哪个月;若y年没有闰月 则返回0
* @param lunar Year
* @return Number (0-12)
* @eg:var leapMonth = calendar.leapMonth(1987) ;//leapMonth=6
*/
leapMonth:function(y) { //闰字编码 \u95f0
return(calendar.lunarInfo[y-1900] & 0xf);
},
/**
* 返回农历y年闰月的天数 若该年没有闰月则返回0
* @param lunar Year
* @return Number (0、29、30)
* @eg:var leapMonthDay = calendar.leapDays(1987) ;//leapMonthDay=29
*/
leapDays:function(y) {
if(calendar.leapMonth(y)) {
return((calendar.lunarInfo[y-1900] & 0x10000)? 30: 29);
}
return(0);
},
/**
* 返回农历y年m月(非闰月)的总天数,计算m为闰月时的天数请使用leapDays方法
* @param lunar Year
* @return Number (-1、29、30)
* @eg:var MonthDay = calendar.monthDays(1987,9) ;//MonthDay=29
*/
monthDays:function(y,m) {
if(m>12 || m<1) {return -1}//月份参数从1至12,参数错误返回-1
return( (calendar.lunarInfo[y-1900] & (0x10000>>m))? 30: 29 );
},
/**
* 返回公历(!)y年m月的天数
* @param solar Year
* @return Number (-1、28、29、30、31)
* @eg:var solarMonthDay = calendar.leapDays(1987) ;//solarMonthDay=30
*/
solarDays:function(y,m) {
if(m>12 || m<1) {return -1} //若参数错误 返回-1
var ms = m-1;
if(ms==1) { //2月份的闰平规律测算后确认返回28或29
return(((y%4 == 0) && (y%100 != 0) || (y%400 == 0))? 29: 28);
}else {
return(calendar.solarMonth[ms]);
}
},
/**
* 农历年份转换为干支纪年
* @param lYear 农历年的年份数
* @return Cn string
*/
toGanZhiYear:function(lYear) {
var ganKey = (lYear - 3) % 10;
var zhiKey = (lYear - 3) % 12;
if(ganKey == 0) ganKey = 10;//如果余数为0则为最后一个天干
if(zhiKey == 0) zhiKey = 12;//如果余数为0则为最后一个地支
return calendar.Gan[ganKey-1] + calendar.Zhi[zhiKey-1];
},
/**
* 公历月、日判断所属星座
* @param cMonth [description]
* @param cDay [description]
* @return Cn string
*/
toAstro:function(cMonth,cDay) {
var s = "\u9b54\u7faf\u6c34\u74f6\u53cc\u9c7c\u767d\u7f8a\u91d1\u725b\u53cc\u5b50\u5de8\u87f9\u72ee\u5b50\u5904\u5973\u5929\u79e4\u5929\u874e\u5c04\u624b\u9b54\u7faf";
var arr = [20,19,21,21,21,22,23,23,23,23,22,22];
return s.substr(cMonth*2 - (cDay < arr[cMonth-1] ? 2 : 0),2) + "\u5ea7";//座
},
/**
* 传入offset偏移量返回干支
* @param offset 相对甲子的偏移量
* @return Cn string
*/
toGanZhi:function(offset) {
return calendar.Gan[offset%10] + calendar.Zhi[offset%12];
},
/**
* 传入公历(!)y年获得该年第n个节气的公历日期
* @param y公历年(1900-2100);n二十四节气中的第几个节气(1~24);从n=1(小寒)算起
* @return day Number
* @eg:var _24 = calendar.getTerm(1987,3) ;//_24=4;意即1987年2月4日立春
*/
getTerm:function(y,n) {
if(y<1900 || y>2100) {return -1;}
if(n<1 || n>24) {return -1;}
var _table = calendar.sTermInfo[y-1900];
var _info = [
parseInt('0x'+_table.substr(0,5)).toString() ,
parseInt('0x'+_table.substr(5,5)).toString(),
parseInt('0x'+_table.substr(10,5)).toString(),
parseInt('0x'+_table.substr(15,5)).toString(),
parseInt('0x'+_table.substr(20,5)).toString(),
parseInt('0x'+_table.substr(25,5)).toString()
];
var _calday = [
_info[0].substr(0,1),
_info[0].substr(1,2),
_info[0].substr(3,1),
_info[0].substr(4,2),
_info[1].substr(0,1),
_info[1].substr(1,2),
_info[1].substr(3,1),
_info[1].substr(4,2),
_info[2].substr(0,1),
_info[2].substr(1,2),
_info[2].substr(3,1),
_info[2].substr(4,2),
_info[3].substr(0,1),
_info[3].substr(1,2),
_info[3].substr(3,1),
_info[3].substr(4,2),
_info[4].substr(0,1),
_info[4].substr(1,2),
_info[4].substr(3,1),
_info[4].substr(4,2),
_info[5].substr(0,1),
_info[5].substr(1,2),
_info[5].substr(3,1),
_info[5].substr(4,2),
];
return parseInt(_calday[n-1]);
},
/**
* 传入农历数字月份返回汉语通俗表示法
* @param lunar month
* @return Cn string
* @eg:var cnMonth = calendar.toChinaMonth(12) ;//cnMonth='腊月'
*/
toChinaMonth:function(m) { // 月 => \u6708
if(m>12 || m<1) {return -1} //若参数错误 返回-1
var s = calendar.nStr3[m-1];
s+= "\u6708";//加上月字
return s;
},
/**
* 传入农历日期数字返回汉字表示法
* @param lunar day
* @return Cn string
* @eg:var cnDay = calendar.toChinaDay(21) ;//cnMonth='廿一'
*/
toChinaDay:function(d){ //日 => \u65e5
var s;
switch (d) {
case 10:
s = '\u521d\u5341'; break;
case 20:
s = '\u4e8c\u5341'; break;
break;
case 30:
s = '\u4e09\u5341'; break;
break;
default :
s = calendar.nStr2[Math.floor(d/10)];
s += calendar.nStr1[d%10];
}
return(s);
},
/**
* 年份转生肖[!仅能大致转换] => 精确划分生肖分界线是“立春”
* @param y year
* @return Cn string
* @eg:var animal = calendar.getAnimal(1987) ;//animal='兔'
*/
getAnimal: function(y) {
return calendar.Animals[(y - 4) % 12]
},
/**
* 传入阳历年月日获得详细的公历、农历object信息 <=>JSON
* @param y solar year
* @param m solar month
* @param d solar day
* @return JSON object
* @eg:console.log(calendar.solar2lunar(1987,11,01));
*/
solar2lunar:function (y,m,d) { //参数区间1900.1.31~2100.12.31
if(y<1900 || y>2100) {return -1;}//年份限定、上限
if(y==1900&&m==1&&d<31) {return -1;}//下限
if(!y) { //未传参 获得当天
var objDate = new Date();
}else {
var objDate = new Date(y,parseInt(m)-1,d)
}
var i, leap=0, temp=0;
//修正ymd参数
var y = objDate.getFullYear(),m = objDate.getMonth()+1,d = objDate.getDate();
var offset = (Date.UTC(objDate.getFullYear(),objDate.getMonth(),objDate.getDate()) - Date.UTC(1900,0,31))/86400000;
for(i=1900; i<2101 && offset>0; i++) { temp=calendar.lYearDays(i); offset-=temp; }
if(offset<0) { offset+=temp; i--; }
//是否今天
var isTodayObj = new Date(),isToday=false;
if(isTodayObj.getFullYear()==y && isTodayObj.getMonth()+1==m && isTodayObj.getDate()==d) {
isToday = true;
}
//星期几
var nWeek = objDate.getDay(),cWeek = calendar.nStr1[nWeek];
if(nWeek==0) {nWeek =7;}//数字表示周几顺应天朝周一开始的惯例
//农历年
var year = i;
var leap = calendar.leapMonth(i); //闰哪个月
var isLeap = false;
//效验闰月
for(i=1; i<13 && offset>0; i++) {
//闰月
if(leap>0 && i==(leap+1) && isLeap==false){
--i;
isLeap = true; temp = calendar.leapDays(year); //计算农历闰月天数
}
else{
temp = calendar.monthDays(year, i);//计算农历普通月天数
}
//解除闰月
if(isLeap==true && i==(leap+1)) { isLeap = false; }
offset -= temp;
}
if(offset==0 && leap>0 && i==leap+1)
if(isLeap){
isLeap = false;
}else{
isLeap = true; --i;
}
if(offset<0){ offset += temp; --i; }
//农历月
var month = i;
//农历日
var day = offset + 1;
//天干地支处理
var sm = m-1;
var gzY = calendar.toGanZhiYear(year);
//月柱 1900年1月小寒以前为 丙子月(60进制12)
var firstNode = calendar.getTerm(year,(m*2-1));//返回当月「节」为几日开始
var secondNode = calendar.getTerm(year,(m*2));//返回当月「节」为几日开始
//依据12节气修正干支月
var gzM = calendar.toGanZhi((y-1900)*12+m+11);
if(d>=firstNode) {
gzM = calendar.toGanZhi((y-1900)*12+m+12);
}
//传入的日期的节气与否
var isTerm = false;
var Term = null;
if(firstNode==d) {
isTerm = true;
Term = calendar.solarTerm[m*2-2];
}
if(secondNode==d) {
isTerm = true;
Term = calendar.solarTerm[m*2-1];
}
//日柱 当月一日与 1900/1/1 相差天数
var dayCyclical = Date.UTC(y,sm,1,0,0,0,0)/86400000+25567+10;
var gzD = calendar.toGanZhi(dayCyclical+d-1);
//该日期所属的星座
var astro = calendar.toAstro(m,d);
return {'lYear':year,'lMonth':month,'lDay':day,'Animal':calendar.getAnimal(year),'IMonthCn':(isLeap?"\u95f0":'')+calendar.toChinaMonth(month),'IDayCn':calendar.toChinaDay(day),'cYear':y,'cMonth':m,'cDay':d,'gzYear':gzY,'gzMonth':gzM,'gzDay':gzD,'isToday':isToday,'isLeap':isLeap,'nWeek':nWeek,'ncWeek':"\u661f\u671f"+cWeek,'isTerm':isTerm,'Term':Term,'astro':astro};
},
/**
* 传入农历年月日以及传入的月份是否闰月获得详细的公历、农历object信息 <=>JSON
* @param y lunar year
* @param m lunar month
* @param d lunar day
* @param isLeapMonth lunar month is leap or not.[如果是农历闰月第四个参数赋值true即可]
* @return JSON object
* @eg:console.log(calendar.lunar2solar(1987,9,10));
*/
lunar2solar:function(y,m,d,isLeapMonth) { //参数区间1900.1.31~2100.12.1
var isLeapMonth = !!isLeapMonth;
var leapOffset = 0;
var leapMonth = calendar.leapMonth(y);
var leapDay = calendar.leapDays(y);
if(isLeapMonth&&(leapMonth!=m)) {return -1;}//传参要求计算该闰月公历 但该年得出的闰月与传参的月份并不同
if(y==2100&&m==12&&d>1 || y==1900&&m==1&&d<31) {return -1;}//超出了最大极限值
var day = calendar.monthDays(y,m);
var _day = day;
//bugFix 2016-9-25
//if month is leap, _day use leapDays method
if(isLeapMonth) {
_day = calendar.leapDays(y,m);
}
if(y < 1900 || y > 2100 || d > _day) {return -1;}//参数合法性效验
//计算农历的时间差
var offset = 0;
for(var i=1900;i<y;i++) {
offset+=calendar.lYearDays(i);
}
var leap = 0,isAdd= false;
for(var i=1;i<m;i++) {
leap = calendar.leapMonth(y);
if(!isAdd) {//处理闰月
if(leap<=i && leap>0) {
offset+=calendar.leapDays(y);isAdd = true;
}
}
offset+=calendar.monthDays(y,i);
}
//转换闰月农历 需补充该年闰月的前一个月的时差
if(isLeapMonth) {offset+=day;}
//1900年农历正月一日的公历时间为1900年1月30日0时0分0秒(该时间也是本农历的最开始起始点)
var stmap = Date.UTC(1900,1,30,0,0,0);
var calObj = new Date((offset+d-31)*86400000+stmap);
var cY = calObj.getUTCFullYear();
var cM = calObj.getUTCMonth()+1;
var cD = calObj.getUTCDate();
return calendar.solar2lunar(cY,cM,cD);
}
};
export var defaultLunar = {
'1-1': '春节',
'1-15': '元宵节',
'2-2': '龙头节',
'5-5': '端午节',
'7-7': '七夕节',
'7-15': '中元节',
'8-15': '中秋节',
'9-9': '重阳节',
'10-1': '寒衣节',
'10-15': '下元节',
'12-8': '腊八节',
'12-23': '小年',
};
export var defaultGregorian = {
'1-1': '元旦',
'2-14': '情人节',
'3-8': '妇女节',
'3-12': '植树节',
'5-1': '劳动节',
'5-4': '青年节',
'6-1': '儿童节',
'7-1': '建党节',
'8-1': '建军节',
'9-10': '教师节',
'10-1': '国庆节',
'12-24': '平安夜',
'12-25': '圣诞节',
};
export var isBrowser = !!window;
var now = new Date();
export var todayString = [now.getFullYear(), now.getMonth() + 1, now.getDate()].join('-');
export default calendar;
\ No newline at end of file
@font-face {font-family: "iconfont";
src: url('data:font/truetype;charset=utf-8;base64,d09GRgABAAAAAASEAAsAAAAABuwAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAADMAAABCsP6z7U9TLzIAAAE8AAAARAAAAFY7d0f0Y21hcAAAAYAAAABTAAABhmJUzs9nbHlmAAAB1AAAALcAAADIzC0F5mhlYWQAAAKMAAAALwAAADYS7IZUaGhlYQAAArwAAAAcAAAAJAfeA4RobXR4AAAC2AAAAAwAAAAMDAAAAGxvY2EAAALkAAAACAAAAAgANgBkbWF4cAAAAuwAAAAfAAAAIAEOACluYW1lAAADDAAAAUUAAAJtPlT+fXBvc3QAAARUAAAALQAAAEOUPjuMeJxjYGRgYOBikGPQYWB0cfMJYeBgYGGAAJAMY05meiJQDMoDyrGAaQ4gZoOIAgCKIwNPAHicY2BkYWCcwMDKwMHUyXSGgYGhH0IzvmYwYuRgYGBiYGVmwAoC0lxTGByeMj5jYm7438AQw9zA0AAUZgTJAQDdSgvleJztkMERgDAIBPdIzMOxEB8W5MvuTRsRMHbhzSwHR/IBWIDiHE4FXYjQ6akyL6yZ13zT3IXd6jYGfO6S75q7xT81fm1Z9zlZXOsl+j5BD35IDU4AeJwVzUEOwUAYBeD/mfxTEso/mkEJoYluqgtajUjYsHEOSytncROJK/QErjNMd+8lL+8jEP3eqq8uNCPiokK1L4t1ihzVCSPMEekAep3mQCh4tpVm95JWz2QGj3iyiN3LZMJBODU49IMuDxk32YifuI89X4+xqwcsHUtEjfVVWt1p5MvWNs9RY4RowNLrJ7Tq8ZKNN7wmvMp8jBc7PDpW3RPfPrISV5ss4QEO9pxcdrix/gMMIyHOAHicY2BkYGAAYmNBZtV4fpuvDNwsDCBw/dlCBQT9fzMLA3MKkMvBwAQSBQDyNAlAAHicY2BkYGBu+N/AEMPCAAJAkpEBFTADAEcJAmwEAAAABAAAAAQAAAAAAAAAADYAZHicY2BkYGBgZpBlANEMDExAzAWEDAz/wXwGAAuHATgAeJxlj01OwzAQhV/6B6QSqqhgh+QFYgEo/RGrblhUavdddN+mTpsqiSPHrdQDcB6OwAk4AtyAO/BIJ5s2lsffvHljTwDc4Acejt8t95E9XDI7cg0XuBeuU38QbpBfhJto41W4Rf1N2MczpsJtdGF5g9e4YvaEd2EPHXwI13CNT+E69S/hBvlbuIk7/Aq30PHqwj7mXle4jUcv9sdWL5xeqeVBxaHJIpM5v4KZXu+Sha3S6pxrW8QmU4OgX0lTnWlb3VPs10PnIhVZk6oJqzpJjMqt2erQBRvn8lGvF4kehCblWGP+tsYCjnEFhSUOjDFCGGSIyujoO1Vm9K+xQ8Jee1Y9zed0WxTU/3OFAQL0z1xTurLSeTpPgT1fG1J1dCtuy56UNJFezUkSskJe1rZUQuoBNmVXjhF6XNGJPyhnSP8ACVpuyAAAAHicY2BigAAuBuyAmZGJkZmRhYEnKzMxryS/tDgjMS+dC8qpzC9lYAAAiPIJlAAAAA==');
}
.iconfont {
font-family:"iconfont" !important;
font-size:16px;
font-style:normal;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
}
.icon-arrow-right:before { content: "\e602"; }
.icon-arrow-left:before { content: "\e501"; }
\ No newline at end of file
.mpvue-calendar {
margin:auto;
width: 100%;
min-width:300rpx;
background: #fff;
user-select:none;
position: relative;
}
.calendar-tools{
height:40px;
font-size: 20px;
line-height: 40px;
color:#5e7a88;
box-shadow: 0rpx 4rpx 8rpx rgba(25, 47, 89, 0.1);
margin-bottom: 30rpx;
border-top: 1px solid rgba(200, 200, 200, .1);
}
.calendar-prev{
width: 14.28571429%;
float:left;
text-align: center;
}
.calendar-prev img, .calendar-next img{
width: 34rpx;
height: 34rpx;
}
.calendar-info{
padding-top: 3px;
font-size:16px;
line-height: 1.3;
text-align: center;
width: 220rpx;
margin: 0 auto;
}
.calendar-info>div.mc-month{
margin:auto;
height:40rpx;
width:100px;
text-align: center;
color:#5e7a88;
overflow: hidden;
position: relative;
}
.calendar-info>div.mc-month .mc-month-inner{
position: absolute;
left:0;
top:0;
height:480rpx;
}
.month-transition{
transition:top .5s cubic-bezier(0.075, 0.82, 0.165, 1);
}
.calendar-info .mc-month-text{
display:block;
font-size:28rpx;
height:40rpx;
width:200rpx;
overflow:hidden;
text-align:center;
}
.calendar-info>div.mc-month .mc-month-inner>span{
display: block;
font-size: 14px;
height:20px;
width:100px;
overflow: hidden;
text-align: center;
}
.calendar-info>div.mc-year{
font-size:10px;
line-height: 1;
color:#999;
}
.calendar-next{
width: 14.28571429%;
float:right;
text-align: center;
}
.mpvue-calendar table {
clear: both;
width: 100%;
margin-bottom:10px;
border-collapse: collapse;
color: #444444;
}
.mpvue-calendar td {
margin:2px !important;
padding:0px 0;
width: 14.28571429%;
height:88rpx;
text-align: center;
vertical-align: middle;
font-size:14px;
line-height: 125%;
cursor: pointer;
position: relative;
vertical-align: top;
}
.mpvue-calendar td.mc-week{
font-size:10px;
pointer-events:none !important;
cursor: default !important;
}
.mpvue-calendar td.disabled {
color: #ccc;
}
.mpvue-calendar td.disabled div{
color: #ccc;
}
.mpvue-calendar td span{
display:block;
height:76rpx;
width:76rpx;
font-size: 28rpx;
line-height:76rpx;
margin:0px auto;
position: relative;
z-index: 3;
}
.mpvue-calendar td:not(.disabled) span.mc-date-red{
color:#ea6151;
}
.mc-today{
color: #3b75fb;
}
.mpvue-calendar td.selected span{
background-color: #3b75fb;
color: #fff;
border-radius:50%;
}
.mpvue-calendar td .mc-text{
position: absolute;
top:28px;
left:0;
right:0;
text-align: center;
padding:2px;
font-size:20rpx;
line-height: 1.2;
color:#444;
z-index: 4;
}
.mpvue-calendar td .isGregorianFestival,
.mpvue-calendar td .isTerm,
.mpvue-calendar td .isLunarFestival{
color:#ea6151;
}
.mpvue-calendar td.selected span.mc-date-red{
background-color: #3b75fb;
color: #fff;
}
.selected .mc-text {
color: #fff !important;
}
.mpvue-calendar .lunarStyle span{
width: 80rpx;
height: 80rpx;
line-height:54rpx;
}
.mpvue-calendar .lunarStyle .mc-text{
top: 44rpx;
}
.mpvue-calendar thead td {
text-transform: uppercase;
height:30px;
vertical-align: middle;
}
.mc-head {
margin-bottom: 20rpx;
}
.mc-head div {
overflow: hidden;
}
.mc-head-box div {
flex:1;
text-align: center;
}
.mc-head-box {
display: flex;
flex-direction: row;
justify-content: center;
align-content: space-between
}
.mc-head-box div {
font-size: 28rpx;
}
.mc-body tr {
display: flex;
flex-direction: row;
justify-content: center;
align-content: space-between
}
.mc-dot {
width: 10rpx;
height: 10rpx;
background-color: #ea6151;
border-radius: 50%;
margin: 0 auto;
margin-top: 5rpx;
position: absolute;
bottom: -5rpx;
left: 50%;
margin-left: -5rpx;
z-index: 5;
}
.remark-text {
padding-left: 8rpx;
padding-right: 8rpx;
box-sizing: border-box;
height: 34rpx;
overflow: hidden;
text-overflow:ellipsis;
white-space: nowrap;
}
.slot-element{
line-height: normal;
position: absolute;
z-index: 5;
}
.mpvue-calendar-change{
position: absolute;
left:0rpx;
top:85rpx;
right:0rpx;
bottom:0rpx;
background:#fff;
display: flex;
justify-content: center;
align-items: center;
flex-wrap:wrap;
overflow: auto;
transition:all .5s cubic-bezier(0.075, 0.82, 0.165, 1);
opacity: 0;
pointer-events: none;
transform: translateY(-10px);
z-index: 9;
}
.mpvue-calendar-change.show{
opacity: 1;
pointer-events: auto;
transform: translateY(0px);
}
.mpvue-calendar-change span{
margin:4px 2%;
display: inline-block;
line-height: 30px;
border-radius: 20px;
text-align:center;
color:#999;
width: 20%;
float: left;
text-align: center;
border-radius: 40px;
box-sizing: border-box;
margin-bottom: 4%;
}
.mpvue-calendar-change span.active{
background-color: #587dff;
box-shadow: 2px 2px 2px rgba(88, 125, 255, 0.7);
color:#fff;
}
.mpvue-calendar-change .calendar-week-switch-months{
height: 100%;
padding: 10rpx 20rpx;
}
.mpvue-calendar-change .calendar-week-switch-months span {
margin-bottom: 20rpx;
margin-top: 0px;
font-size: 26rpx;
line-height: 40rpx;
}
.calendar-years, .calendar-months{
height: 50%;
width: 100%;
padding: 10px;
box-sizing: border-box;
position: relative;
}
.calendar-years:after {
content: '';
display: block;
width: 86%;
height: 1rpx;
background-color: #eee;
position: absolute;
bottom: 2%;
left: 7%;
}
/*range background*/
.mc-range-mode .selected .mc-range-bg{
content: '';
display: block;
width: 110rpx;
height: 80rpx;
background-color: #01a1ed;
position: absolute;
top: 0rpx;
left: 50%;
}
.mpvue-calendar .mc-range-mode .selected .calendar-date{
background-color: transparent;
}
.mpvue-calendar .mc-range-mode .mc-range-row-last span.calendar-date, .mpvue-calendar .mc-range-mode .mc-range-row-first span.calendar-date{
border-radius: 6rpx;
background-color: #01a1ed;
}
.mpvue-calendar .mc-range-mode .mc-range-month-first.selected .calendar-date, .mpvue-calendar .mc-range-mode .mc-range-month-last.selected .calendar-date{
border-radius: 6rpx;
background-color: #01a1ed;
}
.mc-range-mode .mc-range-month-last .mc-range-bg{
background-color: transparent;
border-radius: 6rpx;
}
.mc-range-mode .mc-range-end .mc-range-bg, .mc-range-mode .mc-range-row-last .mc-range-bg{
display: none;
}
.mpvue-calendar .mc-range-mode .mc-range-end span.calendar-date, .mpvue-calendar .mc-range-mode .mc-range-begin span.calendar-date{
background-color: #3b75fb;
color: #fff;
border-radius: 50%;
}
.mc-range-mode .mc-range-row-first.mc-range-end .mc-range-bg{
display: block;
border-radius: 6rpx;
width: 40rpx;
left: 5px;
}
.mpvue-calendar .mc-range-row-first.mc-range-end.month-first-date .mc-range-bg{
margin-left: 0px;
}
.mc-range-mode .mc-range-row-last.mc-range-begin .mc-range-bg{
display: block;
border-radius: 4rpx;
width: 40rpx;
right: 10px;
}
.mpvue-calendar .mc-range-mode .month-last-date.mc-range-begin .mc-range-bg{
display: block;
width: 40rpx;
border-radius: 6rpx;
}
.mpvue-calendar .mc-range-mode .month-first-date.mc-range-end .mc-range-bg{
display: block;
width: 40rpx;
border-radius: 6rpx;
left: 10rpx;
}
.mpvue-calendar .mc-range-mode .mc-range-select-one div.mc-range-bg{
display: none !important;
}
.mc-body .mc-today-element .calendar-date{
background-color: rgba(25, 47, 89, 0.1);
border-radius: 6rpx;
}
/*week switch*/
.mpvue-calendar .mc-range-mode.week-switch .month-last-date.mc-range-begin .mc-range-bg{
width: 130%;
border-radius: 0px 20% 20% 0px;
}
.mpvue-calendar .mc-range-mode.week-switch .mc-range-month-last .mc-range-bg{
background-color: #01a1ed;
border-radius: 0px 20% 20% 0px;
}
/*month range*/
.mpvue-calendar .month-range-mode{
border-bottom: 1px solid #f2f2f2;
position: relative;
}
.mpvue-calendar .mc-month-range-mode-head{
box-shadow: 0 4px 8px rgba(25,47,89,.1);
padding: 15rpx 0rpx;
position: sticky;
top: 0px;
background-color: #fff;
z-index: 9;
}
.month-range-mode .month-rang-head {
text-align: left;
margin: 20rpx 0px;
padding-left: 40rpx;
font-size: 28rpx;
}
.month-range-mode .mc-last-month, .month-range-mode .mc-next-month{
opacity: 0 !important;
}
.month-text-background{
position: absolute;
font-size: 140px;
width: 100%;
height: 100%;
text-align: center;
line-height: 2.4;
}
\ No newline at end of file
Markdown 格式
0% or
您添加了 0 到此讨论。请谨慎行事。
先完成此消息的编辑!
想要评论请 注册