@nutui/nutui-react
Version:
京东风格的轻量级移动端 React 组件库,支持一套代码生成 H5 和小程序
115 lines (114 loc) • 5.17 kB
JavaScript
import { _ as _object_spread } from "@swc/helpers/_/_object_spread";
import { _ as _object_spread_props } from "@swc/helpers/_/_object_spread_props";
import React, { useRef } from "react";
import Popup from "../popup";
import CalendarItem from "../calendaritem";
import { Utils } from "../../utils/date";
import { useConfig } from "../configprovider";
import { ComponentDefaults } from "../../utils/typings";
var defaultProps = _object_spread_props(_object_spread({}, ComponentDefaults), {
type: 'single',
autoBackfill: false,
popup: true,
visible: false,
title: '',
defaultValue: '',
startDate: Utils.getDay(0),
endDate: Utils.getDay(365),
showToday: true,
startText: '',
endText: '',
confirmText: '',
showTitle: true,
showSubTitle: true,
scrollAnimation: true,
firstDayOfWeek: 0,
disableDate: function(date) {
return false;
},
renderHeaderButtons: undefined,
renderDay: undefined,
renderDayTop: undefined,
renderDayBottom: undefined,
onClose: function() {},
onConfirm: function(param) {},
onDayClick: function(data) {},
onPageChange: function(param) {}
});
export var Calendar = /*#__PURE__*/ React.forwardRef(function(props, ref) {
var locale = useConfig().locale;
var _$_object_spread = _object_spread({}, defaultProps, props), style = _$_object_spread.style, className = _$_object_spread.className, children = _$_object_spread.children, popup = _$_object_spread.popup, visible = _$_object_spread.visible, type = _$_object_spread.type, autoBackfill = _$_object_spread.autoBackfill, title = _$_object_spread.title, defaultValue = _$_object_spread.defaultValue, startDate = _$_object_spread.startDate, endDate = _$_object_spread.endDate, showToday = _$_object_spread.showToday, startText = _$_object_spread.startText, endText = _$_object_spread.endText, confirmText = _$_object_spread.confirmText, showTitle = _$_object_spread.showTitle, showSubTitle = _$_object_spread.showSubTitle, scrollAnimation = _$_object_spread.scrollAnimation, firstDayOfWeek = _$_object_spread.firstDayOfWeek, closeIcon = _$_object_spread.closeIcon, disableDate = _$_object_spread.disableDate, renderHeaderButtons = _$_object_spread.renderHeaderButtons, renderBottomButton = _$_object_spread.renderBottomButton, renderDay = _$_object_spread.renderDay, renderDayTop = _$_object_spread.renderDayTop, renderDayBottom = _$_object_spread.renderDayBottom, onClose = _$_object_spread.onClose, onConfirm = _$_object_spread.onConfirm, onDayClick = _$_object_spread.onDayClick, onPageChange = _$_object_spread.onPageChange;
var calendarRef = useRef(null);
var close = function() {
onClose && onClose();
};
var choose = function(param) {
close();
onConfirm && onConfirm(param);
};
var closePopup = function() {
close();
};
var select = function(param) {
onDayClick && onDayClick(param);
};
var scrollToDate = function(date) {
var _calendarRef_current;
(_calendarRef_current = calendarRef.current) === null || _calendarRef_current === void 0 ? void 0 : _calendarRef_current.scrollToDate(date);
};
var yearMonthChange = function(param) {
onPageChange && onPageChange(param);
};
React.useImperativeHandle(ref, function() {
return {
scrollToDate: scrollToDate
};
});
var renderItem = function() {
return /*#__PURE__*/ React.createElement(CalendarItem, {
ref: calendarRef,
style: style,
className: className,
children: children,
type: type,
autoBackfill: autoBackfill,
renderBottomButton: renderBottomButton,
popup: popup,
title: title || locale.calendaritem.title,
defaultValue: defaultValue,
startDate: startDate,
endDate: endDate,
showToday: showToday,
startText: startText || locale.calendaritem.start,
endText: endText || locale.calendaritem.end,
confirmText: confirmText || locale.calendaritem.confirm,
showTitle: showTitle,
showSubTitle: showSubTitle,
scrollAnimation: scrollAnimation,
firstDayOfWeek: firstDayOfWeek,
disableDate: disableDate,
renderHeaderButtons: renderHeaderButtons,
renderDay: renderDay,
renderDayTop: renderDayTop,
renderDayBottom: renderDayBottom,
onConfirm: choose,
onDayClick: select,
onPageChange: yearMonthChange
});
};
return /*#__PURE__*/ React.createElement(React.Fragment, null, popup ? /*#__PURE__*/ React.createElement(Popup, {
className: "nut-calendar-popup",
visible: visible,
position: "bottom",
round: true,
closeable: true,
closeIcon: closeIcon,
destroyOnClose: true,
onOverlayClick: closePopup,
onCloseIconClick: closePopup,
style: {
height: '83%'
}
}, renderItem()) : renderItem());
});
Calendar.displayName = 'NutCalendar';