mirror of
https://github.com/zhigang1992/DefinitelyTyped.git
synced 2026-04-20 00:59:29 +08:00
67 lines
2.1 KiB
TypeScript
67 lines
2.1 KiB
TypeScript
// Type definitions for React Daterange Picker 1.1
|
|
// Project: https://github.com/onefinestay/react-daterange-picker
|
|
// Definitions by: UNCOVER TRUTH Inc. <https://github.com/uncovertruth>
|
|
// MartynasZilinskas <https://github.com/MartynasZilinskas>
|
|
// Definitions: https://github.com/borisyankov/DefinitelyTyped
|
|
// TypeScript Version: 2.3
|
|
|
|
import * as React from "react";
|
|
import * as moment from "moment";
|
|
import * as momentRange from "moment-range";
|
|
|
|
export default class DateRangePicker extends React.Component<Props> { }
|
|
export as namespace ReactDateRangePicker;
|
|
|
|
export interface Props extends React.Props<{}> {
|
|
bemBlock?: string;
|
|
bemNamespace?: string;
|
|
dateStates?: DateState[];
|
|
defaultState?: string;
|
|
disableNavigation?: boolean;
|
|
// Use Number Literal Types after TypeScript 2.0 GA released.
|
|
firstOfWeek?: number; // React.PropTypes.oneOf([0, 1, 2, 3, 4, 5, 6])
|
|
helpMessage?: string;
|
|
initialFromValue?: boolean;
|
|
initialDate?: Date;
|
|
initialMonth?: number;
|
|
initialYear?: number;
|
|
initialRange?: {};
|
|
maximumDate?: Date;
|
|
minimumDate?: Date;
|
|
numberOfCalendars?: number;
|
|
onHighlightDate?(date: Date): void;
|
|
onHighlightRange?(date: Date): void;
|
|
onSelect?(value: Props): void;
|
|
onSelectStart?(value: momentRange.MomentRangeExtends): void;
|
|
paginationArrowComponent?: PaginationArrow;
|
|
selectedLabel?: string;
|
|
selectionType?: 'single' | 'range';
|
|
singleDateRange?: boolean;
|
|
showLegend?: boolean;
|
|
stateDefinitions?: StateDefinitions;
|
|
value?: momentRange.MomentRangeExtends | momentRange.DateRange;
|
|
}
|
|
|
|
export interface DateState {
|
|
state: string;
|
|
range: momentRange.DateRange;
|
|
}
|
|
|
|
export interface StateDefinitions {
|
|
[key: string]: StateDefinition;
|
|
}
|
|
|
|
export interface StateDefinition {
|
|
color: string;
|
|
label: string;
|
|
selectable?: boolean;
|
|
}
|
|
|
|
export interface PaginationArrowProps extends React.Props<{}> {
|
|
disabled?: boolean;
|
|
onTrigger?(): void;
|
|
direction?: 'next' | 'previous';
|
|
}
|
|
|
|
export class PaginationArrow extends React.Component<PaginationArrowProps> { }
|