Слияние кода завершено, страница обновится автоматически
import React, { Component, CSSProperties, ReactNode } from 'react';
import PropTypes from 'prop-types';
import moment, { Moment } from 'moment';
import noop from 'lodash/noop';
import LocaleReceiver from '../locale-provider/LocaleReceiver';
import Header from './Header';
import interopDefault from '../_util/interopDefault';
import enUS from './locale/en_US';
import FullCalendar from '../rc-components/calendar/FullCalendar';
import { getPrefixCls } from '../configure';
export { HeaderProps } from './Header';
function zerofixed(v: number) {
if (v < 10) {
return `0${v}`;
}
return `${v}`;
}
export type CalendarMode = 'month' | 'year';
export interface CalendarProps {
prefixCls?: string;
className?: string;
value?: Moment;
defaultValue?: Moment;
mode?: CalendarMode;
fullscreen?: boolean;
dateCellRender?: (date: Moment) => ReactNode;
monthCellRender?: (date: Moment) => ReactNode;
dateFullCellRender?: (date: Moment) => ReactNode;
monthFullCellRender?: (date: Moment) => ReactNode;
locale?: any;
style?: CSSProperties;
onPanelChange?: (date?: Moment, mode?: CalendarMode) => void;
onSelect?: (date?: Moment) => void;
disabledDate?: (current: Moment) => boolean;
validRange?: [Moment, Moment];
}
export interface CalendarState {
value: Moment;
mode?: CalendarMode;
}
export default class Calendar extends Component<CalendarProps, CalendarState> {
static displayName = 'Calendar';
static defaultProps = {
locale: {},
fullscreen: true,
mode: 'month',
onSelect: noop,
onPanelChange: noop,
};
static propTypes = {
monthCellRender: PropTypes.func,
dateCellRender: PropTypes.func,
monthFullCellRender: PropTypes.func,
dateFullCellRender: PropTypes.func,
fullscreen: PropTypes.bool,
locale: PropTypes.object,
prefixCls: PropTypes.string,
className: PropTypes.string,
style: PropTypes.object,
onPanelChange: PropTypes.func,
value: PropTypes.object,
onSelect: PropTypes.func,
mode: PropTypes.string,
};
constructor(props: CalendarProps) {
super(props);
const value = props.value || props.defaultValue || interopDefault(moment)();
if (!interopDefault(moment).isMoment(value)) {
throw new Error('The value/defaultValue of Calendar must be a moment object');
}
this.state = {
value,
mode: props.mode,
};
}
componentWillReceiveProps(nextProps: CalendarProps) {
if ('value' in nextProps) {
this.setState({
value: nextProps.value!,
});
}
const { mode } = this.props;
if ('mode' in nextProps && nextProps.mode !== mode) {
this.setState({
mode: nextProps.mode!,
});
}
}
getPrefixCls() {
const { prefixCls } = this.props;
return getPrefixCls('fullcalendar', prefixCls);
}
monthCellRender = (value: Moment) => {
const { monthCellRender = noop as Function } = this.props;
const prefixCls = this.getPrefixCls();
return (
<div className={`${prefixCls}-month`}>
<div className={`${prefixCls}-value`}>{value.localeData().monthsShort(value)}</div>
<div className={`${prefixCls}-content`}>{monthCellRender(value)}</div>
</div>
);
};
dateCellRender = (value: Moment) => {
const { dateCellRender = noop as Function } = this.props;
const prefixCls = this.getPrefixCls();
return (
<div className={`${prefixCls}-date`}>
<div className={`${prefixCls}-value`}>{zerofixed(value.date())}</div>
<div className={`${prefixCls}-content`}>{dateCellRender(value)}</div>
</div>
);
};
setValue = (value: Moment, way: 'select' | 'changePanel') => {
if (!('value' in this.props)) {
this.setState({ value });
}
if (way === 'select') {
const { onSelect } = this.props;
if (onSelect) {
onSelect(value);
}
} else if (way === 'changePanel') {
const { mode } = this.state;
this.onPanelChange(value, mode);
}
};
setType = (type: string) => {
const mode = type === 'date' ? 'month' : 'year';
const { mode: stateMode, value } = this.state;
if (stateMode !== mode) {
this.setState({ mode });
this.onPanelChange(value, mode);
}
};
onHeaderValueChange = (value: Moment) => {
this.setValue(value, 'changePanel');
};
onHeaderTypeChange = (type: string) => {
this.setType(type);
};
onPanelChange(value: Moment, mode: CalendarMode | undefined) {
const { onPanelChange } = this.props;
if (onPanelChange) {
onPanelChange(value, mode);
}
}
onSelect = (value: Moment) => {
this.setValue(value, 'select');
};
getDateRange = (validRange: [Moment, Moment], disabledDate?: (current: Moment) => boolean) => (
current: Moment,
) => {
if (!current) {
return false;
}
const [startDate, endDate] = validRange;
const inRange = !current.isBetween(startDate, endDate, 'days', '[]');
if (disabledDate) {
return disabledDate(current) || inRange;
}
return inRange;
};
renderCalendar = (locale: any, localeCode: string) => {
const { state, props } = this;
const { value, mode } = state;
if (value && localeCode) {
value.locale(localeCode);
}
const { style, className, fullscreen, dateFullCellRender, monthFullCellRender } = props;
const prefixCls = this.getPrefixCls();
const type = mode === 'year' ? 'month' : 'date';
let cls = className || '';
if (fullscreen) {
cls += ` ${prefixCls}-fullscreen`;
}
const monthCellRender = monthFullCellRender || this.monthCellRender;
const dateCellRender = dateFullCellRender || this.dateCellRender;
let disabledDate = props.disabledDate;
if (props.validRange) {
disabledDate = this.getDateRange(props.validRange, disabledDate);
}
return (
<div className={cls} style={style}>
<Header
fullscreen={fullscreen}
type={type}
value={value}
locale={locale.lang}
prefixCls={prefixCls}
onTypeChange={this.onHeaderTypeChange}
onValueChange={this.onHeaderValueChange}
validRange={props.validRange}
/>
<FullCalendar
{...props}
disabledDate={disabledDate}
Select={noop}
locale={locale.lang}
type={type}
prefixCls={prefixCls}
showHeader={false}
value={value}
monthCellRender={monthCellRender}
dateCellRender={dateCellRender}
onSelect={this.onSelect}
/>
</div>
);
};
render() {
return (
<LocaleReceiver componentName="Calendar" defaultLocale={enUS}>
{this.renderCalendar}
</LocaleReceiver>
);
}
}
Вы можете оставить комментарий после Вход в систему
Неприемлемый контент может быть отображен здесь и не будет показан на странице. Вы можете проверить и изменить его с помощью соответствующей функции редактирования.
Если вы подтверждаете, что содержание не содержит непристойной лексики/перенаправления на рекламу/насилия/вульгарной порнографии/нарушений/пиратства/ложного/незначительного или незаконного контента, связанного с национальными законами и предписаниями, вы можете нажать «Отправить» для подачи апелляции, и мы обработаем ее как можно скорее.
Опубликовать ( 0 )