nutui-taro-upgrade
Version:
@nutui/nutui-taro 对京东风格组件库的taro4 版本支持
484 lines (483 loc) • 17.5 kB
JavaScript
var __defProp = Object.defineProperty;
var __defProps = Object.defineProperties;
var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
var __hasOwnProp = Object.prototype.hasOwnProperty;
var __propIsEnum = Object.prototype.propertyIsEnumerable;
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
var __spreadValues = (a, b) => {
for (var prop in b || (b = {}))
if (__hasOwnProp.call(b, prop))
__defNormalProp(a, prop, b[prop]);
if (__getOwnPropSymbols)
for (var prop of __getOwnPropSymbols(b)) {
if (__propIsEnum.call(b, prop))
__defNormalProp(a, prop, b[prop]);
}
return a;
};
var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
import { h, defineComponent, ref, computed, watchEffect, withDirectives, openBlock, createElementBlock, createElementVNode, createVNode, unref, createTextVNode, toDisplayString, Fragment, renderList, normalizeClass, renderSlot, vShow } from "vue";
import { U as Utils } from "../date-93eaa982.js";
import { u as useLocale } from "../index-3b6ff56c.js";
import { w as withInstall } from "../with-install-783bc31f.js";
import "nutui-taro-upgrade/dist/packages/locale/lang";
import "../util-f26975e1.js";
const left = "";
const right = "";
const doubleLeft = "";
const doubleRight = "";
const Icon = (url) => {
const style = {
background: `url('${url}') no-repeat center`,
backgroundSize: "100% 100%",
width: "18px",
height: "18px",
display: "block"
};
return h("view", {
style
});
};
const Left = () => {
return Icon(left);
};
const Right = () => {
return Icon(right);
};
const DoubleLeft = () => {
return Icon(doubleLeft);
};
const DoubleRight = () => {
return Icon(doubleRight);
};
const convertDateToDay = (date) => {
return date ? {
year: date.getFullYear(),
month: date.getMonth() + 1,
date: date.getDate()
} : null;
};
const convertDayToDate = (day) => {
return day ? new Date(day.year, day.month - 1, day.date) : null;
};
const valueToRange = (val) => {
if (Array.isArray(val)) {
return val.map((date) => {
return convertDateToDay(date);
});
}
return val ? [convertDateToDay(val)] : [];
};
const rangeTovalue = (range) => {
if (Array.isArray(range)) {
return range.map((day) => {
return convertDayToDate(day);
});
}
return range ? [convertDayToDate(range)] : [];
};
const getPrevMonthDays = (year, month, firstDayOfWeek) => {
let prevMonth = month - 1;
let prevYear = year;
if (prevMonth <= 0) {
prevMonth = 12;
prevYear -= 1;
}
let days = Utils.getMonthPreDay(year, month);
days -= firstDayOfWeek;
if (days >= 7) {
days -= 7;
}
const preDates = Utils.getMonthDays(`${prevYear}`, `${prevMonth}`);
const months = Array.from(Array(preDates), (_, k) => {
return {
type: "prev",
year: prevYear,
month: prevMonth,
date: k + 1
};
});
return months.slice(preDates - days);
};
const getCurrentMonthDays = (year, month) => {
const days = Utils.getMonthDays(`${year}`, `${month}`);
return Array.from(Array(days), (_, k) => {
return {
type: "current",
year,
month,
date: k + 1
};
});
};
const getCurrentWeekDays = (day, firstDayOfWeek) => {
const current = new Date(day.year, day.month - 1, day.date);
const count = (current.getDay() + 7 - firstDayOfWeek) % 7;
return [
convertDateToDay(new Date(current.getTime() - 24 * 60 * 60 * 1e3 * count)),
convertDateToDay(new Date(current.getTime() + 24 * 60 * 60 * 1e3 * (6 - count)))
];
};
const getDays = (month, firstDayOfWeek) => {
const y = month.year;
const m = month.month;
const days = [...getPrevMonthDays(y, m, firstDayOfWeek), ...getCurrentMonthDays(y, m)];
const size = days.length;
const yearOfNextMonth = month.month === 12 ? month.year + 1 : month.year;
const monthOfNextMonth = month.month === 12 ? 1 : month.month + 1;
for (let i = 1; i <= 42 - size; i++) {
days.push({
type: "next",
year: yearOfNextMonth,
month: monthOfNextMonth,
date: i
});
}
return days;
};
const compareDay = (day1, day2) => {
if (day1 && day2) {
if (day1.year === day2.year) {
if (day1.month === day2.month) {
return day1.date - day2.date;
}
return day1.month - day2.month;
}
return day1.year - day2.year;
}
};
const isSameDay = (day1, day2) => {
return compareDay(day1, day2) === 0;
};
const _hoisted_1 = { class: "nut-calendarcard" };
const _hoisted_2 = { class: "nut-calendarcard-header" };
const _hoisted_3 = { class: "nut-calendarcard-header-left" };
const _hoisted_4 = { class: "nut-calendarcard-header-title" };
const _hoisted_5 = { class: "nut-calendarcard-header-right" };
const _hoisted_6 = { class: "nut-calendarcard-content" };
const _hoisted_7 = { class: "nut-calendarcard-days" };
const _hoisted_8 = { class: "nut-calendarcard-days" };
const _hoisted_9 = ["onClick"];
const _hoisted_10 = { class: "nut-calendarcard-day-top" };
const _hoisted_11 = { class: "nut-calendarcard-day-inner" };
const _hoisted_12 = { class: "nut-calendarcard-day-bottom" };
const cN = "NutCalendarCard";
const _sfc_main = /* @__PURE__ */ defineComponent(__spreadProps(__spreadValues({}, {
name: cN
}), {
__name: "calendar-card.taro",
props: {
type: { default: "single" },
firstDayOfWeek: { default: 0 },
modelValue: { default: null },
startDate: { default: null },
endDate: { default: null },
disableDay: { type: Function, default: () => false }
},
emits: ["update:modelValue", "change", "dayClick", "pageChange"],
setup(__props, { expose: __expose, emit: __emit }) {
const props = __props;
const emit = __emit;
const translate = useLocale(cN);
const initMonth = () => {
let date = new Date(Date.now());
const val = props.modelValue;
if (Array.isArray(val)) {
if (val.length) {
date = val[0];
}
} else if (val) {
date = val;
}
return {
year: date.getFullYear(),
month: date.getMonth() + 1
};
};
const month = ref(initMonth());
const days = ref([]);
const weekHeader = computed(() => {
const weekdays = translate("weekdays").map((day, index) => {
return {
name: day,
key: index
};
});
return [...weekdays.slice(props.firstDayOfWeek, 7), ...weekdays.slice(0, props.firstDayOfWeek)];
});
const innerValue = ref(props.modelValue ? valueToRange(props.modelValue) : []);
watchEffect(() => {
const val = props.modelValue ? valueToRange(props.modelValue) : [];
innerValue.value = val;
});
const change = (v) => {
innerValue.value = v;
if (props.type === "single") {
const date = convertDayToDate(v[0]);
emit("update:modelValue", date);
emit("change", date);
} else if (props.type === "multiple" || props.type === "range" || props.type === "week") {
const val = rangeTovalue(v);
emit("update:modelValue", val);
emit("change", val);
}
};
watchEffect(() => {
const newDays = getDays(month.value, props.firstDayOfWeek);
days.value = newDays;
emit("pageChange", month.value);
});
const isDisable = (day) => {
if (props.disableDay && props.disableDay(day)) {
return true;
}
if (props.startDate && Number(compareDay(day, convertDateToDay(props.startDate))) < 0) {
return true;
}
if (props.endDate && Number(compareDay(day, convertDateToDay(props.endDate))) > 0) {
return true;
}
return false;
};
const isActive = (day) => {
if (props.type === "single" || props.type === "multiple") {
for (const val in innerValue.value) {
if (isSameDay(day, innerValue.value[val])) {
return true;
}
}
} else if (props.type === "range" && innerValue.value.length === 1 && isSameDay(innerValue.value[0], day)) {
return true;
}
return false;
};
const isStart = (day) => {
return (props.type === "range" || props.type === "week") && innerValue.value.length === 2 && isSameDay(day, innerValue.value[0]);
};
const isEnd = (day) => {
return (props.type === "range" || props.type === "week") && innerValue.value.length === 2 && isSameDay(day, innerValue.value[1]);
};
const isMid = (day) => {
if (props.type === "range" || props.type === "week") {
if (innerValue.value.length === 2) {
const c1 = compareDay(innerValue.value[0], day);
const c2 = compareDay(day, innerValue.value[1]);
if (c1 && c1 < 0 && c2 && c2 < 0) {
return true;
}
}
}
return false;
};
const isWeekend = (day) => {
const d = new Date(day.year, day.month - 1, day.date).getDay();
return d === 0 || d === 6;
};
const getClasses = (day) => {
if (isDisable(day)) {
return ["disabled"];
}
const res = [];
if (day.type === "current") {
if (isActive(day)) {
res.push("active");
}
if (isStart(day)) {
res.push("start");
}
if (isEnd(day)) {
res.push("end");
}
if (isMid(day)) {
res.push("mid");
}
if (isWeekend(day)) {
res.push("weekend");
}
}
return res;
};
const jumpTo = (y, m) => {
if (props.startDate) {
const c = compareDay(
{
year: y,
month: m,
date: 31
},
convertDateToDay(props.startDate)
);
if (c && c < 0) {
return;
}
}
if (props.endDate) {
const c = compareDay(
{
year: y,
month: m,
date: 1
},
convertDateToDay(props.endDate)
);
if (c && c > 0) {
return;
}
}
month.value = {
year: y,
month: m
};
};
const jump = (step = 1) => {
const current = month.value.year * 12 + month.value.month;
let newMonth = (current + step) % 12;
if (newMonth === 0) {
newMonth = 12;
}
const newYear = Math.floor((current + step - newMonth) / 12);
jumpTo(newYear, newMonth);
};
const handleDayClick = (day) => {
if (day.type === "prev" || day.type === "next" || isDisable(day)) {
return;
}
emit("dayClick", day);
switch (props.type) {
case "single": {
if (innerValue.value[0] && isSameDay(innerValue.value[0], day)) {
change([]);
} else {
change([day]);
}
break;
}
case "multiple": {
const t = innerValue.value.find((i) => isSameDay(i, day));
if (t) {
change(innerValue.value.filter((i) => i !== t));
} else {
change([...innerValue.value, day]);
}
break;
}
case "range": {
const len = innerValue.value.length;
if (len === 0 || len === 2) {
change([day]);
} else if (len === 1) {
const t = compareDay(innerValue.value[0], day);
if (t === null || t === void 0) {
change([]);
} else if (t < 0) {
change([innerValue.value[0], day]);
} else {
change([day, innerValue.value[0]]);
}
} else {
console.warn("[NutUI] Calendar range error");
}
break;
}
case "week": {
if (innerValue.value.length === 2 || innerValue.value.length === 0) {
const [left2, right2] = getCurrentWeekDays(day, props.firstDayOfWeek);
change([left2, right2]);
} else {
console.warn("[NutUI] Calendar week error");
}
break;
}
default: {
console.warn("[NutUI] Calendar type error");
}
}
};
__expose({
jump,
jumpTo
});
return (_ctx, _cache) => {
return withDirectives((openBlock(), createElementBlock("div", _hoisted_1, [
createElementVNode("div", _hoisted_2, [
createElementVNode("div", _hoisted_3, [
createElementVNode("div", {
class: "double-left",
onClick: _cache[0] || (_cache[0] = ($event) => jump(-12))
}, [
createVNode(unref(DoubleLeft))
]),
_cache[4] || (_cache[4] = createTextVNode()),
createElementVNode("div", {
class: "left",
onClick: _cache[1] || (_cache[1] = ($event) => jump(-1))
}, [
createVNode(unref(Left))
])
]),
_cache[6] || (_cache[6] = createTextVNode()),
createElementVNode("div", _hoisted_4, toDisplayString(unref(translate)("monthTitle", month.value.year, month.value.month)), 1),
_cache[7] || (_cache[7] = createTextVNode()),
createElementVNode("div", _hoisted_5, [
createElementVNode("div", {
class: "right",
onClick: _cache[2] || (_cache[2] = ($event) => jump(1))
}, [
createVNode(unref(Right))
]),
_cache[5] || (_cache[5] = createTextVNode()),
createElementVNode("div", {
class: "double-right",
onClick: _cache[3] || (_cache[3] = ($event) => jump(12))
}, [
createVNode(unref(DoubleRight))
])
])
]),
_cache[11] || (_cache[11] = createTextVNode()),
createElementVNode("div", _hoisted_6, [
createElementVNode("div", _hoisted_7, [
(openBlock(true), createElementBlock(Fragment, null, renderList(weekHeader.value, (d) => {
return openBlock(), createElementBlock("div", {
key: d.name,
class: normalizeClass(["nut-calendarcard-day header", d.key === 0 || d.key === 6 ? "weekend" : ""])
}, toDisplayString(d.name), 3);
}), 128))
]),
_cache[10] || (_cache[10] = createTextVNode()),
createElementVNode("div", _hoisted_8, [
(openBlock(true), createElementBlock(Fragment, null, renderList(days.value, (day) => {
return openBlock(), createElementBlock("div", {
key: `${day.year}-${day.month}-${day.date}`,
class: normalizeClass(["nut-calendarcard-day", [day.type, ...getClasses(day)]]),
onClick: ($event) => handleDayClick(day)
}, [
createElementVNode("div", _hoisted_10, [
renderSlot(_ctx.$slots, "top", { day })
]),
_cache[8] || (_cache[8] = createTextVNode()),
createElementVNode("div", _hoisted_11, [
renderSlot(_ctx.$slots, "default", { day }, () => [
createTextVNode(toDisplayString(day.date), 1)
])
]),
_cache[9] || (_cache[9] = createTextVNode()),
createElementVNode("div", _hoisted_12, [
renderSlot(_ctx.$slots, "bottom", { day })
])
], 10, _hoisted_9);
}), 128))
])
])
], 512)), [
[vShow, days.value.length > 0]
]);
};
}
}));
withInstall(_sfc_main);
export {
_sfc_main as CalendarCard,
_sfc_main as default
};