Socket
Socket
Sign inDemoInstall

@blueprintjs/datetime

Package Overview
Dependencies
Maintainers
1
Versions
253
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@blueprintjs/datetime - npm Package Compare versions

Comparing version 1.2.0 to 1.3.0

2

dist/common/utils.d.ts

@@ -5,3 +5,3 @@ /**

*/
export declare function measureTextWidth(text: string, className?: string): string;
export declare function measureTextWidth(text: string, className?: string, containerElement?: HTMLElement): string;
export declare function padWithZeroes(str: string, minLength: number): string;

@@ -12,8 +12,9 @@ /*

*/
function measureTextWidth(text, className) {
function measureTextWidth(text, className, containerElement) {
if (className === void 0) { className = ""; }
if (containerElement === void 0) { containerElement = document.body; }
var span = document.createElement("span");
span.classList.add(className);
span.innerHTML = text;
document.body.appendChild(span);
containerElement.appendChild(span);
var spanWidth = span.offsetWidth;

@@ -37,2 +38,2 @@ span.remove();

//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9jb21tb24vdXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7O0dBS0c7O0FBRUg7OztHQUdHO0FBQ0gsMEJBQWlDLElBQVksRUFBRSxTQUFjO0lBQWQseUJBQWMsR0FBZCxjQUFjO0lBQ3pELElBQU0sSUFBSSxHQUFHLFFBQVEsQ0FBQyxhQUFhLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDNUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsU0FBUyxDQUFDLENBQUM7SUFDOUIsSUFBSSxDQUFDLFNBQVMsR0FBRyxJQUFJLENBQUM7SUFFdEIsUUFBUSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDaEMsSUFBTSxTQUFTLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQztJQUNuQyxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7SUFFZCxNQUFNLENBQUMsU0FBUyxHQUFHLElBQUksQ0FBQztBQUM1QixDQUFDO0FBVmUsd0JBQWdCLG1CQVUvQixDQUFBO0FBRUQsdUJBQThCLEdBQVcsRUFBRSxTQUFpQjtJQUN4RCxFQUFFLENBQUMsQ0FBQyxHQUFHLENBQUMsTUFBTSxHQUFHLFNBQVMsQ0FBQyxDQUFDLENBQUM7UUFDekIsTUFBTSxDQUFDLEtBQUcsWUFBWSxDQUFDLEdBQUcsRUFBRSxTQUFTLEdBQUcsR0FBRyxDQUFDLE1BQU0sQ0FBQyxHQUFHLEdBQUssQ0FBQztJQUNoRSxDQUFDO0lBQUMsSUFBSSxDQUFDLENBQUM7UUFDSixNQUFNLENBQUMsR0FBRyxDQUFDO0lBQ2YsQ0FBQztBQUNMLENBQUM7QUFOZSxxQkFBYSxnQkFNNUIsQ0FBQTtBQUVELHNCQUFzQixHQUFXLEVBQUUsUUFBZ0I7SUFDL0MsTUFBTSxDQUFDLElBQUksS0FBSyxDQUFDLFFBQVEsR0FBRyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7QUFDN0MsQ0FBQyIsImZpbGUiOiJjb21tb24vdXRpbHMuanMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogQ29weXJpZ2h0IDIwMTUgUGFsYW50aXIgVGVjaG5vbG9naWVzLCBJbmMuIEFsbCByaWdodHMgcmVzZXJ2ZWQuXG4gKiBMaWNlbnNlZCB1bmRlciB0aGUgQlNELTMgTGljZW5zZSBhcyBtb2RpZmllZCAodGhlIOKAnExpY2Vuc2XigJ0pOyB5b3UgbWF5IG9idGFpbiBhIGNvcHlcbiAqIG9mIHRoZSBsaWNlbnNlIGF0IGh0dHBzOi8vZ2l0aHViLmNvbS9wYWxhbnRpci9ibHVlcHJpbnQvYmxvYi9tYXN0ZXIvTElDRU5TRVxuICogYW5kIGh0dHBzOi8vZ2l0aHViLmNvbS9wYWxhbnRpci9ibHVlcHJpbnQvYmxvYi9tYXN0ZXIvUEFURU5UU1xuICovXG5cbi8qKlxuICogTWVhc3VyZSB3aWR0aCBvZiBhIHN0cmluZyBkaXNwbGF5ZWQgd2l0aCBzdHlsZXMgcHJvdmlkZWQgYnkgYGNsYXNzTmFtZWAuXG4gKiBTaG91bGQgb25seSBiZSB1c2VkIGlmIG1lYXN1cmluZyBjYW4ndCBiZSBkb25lIHdpdGggZXhpc3RpbmcgRE9NIGVsZW1lbnRzLlxuICovXG5leHBvcnQgZnVuY3Rpb24gbWVhc3VyZVRleHRXaWR0aCh0ZXh0OiBzdHJpbmcsIGNsYXNzTmFtZSA9IFwiXCIpIHtcbiAgICBjb25zdCBzcGFuID0gZG9jdW1lbnQuY3JlYXRlRWxlbWVudChcInNwYW5cIik7XG4gICAgc3Bhbi5jbGFzc0xpc3QuYWRkKGNsYXNzTmFtZSk7XG4gICAgc3Bhbi5pbm5lckhUTUwgPSB0ZXh0O1xuXG4gICAgZG9jdW1lbnQuYm9keS5hcHBlbmRDaGlsZChzcGFuKTtcbiAgICBjb25zdCBzcGFuV2lkdGggPSBzcGFuLm9mZnNldFdpZHRoO1xuICAgIHNwYW4ucmVtb3ZlKCk7XG5cbiAgICByZXR1cm4gc3BhbldpZHRoICsgXCJweFwiO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gcGFkV2l0aFplcm9lcyhzdHI6IHN0cmluZywgbWluTGVuZ3RoOiBudW1iZXIpIHtcbiAgICBpZiAoc3RyLmxlbmd0aCA8IG1pbkxlbmd0aCkge1xuICAgICAgICByZXR1cm4gYCR7c3RyaW5nUmVwZWF0KFwiMFwiLCBtaW5MZW5ndGggLSBzdHIubGVuZ3RoKX0ke3N0cn1gO1xuICAgIH0gZWxzZSB7XG4gICAgICAgIHJldHVybiBzdHI7XG4gICAgfVxufVxuXG5mdW5jdGlvbiBzdHJpbmdSZXBlYXQoc3RyOiBzdHJpbmcsIG51bVRpbWVzOiBudW1iZXIpIHtcbiAgICByZXR1cm4gbmV3IEFycmF5KG51bVRpbWVzICsgMSkuam9pbihzdHIpO1xufVxuIl0sInNvdXJjZVJvb3QiOiIvc291cmNlLyJ9
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9jb21tb24vdXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7O0dBS0c7O0FBRUg7OztHQUdHO0FBQ0gsMEJBQWlDLElBQVksRUFBRSxTQUFjLEVBQUUsZ0JBQWdDO0lBQWhELHlCQUFjLEdBQWQsY0FBYztJQUFFLGdDQUFnQyxHQUFoQyxtQkFBbUIsUUFBUSxDQUFDLElBQUk7SUFDM0YsSUFBTSxJQUFJLEdBQUcsUUFBUSxDQUFDLGFBQWEsQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUM1QyxJQUFJLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUM5QixJQUFJLENBQUMsU0FBUyxHQUFHLElBQUksQ0FBQztJQUV0QixnQkFBZ0IsQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDbkMsSUFBTSxTQUFTLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQztJQUNuQyxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7SUFFZCxNQUFNLENBQUMsU0FBUyxHQUFHLElBQUksQ0FBQztBQUM1QixDQUFDO0FBVmUsd0JBQWdCLG1CQVUvQixDQUFBO0FBRUQsdUJBQThCLEdBQVcsRUFBRSxTQUFpQjtJQUN4RCxFQUFFLENBQUMsQ0FBQyxHQUFHLENBQUMsTUFBTSxHQUFHLFNBQVMsQ0FBQyxDQUFDLENBQUM7UUFDekIsTUFBTSxDQUFDLEtBQUcsWUFBWSxDQUFDLEdBQUcsRUFBRSxTQUFTLEdBQUcsR0FBRyxDQUFDLE1BQU0sQ0FBQyxHQUFHLEdBQUssQ0FBQztJQUNoRSxDQUFDO0lBQUMsSUFBSSxDQUFDLENBQUM7UUFDSixNQUFNLENBQUMsR0FBRyxDQUFDO0lBQ2YsQ0FBQztBQUNMLENBQUM7QUFOZSxxQkFBYSxnQkFNNUIsQ0FBQTtBQUVELHNCQUFzQixHQUFXLEVBQUUsUUFBZ0I7SUFDL0MsTUFBTSxDQUFDLElBQUksS0FBSyxDQUFDLFFBQVEsR0FBRyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7QUFDN0MsQ0FBQyIsImZpbGUiOiJjb21tb24vdXRpbHMuanMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogQ29weXJpZ2h0IDIwMTUgUGFsYW50aXIgVGVjaG5vbG9naWVzLCBJbmMuIEFsbCByaWdodHMgcmVzZXJ2ZWQuXG4gKiBMaWNlbnNlZCB1bmRlciB0aGUgQlNELTMgTGljZW5zZSBhcyBtb2RpZmllZCAodGhlIOKAnExpY2Vuc2XigJ0pOyB5b3UgbWF5IG9idGFpbiBhIGNvcHlcbiAqIG9mIHRoZSBsaWNlbnNlIGF0IGh0dHBzOi8vZ2l0aHViLmNvbS9wYWxhbnRpci9ibHVlcHJpbnQvYmxvYi9tYXN0ZXIvTElDRU5TRVxuICogYW5kIGh0dHBzOi8vZ2l0aHViLmNvbS9wYWxhbnRpci9ibHVlcHJpbnQvYmxvYi9tYXN0ZXIvUEFURU5UU1xuICovXG5cbi8qKlxuICogTWVhc3VyZSB3aWR0aCBvZiBhIHN0cmluZyBkaXNwbGF5ZWQgd2l0aCBzdHlsZXMgcHJvdmlkZWQgYnkgYGNsYXNzTmFtZWAuXG4gKiBTaG91bGQgb25seSBiZSB1c2VkIGlmIG1lYXN1cmluZyBjYW4ndCBiZSBkb25lIHdpdGggZXhpc3RpbmcgRE9NIGVsZW1lbnRzLlxuICovXG5leHBvcnQgZnVuY3Rpb24gbWVhc3VyZVRleHRXaWR0aCh0ZXh0OiBzdHJpbmcsIGNsYXNzTmFtZSA9IFwiXCIsIGNvbnRhaW5lckVsZW1lbnQgPSBkb2N1bWVudC5ib2R5KSB7XG4gICAgY29uc3Qgc3BhbiA9IGRvY3VtZW50LmNyZWF0ZUVsZW1lbnQoXCJzcGFuXCIpO1xuICAgIHNwYW4uY2xhc3NMaXN0LmFkZChjbGFzc05hbWUpO1xuICAgIHNwYW4uaW5uZXJIVE1MID0gdGV4dDtcblxuICAgIGNvbnRhaW5lckVsZW1lbnQuYXBwZW5kQ2hpbGQoc3Bhbik7XG4gICAgY29uc3Qgc3BhbldpZHRoID0gc3Bhbi5vZmZzZXRXaWR0aDtcbiAgICBzcGFuLnJlbW92ZSgpO1xuXG4gICAgcmV0dXJuIHNwYW5XaWR0aCArIFwicHhcIjtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHBhZFdpdGhaZXJvZXMoc3RyOiBzdHJpbmcsIG1pbkxlbmd0aDogbnVtYmVyKSB7XG4gICAgaWYgKHN0ci5sZW5ndGggPCBtaW5MZW5ndGgpIHtcbiAgICAgICAgcmV0dXJuIGAke3N0cmluZ1JlcGVhdChcIjBcIiwgbWluTGVuZ3RoIC0gc3RyLmxlbmd0aCl9JHtzdHJ9YDtcbiAgICB9IGVsc2Uge1xuICAgICAgICByZXR1cm4gc3RyO1xuICAgIH1cbn1cblxuZnVuY3Rpb24gc3RyaW5nUmVwZWF0KHN0cjogc3RyaW5nLCBudW1UaW1lczogbnVtYmVyKSB7XG4gICAgcmV0dXJuIG5ldyBBcnJheShudW1UaW1lcyArIDEpLmpvaW4oc3RyKTtcbn1cbiJdLCJzb3VyY2VSb290IjoiL3NvdXJjZS8ifQ==

@@ -140,3 +140,8 @@ /*

this.fromMomentToDate = function (momentDate) {
return new Date(momentDate.year(), momentDate.month(), momentDate.date(), momentDate.hours(), momentDate.minutes(), momentDate.seconds(), momentDate.milliseconds());
if (momentDate == null) {
return undefined;
}
else {
return new Date(momentDate.year(), momentDate.month(), momentDate.date(), momentDate.hours(), momentDate.minutes(), momentDate.seconds(), momentDate.milliseconds());
}
};

@@ -148,11 +153,16 @@ /**

this.fromDateToMoment = function (date) {
return moment([
date.getFullYear(),
date.getMonth(),
date.getDate(),
date.getHours(),
date.getMinutes(),
date.getSeconds(),
date.getMilliseconds(),
]);
if (date == null || typeof date === "string") {
return moment(date);
}
else {
return moment([
date.getFullYear(),
date.getMonth(),
date.getDate(),
date.getHours(),
date.getMinutes(),
date.getSeconds(),
date.getMilliseconds(),
]);
}
};

@@ -209,2 +219,2 @@ var defaultValue = this.props.defaultValue ? this.fromDateToMoment(this.props.defaultValue) : moment(null);

//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/dateInput.tsx"],"names":[],"mappings":"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","file":"dateInput.js","sourcesContent":["/*\n * Copyright 2016 Palantir Technologies, Inc. All rights reserved.\n * Licensed under the BSD-3 License as modified (the “License”); you may obtain a copy\n * of the license at https://github.com/palantir/blueprint/blob/master/LICENSE\n * and https://github.com/palantir/blueprint/blob/master/PATENTS\n */\n\nimport * as classNames from \"classnames\";\nimport * as moment from \"moment\";\nimport * as React from \"react\";\n\nimport {\n    AbstractComponent,\n    Button,\n    Classes,\n    InputGroup,\n    Intent,\n    IProps,\n    Popover,\n    Position,\n    Utils,\n} from \"@blueprintjs/core\";\n\nimport { DatePicker } from \"./datePicker\";\nimport {\n    getDefaultMaxDate,\n    getDefaultMinDate,\n    IDatePickerBaseProps,\n} from \"./datePickerCore\";\n\nexport interface IDateInputProps extends IDatePickerBaseProps, IProps {\n    /**\n     * Allows the user to clear the selection by clicking the currently selected day.\n     * Passed to `DatePicker` component\n     */\n    canClearSelection?: boolean;\n\n    /**\n     * Whether the calendar popover should close when a date is selected.\n     * @default true\n     */\n    closeOnSelection?: boolean;\n\n    /**\n     * Whether the component should be enabled or disabled.\n     * @default false\n     */\n    disabled?: boolean;\n\n    /**\n     * The default date to be used in the component when uncontrolled.\n     */\n    defaultValue?: Date;\n\n    /**\n     * The format of the date. See options\n     * here: http://momentjs.com/docs/#/displaying/format/\n     * @default \"YYYY-MM-DD\"\n     */\n    format?: string;\n\n    /**\n     * The error message to display when the date selected invalid.\n     * @default \"Invalid date\"\n     */\n    invalidDateMessage?: string;\n\n    /**\n     * Called when the user selects a new valid date through the `DatePicker` or by typing\n     * in the input.\n     */\n    onChange?: (selectedDate: Date) => void;\n\n    /**\n     * Called when the user finishes typing in a new date and the date causes an error state.\n     * If the date is invalid, `new Date(undefined)` will be returned. If the date is out of range,\n     * the out of range date will be returned (`onChange` is not called in this case).\n     */\n    onError?: (errorDate: Date) => void;\n\n    /**\n     * If true, the Popover will open when the user clicks on the input. If false, the Popover will only\n     * open when the calendar icon is clicked.\n     * @default true\n     */\n    openOnFocus?: boolean;\n\n    /**\n     * The error message to display when the date selected is out of range.\n     * @default \"Out of range\"\n     */\n    outOfRangeMessage?: string;\n\n    /**\n     * The position the date popover should appear in relative to the input box.\n     * @default Position.BOTTOM\n     */\n    popoverPosition?: Position;\n\n    /**\n     * The currently selected day. If this prop is present, the component acts in a controlled manner.\n     * To display no date in the input field, pass `null` to the value prop. To display an invalid date error\n     * in the input field, pass `new Date(undefined)` to the value prop.\n     */\n    value?: Date;\n}\n\nexport interface IDateInputState {\n    value?: moment.Moment;\n    valueString?: string;\n    isInputFocused?: boolean;\n    isOpen?: boolean;\n}\n\nexport class DateInput extends AbstractComponent<IDateInputProps, IDateInputState> {\n    public static defaultProps: IDateInputProps = {\n        closeOnSelection: true,\n        disabled: false,\n        format: \"YYYY-MM-DD\",\n        invalidDateMessage: \"Invalid date\",\n        maxDate: getDefaultMaxDate(),\n        minDate: getDefaultMinDate(),\n        openOnFocus: true,\n        outOfRangeMessage: \"Out of range\",\n        popoverPosition: Position.BOTTOM,\n    };\n\n    public displayName = \"Blueprint.DateInput\";\n\n    private inputRef: HTMLElement = null;\n\n    public constructor(props?: IDateInputProps, context?: any) {\n        super(props, context);\n\n        const defaultValue = this.props.defaultValue ? this.fromDateToMoment(this.props.defaultValue) : moment(null);\n\n        this.state = {\n            isInputFocused: false,\n            isOpen: false,\n            value: this.props.value !== undefined ? this.fromDateToMoment(this.props.value) : defaultValue,\n            valueString: null,\n        };\n    }\n\n    public render() {\n        const dateString = this.state.isInputFocused ? this.state.valueString : this.getDateString(this.state.value);\n        const date = this.state.isInputFocused ? moment(this.state.valueString, this.props.format) : this.state.value;\n\n        const popoverContent = (\n            <DatePicker\n                {...this.props}\n                canClearSelection={this.props.canClearSelection}\n                defaultValue={null}\n                onChange={this.handleDateChange}\n                value={this.validAndInRange(this.state.value) ? this.fromMomentToDate(this.state.value) : null}\n            />\n        );\n\n        const inputClasses = classNames({\n            \"pt-intent-danger\": !(this.validAndInRange(date) || this.isNull(date) || dateString === \"\"),\n        });\n\n        const calendarIcon = (\n            <Button\n                className={Classes.MINIMAL}\n                disabled={this.props.disabled}\n                iconName=\"calendar\"\n                intent={Intent.PRIMARY}\n                onClick={this.handleIconClick}\n            />\n        );\n\n        return (\n            <Popover\n                autoFocus={false}\n                content={popoverContent}\n                enforceFocus={false}\n                inline={true}\n                isOpen={this.state.isOpen}\n                onClose={this.handleClosePopover}\n                popoverClassName=\"pt-dateinput-popover\"\n                position={this.props.popoverPosition}\n            >\n                <InputGroup\n                    className={inputClasses}\n                    disabled={this.props.disabled}\n                    inputRef={this.setInputRef}\n                    type=\"text\"\n                    onBlur={this.handleInputBlur}\n                    onChange={this.handleInputChange}\n                    onClick={this.handleInputClick}\n                    onFocus={this.handleInputFocus}\n                    placeholder={this.props.format}\n                    rightElement={calendarIcon}\n                    value={dateString}\n                />\n            </Popover>\n        );\n    }\n\n    public componentWillReceiveProps(nextProps: IDateInputProps) {\n        if (nextProps.value !== this.props.value) {\n            this.setState({ value: this.fromDateToMoment(nextProps.value) });\n        }\n\n        super.componentWillReceiveProps(nextProps);\n    }\n\n    private getDateString = (value: moment.Moment) => {\n        if (this.isNull(value)) {\n            return \"\";\n        }\n        if (value.isValid()) {\n            if (this.dateIsInRange(value)) {\n                return value.format(this.props.format);\n            } else {\n                return this.props.outOfRangeMessage;\n            }\n        }\n        return this.props.invalidDateMessage;\n    }\n\n    private validAndInRange(value: moment.Moment) {\n        return value.isValid() && this.dateIsInRange(value);\n    }\n\n    private isNull(value: moment.Moment) {\n        return value.parsingFlags().nullInput;\n    }\n\n    private dateIsInRange(value: moment.Moment) {\n        return value.isBetween(this.props.minDate, this.props.maxDate, \"day\", \"[]\");\n    }\n\n    private handleClosePopover = () => {\n        this.setState({ isOpen: false });\n    }\n\n    private handleDateChange = (date: Date, hasUserManuallySelectedDate: boolean) => {\n        const momentDate = this.fromDateToMoment(date);\n        const hasMonthChanged = date !== null && !this.isNull(this.state.value) && this.state.value.isValid() &&\n            momentDate.month() !== this.state.value.month();\n        const isOpen = !(this.props.closeOnSelection && hasUserManuallySelectedDate && !hasMonthChanged);\n        if (this.props.value === undefined) {\n            this.setState({ isInputFocused: false, isOpen, value: momentDate });\n        } else {\n            this.setState({ isInputFocused: false, isOpen });\n        }\n        Utils.safeInvoke(this.props.onChange, this.fromMomentToDate(momentDate));\n    }\n\n    private handleIconClick = (e: React.SyntheticEvent<HTMLElement>) => {\n        if (this.state.isOpen) {\n            if (this.inputRef != null) {\n                this.inputRef.blur();\n            }\n        } else {\n            this.setState({ isOpen: true });\n            e.stopPropagation();\n            if (this.inputRef != null) {\n                this.inputRef.focus();\n            }\n        }\n    }\n\n    private handleInputFocus = () => {\n        const valueString = this.isNull(this.state.value) ? \"\" : this.state.value.format(this.props.format);\n\n        if (this.props.openOnFocus) {\n            this.setState({ isInputFocused: true, isOpen: true, valueString });\n        } else {\n            this.setState({ isInputFocused: true, valueString });\n        }\n    }\n\n    private handleInputClick = (e: React.SyntheticEvent<HTMLInputElement>) => {\n        if (this.props.openOnFocus) {\n            e.stopPropagation();\n        }\n    }\n\n    private handleInputChange = (e: React.SyntheticEvent<HTMLInputElement>) => {\n        const valueString = (e.target as HTMLInputElement).value;\n        const value = moment(valueString, this.props.format);\n\n        if (value.isValid() && this.dateIsInRange(value)) {\n            if (this.props.value === undefined) {\n                this.setState({ value, valueString });\n            } else {\n                this.setState({ valueString });\n            }\n            Utils.safeInvoke(this.props.onChange, this.fromMomentToDate(value));\n        } else {\n            this.setState({ valueString });\n        }\n    }\n\n    private handleInputBlur = () => {\n        const valueString = this.state.valueString;\n        let value = moment(valueString, this.props.format);\n        if (valueString !== this.getDateString(this.state.value) && (!value.isValid() || !this.dateIsInRange(value))) {\n\n            if (this.props.value === undefined) {\n                this.setState({ isInputFocused: false, value, valueString: null });\n            } else {\n                this.setState({ isInputFocused: false });\n            }\n\n            if (!value.isValid()) {\n                Utils.safeInvoke(this.props.onError, new Date(undefined));\n            } else if (!this.dateIsInRange(value)) {\n                Utils.safeInvoke(this.props.onError, this.fromMomentToDate(value));\n            } else {\n                Utils.safeInvoke(this.props.onChange, this.fromMomentToDate(value));\n            }\n        } else {\n            this.setState({ isInputFocused: false });\n        }\n    }\n\n    private setInputRef = (el: HTMLElement) => {\n        this.inputRef = el;\n    }\n\n    /**\n     * Translate a moment into a Date object, adjusting the moment timezone into the local one.\n     * This is a no-op unless moment-timezone's setDefault has been called.\n     */\n    private fromMomentToDate = (momentDate: moment.Moment) => {\n        return new Date(\n            momentDate.year(),\n            momentDate.month(),\n            momentDate.date(),\n            momentDate.hours(),\n            momentDate.minutes(),\n            momentDate.seconds(),\n            momentDate.milliseconds(),\n        );\n    }\n\n    /**\n     * Translate a Date object into a moment, adjusting the local timezone into the moment one.\n     * This is a no-op unless moment-timezone's setDefault has been called.\n     */\n    private fromDateToMoment = (date: Date) => {\n        return moment([\n            date.getFullYear(),\n            date.getMonth(),\n            date.getDate(),\n            date.getHours(),\n            date.getMinutes(),\n            date.getSeconds(),\n            date.getMilliseconds(),\n        ]);\n    }\n}\n"],"sourceRoot":"/source/"}
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/dateInput.tsx"],"names":[],"mappings":"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","file":"dateInput.js","sourcesContent":["/*\n * Copyright 2016 Palantir Technologies, Inc. All rights reserved.\n * Licensed under the BSD-3 License as modified (the “License”); you may obtain a copy\n * of the license at https://github.com/palantir/blueprint/blob/master/LICENSE\n * and https://github.com/palantir/blueprint/blob/master/PATENTS\n */\n\nimport * as classNames from \"classnames\";\nimport * as moment from \"moment\";\nimport * as React from \"react\";\n\nimport {\n    AbstractComponent,\n    Button,\n    Classes,\n    InputGroup,\n    Intent,\n    IProps,\n    Popover,\n    Position,\n    Utils,\n} from \"@blueprintjs/core\";\n\nimport { DatePicker } from \"./datePicker\";\nimport {\n    getDefaultMaxDate,\n    getDefaultMinDate,\n    IDatePickerBaseProps,\n} from \"./datePickerCore\";\n\nexport interface IDateInputProps extends IDatePickerBaseProps, IProps {\n    /**\n     * Allows the user to clear the selection by clicking the currently selected day.\n     * Passed to `DatePicker` component\n     */\n    canClearSelection?: boolean;\n\n    /**\n     * Whether the calendar popover should close when a date is selected.\n     * @default true\n     */\n    closeOnSelection?: boolean;\n\n    /**\n     * Whether the component should be enabled or disabled.\n     * @default false\n     */\n    disabled?: boolean;\n\n    /**\n     * The default date to be used in the component when uncontrolled.\n     */\n    defaultValue?: Date;\n\n    /**\n     * The format of the date. See options\n     * here: http://momentjs.com/docs/#/displaying/format/\n     * @default \"YYYY-MM-DD\"\n     */\n    format?: string;\n\n    /**\n     * The error message to display when the date selected invalid.\n     * @default \"Invalid date\"\n     */\n    invalidDateMessage?: string;\n\n    /**\n     * Called when the user selects a new valid date through the `DatePicker` or by typing\n     * in the input.\n     */\n    onChange?: (selectedDate: Date) => void;\n\n    /**\n     * Called when the user finishes typing in a new date and the date causes an error state.\n     * If the date is invalid, `new Date(undefined)` will be returned. If the date is out of range,\n     * the out of range date will be returned (`onChange` is not called in this case).\n     */\n    onError?: (errorDate: Date) => void;\n\n    /**\n     * If true, the Popover will open when the user clicks on the input. If false, the Popover will only\n     * open when the calendar icon is clicked.\n     * @default true\n     */\n    openOnFocus?: boolean;\n\n    /**\n     * The error message to display when the date selected is out of range.\n     * @default \"Out of range\"\n     */\n    outOfRangeMessage?: string;\n\n    /**\n     * The position the date popover should appear in relative to the input box.\n     * @default Position.BOTTOM\n     */\n    popoverPosition?: Position;\n\n    /**\n     * The currently selected day. If this prop is present, the component acts in a controlled manner.\n     * To display no date in the input field, pass `null` to the value prop. To display an invalid date error\n     * in the input field, pass `new Date(undefined)` to the value prop.\n     */\n    value?: Date;\n}\n\nexport interface IDateInputState {\n    value?: moment.Moment;\n    valueString?: string;\n    isInputFocused?: boolean;\n    isOpen?: boolean;\n}\n\nexport class DateInput extends AbstractComponent<IDateInputProps, IDateInputState> {\n    public static defaultProps: IDateInputProps = {\n        closeOnSelection: true,\n        disabled: false,\n        format: \"YYYY-MM-DD\",\n        invalidDateMessage: \"Invalid date\",\n        maxDate: getDefaultMaxDate(),\n        minDate: getDefaultMinDate(),\n        openOnFocus: true,\n        outOfRangeMessage: \"Out of range\",\n        popoverPosition: Position.BOTTOM,\n    };\n\n    public displayName = \"Blueprint.DateInput\";\n\n    private inputRef: HTMLElement = null;\n\n    public constructor(props?: IDateInputProps, context?: any) {\n        super(props, context);\n\n        const defaultValue = this.props.defaultValue ? this.fromDateToMoment(this.props.defaultValue) : moment(null);\n\n        this.state = {\n            isInputFocused: false,\n            isOpen: false,\n            value: this.props.value !== undefined ? this.fromDateToMoment(this.props.value) : defaultValue,\n            valueString: null,\n        };\n    }\n\n    public render() {\n        const dateString = this.state.isInputFocused ? this.state.valueString : this.getDateString(this.state.value);\n        const date = this.state.isInputFocused ? moment(this.state.valueString, this.props.format) : this.state.value;\n\n        const popoverContent = (\n            <DatePicker\n                {...this.props}\n                canClearSelection={this.props.canClearSelection}\n                defaultValue={null}\n                onChange={this.handleDateChange}\n                value={this.validAndInRange(this.state.value) ? this.fromMomentToDate(this.state.value) : null}\n            />\n        );\n\n        const inputClasses = classNames({\n            \"pt-intent-danger\": !(this.validAndInRange(date) || this.isNull(date) || dateString === \"\"),\n        });\n\n        const calendarIcon = (\n            <Button\n                className={Classes.MINIMAL}\n                disabled={this.props.disabled}\n                iconName=\"calendar\"\n                intent={Intent.PRIMARY}\n                onClick={this.handleIconClick}\n            />\n        );\n\n        return (\n            <Popover\n                autoFocus={false}\n                content={popoverContent}\n                enforceFocus={false}\n                inline={true}\n                isOpen={this.state.isOpen}\n                onClose={this.handleClosePopover}\n                popoverClassName=\"pt-dateinput-popover\"\n                position={this.props.popoverPosition}\n            >\n                <InputGroup\n                    className={inputClasses}\n                    disabled={this.props.disabled}\n                    inputRef={this.setInputRef}\n                    type=\"text\"\n                    onBlur={this.handleInputBlur}\n                    onChange={this.handleInputChange}\n                    onClick={this.handleInputClick}\n                    onFocus={this.handleInputFocus}\n                    placeholder={this.props.format}\n                    rightElement={calendarIcon}\n                    value={dateString}\n                />\n            </Popover>\n        );\n    }\n\n    public componentWillReceiveProps(nextProps: IDateInputProps) {\n        if (nextProps.value !== this.props.value) {\n            this.setState({ value: this.fromDateToMoment(nextProps.value) });\n        }\n\n        super.componentWillReceiveProps(nextProps);\n    }\n\n    private getDateString = (value: moment.Moment) => {\n        if (this.isNull(value)) {\n            return \"\";\n        }\n        if (value.isValid()) {\n            if (this.dateIsInRange(value)) {\n                return value.format(this.props.format);\n            } else {\n                return this.props.outOfRangeMessage;\n            }\n        }\n        return this.props.invalidDateMessage;\n    }\n\n    private validAndInRange(value: moment.Moment) {\n        return value.isValid() && this.dateIsInRange(value);\n    }\n\n    private isNull(value: moment.Moment) {\n        return value.parsingFlags().nullInput;\n    }\n\n    private dateIsInRange(value: moment.Moment) {\n        return value.isBetween(this.props.minDate, this.props.maxDate, \"day\", \"[]\");\n    }\n\n    private handleClosePopover = () => {\n        this.setState({ isOpen: false });\n    }\n\n    private handleDateChange = (date: Date, hasUserManuallySelectedDate: boolean) => {\n        const momentDate = this.fromDateToMoment(date);\n        const hasMonthChanged = date !== null && !this.isNull(this.state.value) && this.state.value.isValid() &&\n            momentDate.month() !== this.state.value.month();\n        const isOpen = !(this.props.closeOnSelection && hasUserManuallySelectedDate && !hasMonthChanged);\n        if (this.props.value === undefined) {\n            this.setState({ isInputFocused: false, isOpen, value: momentDate });\n        } else {\n            this.setState({ isInputFocused: false, isOpen });\n        }\n        Utils.safeInvoke(this.props.onChange, this.fromMomentToDate(momentDate));\n    }\n\n    private handleIconClick = (e: React.SyntheticEvent<HTMLElement>) => {\n        if (this.state.isOpen) {\n            if (this.inputRef != null) {\n                this.inputRef.blur();\n            }\n        } else {\n            this.setState({ isOpen: true });\n            e.stopPropagation();\n            if (this.inputRef != null) {\n                this.inputRef.focus();\n            }\n        }\n    }\n\n    private handleInputFocus = () => {\n        const valueString = this.isNull(this.state.value) ? \"\" : this.state.value.format(this.props.format);\n\n        if (this.props.openOnFocus) {\n            this.setState({ isInputFocused: true, isOpen: true, valueString });\n        } else {\n            this.setState({ isInputFocused: true, valueString });\n        }\n    }\n\n    private handleInputClick = (e: React.SyntheticEvent<HTMLInputElement>) => {\n        if (this.props.openOnFocus) {\n            e.stopPropagation();\n        }\n    }\n\n    private handleInputChange = (e: React.SyntheticEvent<HTMLInputElement>) => {\n        const valueString = (e.target as HTMLInputElement).value;\n        const value = moment(valueString, this.props.format);\n\n        if (value.isValid() && this.dateIsInRange(value)) {\n            if (this.props.value === undefined) {\n                this.setState({ value, valueString });\n            } else {\n                this.setState({ valueString });\n            }\n            Utils.safeInvoke(this.props.onChange, this.fromMomentToDate(value));\n        } else {\n            this.setState({ valueString });\n        }\n    }\n\n    private handleInputBlur = () => {\n        const valueString = this.state.valueString;\n        let value = moment(valueString, this.props.format);\n        if (valueString !== this.getDateString(this.state.value) && (!value.isValid() || !this.dateIsInRange(value))) {\n\n            if (this.props.value === undefined) {\n                this.setState({ isInputFocused: false, value, valueString: null });\n            } else {\n                this.setState({ isInputFocused: false });\n            }\n\n            if (!value.isValid()) {\n                Utils.safeInvoke(this.props.onError, new Date(undefined));\n            } else if (!this.dateIsInRange(value)) {\n                Utils.safeInvoke(this.props.onError, this.fromMomentToDate(value));\n            } else {\n                Utils.safeInvoke(this.props.onChange, this.fromMomentToDate(value));\n            }\n        } else {\n            this.setState({ isInputFocused: false });\n        }\n    }\n\n    private setInputRef = (el: HTMLElement) => {\n        this.inputRef = el;\n    }\n\n    /**\n     * Translate a moment into a Date object, adjusting the moment timezone into the local one.\n     * This is a no-op unless moment-timezone's setDefault has been called.\n     */\n    private fromMomentToDate = (momentDate: moment.Moment) => {\n        if (momentDate == null) {\n            return undefined;\n        } else {\n            return new Date(\n                momentDate.year(),\n                momentDate.month(),\n                momentDate.date(),\n                momentDate.hours(),\n                momentDate.minutes(),\n                momentDate.seconds(),\n                momentDate.milliseconds(),\n            );\n        }\n    }\n\n    /**\n     * Translate a Date object into a moment, adjusting the local timezone into the moment one.\n     * This is a no-op unless moment-timezone's setDefault has been called.\n     */\n    private fromDateToMoment = (date: Date) => {\n        if (date == null || typeof date === \"string\") {\n            return moment(date);\n        } else {\n            return moment([\n                date.getFullYear(),\n                date.getMonth(),\n                date.getDate(),\n                date.getHours(),\n                date.getMinutes(),\n                date.getSeconds(),\n                date.getMilliseconds(),\n            ]);\n        }\n    }\n}\n"],"sourceRoot":"/source/"}

@@ -16,7 +16,9 @@ import * as React from "react";

private displayedYearText;
private monthArrow;
private yearArrow;
private containerElement;
private monthArrowElement;
private yearArrowElement;
render(): JSX.Element;
componentDidMount(): void;
componentDidUpdate(): void;
private containerRefHandler;
private monthArrowRefHandler;

@@ -23,0 +25,0 @@ private yearArrowRefHandler;

@@ -23,4 +23,5 @@ /*

_super.apply(this, arguments);
this.monthArrowRefHandler = function (r) { return _this.monthArrow = r; };
this.yearArrowRefHandler = function (r) { return _this.yearArrow = r; };
this.containerRefHandler = function (r) { return _this.containerElement = r; };
this.monthArrowRefHandler = function (r) { return _this.monthArrowElement = r; };
this.yearArrowRefHandler = function (r) { return _this.yearArrowElement = r; };
this.handleMonthSelectChange = function (e) {

@@ -58,3 +59,3 @@ var month = parseInt(e.target.value, 10);

var caretClasses = classNames("pt-icon-standard", "pt-icon-caret-down", Classes.DATEPICKER_CAPTION_CARET);
return (React.createElement("div", {className: Classes.DATEPICKER_CAPTION},
return (React.createElement("div", {className: Classes.DATEPICKER_CAPTION, ref: this.containerRefHandler},
React.createElement("div", {className: Classes.DATEPICKER_CAPTION_SELECT},

@@ -74,7 +75,9 @@ React.createElement("select", {className: Classes.DATEPICKER_MONTH_SELECT, onChange: this.handleMonthSelectChange, value: displayMonth.toString()}, monthOptionElements),

DatePickerCaption.prototype.positionArrows = function () {
// pass our container element to the measureTextWidth utility to ensure
// that we're measuring the width of text as sized within this component.
var textClass = "pt-datepicker-caption-measure";
var monthWidth = Utils.measureTextWidth(this.displayedMonthText, textClass);
this.monthArrow.setAttribute("style", "left:" + monthWidth);
var yearWidth = Utils.measureTextWidth(this.displayedYearText, textClass);
this.yearArrow.setAttribute("style", "left:" + yearWidth);
var monthWidth = Utils.measureTextWidth(this.displayedMonthText, textClass, this.containerElement);
this.monthArrowElement.setAttribute("style", "left:" + monthWidth);
var yearWidth = Utils.measureTextWidth(this.displayedYearText, textClass, this.containerElement);
this.yearArrowElement.setAttribute("style", "left:" + yearWidth);
};

@@ -85,2 +88,2 @@ return DatePickerCaption;

//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/datePickerCaption.tsx"],"names":[],"mappings":"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","file":"datePickerCaption.js","sourcesContent":["/*\n * Copyright 2015 Palantir Technologies, Inc. All rights reserved.\n * Licensed under the BSD-3 License as modified (the “License”); you may obtain a copy\n * of the license at https://github.com/palantir/blueprint/blob/master/LICENSE\n * and https://github.com/palantir/blueprint/blob/master/PATENTS\n */\n\nimport { Utils as BlueprintUtils } from \"@blueprintjs/core\";\nimport * as classNames from \"classnames\";\nimport * as React from \"react\";\n\nimport * as Classes from \"./common/classes\";\nimport * as Utils from \"./common/utils\";\nimport { IDatePickerLocaleUtils } from \"./datePickerCore\";\n\nexport interface IDatePickerCaptionProps {\n    maxDate: Date;\n    minDate: Date;\n    onMonthChange?: (month: number) => void;\n    onYearChange?: (year: number) => void;\n\n    // normally we could extend ReactDayPicker.CaptionElementProps,\n    // but we don't want to introduce a typing dependency, so manually add props here\n    date?: Date;\n    localeUtils?: IDatePickerLocaleUtils;\n    locale?: string;\n    onClick?: React.MouseEventHandler<HTMLElement>;\n}\n\nexport class DatePickerCaption extends React.Component<IDatePickerCaptionProps, {}> {\n    private displayedMonthText: string;\n    private displayedYearText: string;\n\n    private monthArrow: HTMLElement;\n    private yearArrow: HTMLElement;\n\n    public render() {\n        const { date, locale, localeUtils, minDate, maxDate } = this.props;\n        const minYear = minDate.getFullYear();\n        const maxYear = maxDate.getFullYear();\n        const displayMonth = date.getMonth();\n        const displayYear = date.getFullYear();\n\n        // build the list of available months, limiting based on minDate and maxDate as necessary\n        const months = localeUtils.getMonths(locale);\n        const startMonth = (displayYear === minYear) ? minDate.getMonth() : 0;\n        const endMonth = (displayYear === maxYear) ? maxDate.getMonth() + 1 : undefined;\n        const monthOptionElements = months.map((name, i) => {\n            return <option key={i} value={i.toString()}>{name}</option>;\n        }).slice(startMonth, endMonth);\n\n        const years = [minYear];\n        for (let year = minYear + 1; year <= maxYear; ++year) {\n            years.push(year);\n        }\n        const yearOptionElements = years.map((year, i) => {\n            return <option key={i} value={year.toString()}>{year}</option>;\n        });\n\n        this.displayedMonthText = months[displayMonth];\n        this.displayedYearText = displayYear.toString();\n\n        const caretClasses = classNames(\"pt-icon-standard\", \"pt-icon-caret-down\", Classes.DATEPICKER_CAPTION_CARET);\n        return (\n            <div className={Classes.DATEPICKER_CAPTION}>\n                <div className={Classes.DATEPICKER_CAPTION_SELECT}>\n                    <select\n                        className={Classes.DATEPICKER_MONTH_SELECT}\n                        onChange={this.handleMonthSelectChange}\n                        value={displayMonth.toString()}\n                    >\n                        {monthOptionElements}\n                    </select>\n                    <span\n                        className={caretClasses}\n                        ref={this.monthArrowRefHandler}\n                    />\n                </div>\n                <div className={Classes.DATEPICKER_CAPTION_SELECT}>\n                    <select\n                        className={Classes.DATEPICKER_YEAR_SELECT}\n                        onChange={this.handleYearSelectChange}\n                        value={displayYear.toString()}\n                    >\n                        {yearOptionElements}\n                    </select>\n                    <span\n                        className={caretClasses}\n                        ref={this.yearArrowRefHandler}\n                    />\n                </div>\n            </div>\n        );\n    }\n\n    public componentDidMount() {\n        this.positionArrows();\n    }\n\n    public componentDidUpdate() {\n        this.positionArrows();\n    }\n\n    private monthArrowRefHandler = (r: HTMLElement) => this.monthArrow = r;\n    private yearArrowRefHandler = (r: HTMLElement) => this.yearArrow = r;\n\n    private positionArrows() {\n        const textClass = \"pt-datepicker-caption-measure\";\n        const monthWidth = Utils.measureTextWidth(this.displayedMonthText, textClass);\n        this.monthArrow.setAttribute(\"style\", `left:${monthWidth}`);\n\n        const yearWidth = Utils.measureTextWidth(this.displayedYearText, textClass);\n        this.yearArrow.setAttribute(\"style\", `left:${yearWidth}`);\n    }\n\n    private handleMonthSelectChange = (e: React.FormEvent<HTMLSelectElement>) => {\n        const month = parseInt((e.target as HTMLSelectElement).value, 10);\n        BlueprintUtils.safeInvoke(this.props.onMonthChange, month);\n    }\n\n    private handleYearSelectChange = (e: React.FormEvent<HTMLSelectElement>) => {\n        const year = parseInt((e.target as HTMLSelectElement).value, 10);\n        BlueprintUtils.safeInvoke(this.props.onYearChange, year);\n    }\n}\n"],"sourceRoot":"/source/"}
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/datePickerCaption.tsx"],"names":[],"mappings":"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","file":"datePickerCaption.js","sourcesContent":["/*\n * Copyright 2015 Palantir Technologies, Inc. All rights reserved.\n * Licensed under the BSD-3 License as modified (the “License”); you may obtain a copy\n * of the license at https://github.com/palantir/blueprint/blob/master/LICENSE\n * and https://github.com/palantir/blueprint/blob/master/PATENTS\n */\n\nimport { Utils as BlueprintUtils } from \"@blueprintjs/core\";\nimport * as classNames from \"classnames\";\nimport * as React from \"react\";\n\nimport * as Classes from \"./common/classes\";\nimport * as Utils from \"./common/utils\";\nimport { IDatePickerLocaleUtils } from \"./datePickerCore\";\n\nexport interface IDatePickerCaptionProps {\n    maxDate: Date;\n    minDate: Date;\n    onMonthChange?: (month: number) => void;\n    onYearChange?: (year: number) => void;\n\n    // normally we could extend ReactDayPicker.CaptionElementProps,\n    // but we don't want to introduce a typing dependency, so manually add props here\n    date?: Date;\n    localeUtils?: IDatePickerLocaleUtils;\n    locale?: string;\n    onClick?: React.MouseEventHandler<HTMLElement>;\n}\n\nexport class DatePickerCaption extends React.Component<IDatePickerCaptionProps, {}> {\n    private displayedMonthText: string;\n    private displayedYearText: string;\n\n    private containerElement: HTMLElement;\n    private monthArrowElement: HTMLElement;\n    private yearArrowElement: HTMLElement;\n\n    public render() {\n        const { date, locale, localeUtils, minDate, maxDate } = this.props;\n        const minYear = minDate.getFullYear();\n        const maxYear = maxDate.getFullYear();\n        const displayMonth = date.getMonth();\n        const displayYear = date.getFullYear();\n\n        // build the list of available months, limiting based on minDate and maxDate as necessary\n        const months = localeUtils.getMonths(locale);\n        const startMonth = (displayYear === minYear) ? minDate.getMonth() : 0;\n        const endMonth = (displayYear === maxYear) ? maxDate.getMonth() + 1 : undefined;\n        const monthOptionElements = months.map((name, i) => {\n            return <option key={i} value={i.toString()}>{name}</option>;\n        }).slice(startMonth, endMonth);\n\n        const years = [minYear];\n        for (let year = minYear + 1; year <= maxYear; ++year) {\n            years.push(year);\n        }\n        const yearOptionElements = years.map((year, i) => {\n            return <option key={i} value={year.toString()}>{year}</option>;\n        });\n\n        this.displayedMonthText = months[displayMonth];\n        this.displayedYearText = displayYear.toString();\n\n        const caretClasses = classNames(\"pt-icon-standard\", \"pt-icon-caret-down\", Classes.DATEPICKER_CAPTION_CARET);\n        return (\n            <div\n                className={Classes.DATEPICKER_CAPTION}\n                ref={this.containerRefHandler}\n            >\n                <div className={Classes.DATEPICKER_CAPTION_SELECT}>\n                    <select\n                        className={Classes.DATEPICKER_MONTH_SELECT}\n                        onChange={this.handleMonthSelectChange}\n                        value={displayMonth.toString()}\n                    >\n                        {monthOptionElements}\n                    </select>\n                    <span\n                        className={caretClasses}\n                        ref={this.monthArrowRefHandler}\n                    />\n                </div>\n                <div className={Classes.DATEPICKER_CAPTION_SELECT}>\n                    <select\n                        className={Classes.DATEPICKER_YEAR_SELECT}\n                        onChange={this.handleYearSelectChange}\n                        value={displayYear.toString()}\n                    >\n                        {yearOptionElements}\n                    </select>\n                    <span\n                        className={caretClasses}\n                        ref={this.yearArrowRefHandler}\n                    />\n                </div>\n            </div>\n        );\n    }\n\n    public componentDidMount() {\n        this.positionArrows();\n    }\n\n    public componentDidUpdate() {\n        this.positionArrows();\n    }\n\n    private containerRefHandler = (r: HTMLElement) => this.containerElement = r;\n    private monthArrowRefHandler = (r: HTMLElement) => this.monthArrowElement = r;\n    private yearArrowRefHandler = (r: HTMLElement) => this.yearArrowElement = r;\n\n    private positionArrows() {\n        // pass our container element to the measureTextWidth utility to ensure\n        // that we're measuring the width of text as sized within this component.\n        const textClass = \"pt-datepicker-caption-measure\";\n        const monthWidth = Utils.measureTextWidth(this.displayedMonthText, textClass, this.containerElement);\n        this.monthArrowElement.setAttribute(\"style\", `left:${monthWidth}`);\n\n        const yearWidth = Utils.measureTextWidth(this.displayedYearText, textClass, this.containerElement);\n        this.yearArrowElement.setAttribute(\"style\", `left:${yearWidth}`);\n    }\n\n    private handleMonthSelectChange = (e: React.FormEvent<HTMLSelectElement>) => {\n        const month = parseInt((e.target as HTMLSelectElement).value, 10);\n        BlueprintUtils.safeInvoke(this.props.onMonthChange, month);\n    }\n\n    private handleYearSelectChange = (e: React.FormEvent<HTMLSelectElement>) => {\n        const year = parseInt((e.target as HTMLSelectElement).value, 10);\n        BlueprintUtils.safeInvoke(this.props.onYearChange, year);\n    }\n}\n"],"sourceRoot":"/source/"}

@@ -128,2 +128,11 @@ /*

}
// if the initial month is the last month of the picker's
// allowable range, the react-day-picker library will show
// the max month on the left and the *min* month on the right.
// subtracting one avoids that weird, wraparound state (#289).
var initialMonthEqualsMinMonth = initialMonth.getMonth() === props.minDate.getMonth();
var initalMonthEqualsMaxMonth = initialMonth.getMonth() === props.maxDate.getMonth();
if (!initialMonthEqualsMinMonth && initalMonthEqualsMaxMonth) {
initialMonth.setMonth(initialMonth.getMonth() - 1);
}
this.state = {

@@ -309,2 +318,2 @@ displayMonth: initialMonth.getMonth(),

//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/dateRangePicker.tsx"],"names":[],"mappings":"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","file":"dateRangePicker.js","sourcesContent":["/*\n * Copyright 2016 Palantir Technologies, Inc. All rights reserved.\n * Licensed under the BSD-3 License as modified (the “License”); you may obtain a copy\n * of the license at https://github.com/palantir/blueprint/blob/master/LICENSE\n * and https://github.com/palantir/blueprint/blob/master/PATENTS\n */\n\nimport { AbstractComponent, Classes, IProps, Menu, MenuItem, Utils } from \"@blueprintjs/core\";\nimport * as classNames from \"classnames\";\nimport * as React from \"react\";\nimport * as DayPicker from \"react-day-picker\";\n\nimport * as DateClasses from \"./common/classes\";\nimport * as DateUtils from \"./common/dateUtils\";\nimport { DateRange } from \"./common/dateUtils\";\nimport * as Errors from \"./common/errors\";\n\nimport { DatePickerCaption } from \"./datePickerCaption\";\nimport {\n    combineModifiers,\n    getDefaultMaxDate,\n    getDefaultMinDate,\n    IDatePickerBaseProps,\n    IDatePickerDayModifiers,\n    IDatePickerModifiers,\n    SELECTED_RANGE_MODIFIER,\n} from \"./datePickerCore\";\n\nexport interface IDateRangeShortcut {\n    label: string;\n    dateRange: DateRange;\n}\n\nexport interface IDateRangePickerProps extends IDatePickerBaseProps, IProps {\n    /**\n     * Whether the start and end dates of the range can be the same day.\n     * If `true`, clicking a selected date will create a one-day range.\n     * If `false`, clicking a selected date will clear the selection.\n     * @default false\n     */\n    allowSingleDayRange?: boolean;\n\n    /**\n     * Initial DateRange the calendar will display as selected.\n     * This should not be set if `value` is set.\n     */\n    defaultValue?: DateRange;\n\n    /**\n     * Called when the user selects a day.\n     * If no days are selected, it will pass `[null, null]`.\n     * If a start date is selected but not an end date, it will pass `[selectedDate, null]`.\n     * If both a start and end date are selected, it will pass `[startDate, endDate]`.\n     */\n    onChange?: (selectedDates: DateRange) => void;\n\n    /**\n     * Whether shortcuts to quickly select a range of dates are displayed or not.\n     * If `true`, preset shortcuts will be displayed.\n     * If `false`, no shortcuts will be displayed.\n     * If an array, the custom shortcuts provided will be displayed.\n     * @default true\n     */\n    shortcuts?: boolean | IDateRangeShortcut[];\n\n    /**\n     * The currently selected DateRange.\n     * If this prop is present, the component acts in a controlled manner.\n     */\n    value?: DateRange;\n}\n\nexport interface IDateRangePickerState {\n    displayMonth?: number;\n    displayYear?: number;\n    value?: DateRange;\n}\n\nexport class DateRangePicker\n    extends AbstractComponent<IDateRangePickerProps, IDateRangePickerState> {\n\n    public static defaultProps: IDateRangePickerProps = {\n        allowSingleDayRange: false,\n        maxDate: getDefaultMaxDate(),\n        minDate: getDefaultMinDate(),\n        shortcuts: true,\n    };\n\n    public displayName = \"Blueprint.DateRangePicker\";\n\n    // these will get merged with the user's own\n    private modifiers: IDatePickerModifiers = {\n        [SELECTED_RANGE_MODIFIER]: (day) => {\n            const { value } = this.state;\n            return value[0] != null && value[1] != null && DateUtils.isDayInRange(day, value, true);\n        },\n        [`${SELECTED_RANGE_MODIFIER}-start`]: (day) => DateUtils.areSameDay(this.state.value[0], day),\n        [`${SELECTED_RANGE_MODIFIER}-end`]: (day) => DateUtils.areSameDay(this.state.value[1], day),\n    };\n\n    // these will get passed directly to DayPicker\n    private states = {\n        disabledDays: (day: Date) => !DateUtils.isDayInRange(day, [this.props.minDate, this.props.maxDate]),\n        selectedDays: (day: Date) => {\n            const [start, end] = this.state.value;\n            return DateUtils.areSameDay(start, day) || DateUtils.areSameDay(end, day);\n        },\n    };\n\n    public constructor(props?: IDateRangePickerProps, context?: any) {\n        super(props, context);\n\n        let value: DateRange = [null, null];\n        if (props.value != null) {\n            value = props.value;\n        } else if (props.defaultValue != null) {\n            value = props.defaultValue;\n        }\n\n        let initialMonth: Date;\n        const today = new Date();\n        if (props.initialMonth != null) {\n            initialMonth = props.initialMonth;\n        } else if (value[0] != null) {\n            initialMonth = value[0];\n        } else if (DateUtils.isDayInRange(today, [props.minDate, props.maxDate])) {\n            initialMonth = today;\n        } else {\n            initialMonth = DateUtils.getDateBetween([props.minDate, props.maxDate]);\n        }\n\n        this.state = {\n            displayMonth: initialMonth.getMonth(),\n            displayYear: initialMonth.getFullYear(),\n            value,\n        };\n    }\n\n    public render() {\n        const modifiers = combineModifiers(this.modifiers, this.props.modifiers);\n        const { className, locale, localeUtils, maxDate, minDate } = this.props;\n        const { displayMonth, displayYear } = this.state;\n        const isShowingOneMonth = DateUtils.areSameMonth(this.props.minDate, this.props.maxDate);\n\n        return (\n            <div className={classNames(DateClasses.DATEPICKER, DateClasses.DATERANGEPICKER, className)}>\n                {this.maybeRenderShortcuts()}\n                <DayPicker\n                    canChangeMonth={true}\n                    captionElement={this.renderCaption()}\n                    disabledDays={this.states.disabledDays}\n                    enableOutsideDays={true}\n                    fromMonth={minDate}\n                    initialMonth={new Date(displayYear, displayMonth)}\n                    locale={locale}\n                    localeUtils={localeUtils}\n                    modifiers={modifiers}\n                    numberOfMonths={isShowingOneMonth ? 1 : 2}\n                    onDayClick={this.handleDayClick}\n                    onMonthChange={this.handleMonthChange}\n                    selectedDays={this.states.selectedDays}\n                    toMonth={maxDate}\n                />\n            </div>\n        );\n    }\n\n    public componentWillReceiveProps(nextProps: IDateRangePickerProps) {\n        super.componentWillReceiveProps(nextProps);\n\n        const { displayMonth, displayYear } = this.state;\n        const nextState = getStateChange(this.props.value, nextProps.value, displayMonth, displayYear);\n        this.setState(nextState);\n    }\n\n    protected validateProps(props: IDateRangePickerProps) {\n        const { defaultValue, initialMonth, maxDate, minDate, value } = props;\n        const dateRange: DateRange = [minDate, maxDate];\n\n        if (defaultValue != null && !DateUtils.isDayRangeInRange(defaultValue, dateRange)) {\n            throw new Error(Errors.DATERANGEPICKER_DEFAULT_VALUE_INVALID);\n        }\n\n        if (initialMonth != null && !DateUtils.isMonthInRange(initialMonth, dateRange)) {\n            throw new Error(Errors.DATERANGEPICKER_INITIAL_MONTH_INVALID);\n        }\n\n        if (defaultValue != null && defaultValue[0] == null && defaultValue[1] != null\n            || value != null && value[0] == null && value[1] != null) {\n            throw new Error(Errors.DATERANGEPICKER_INVALID_DATE_RANGE);\n        }\n\n        if (maxDate != null\n                && minDate != null\n                && maxDate < minDate\n                && !DateUtils.areSameDay(maxDate, minDate)) {\n            throw new Error(Errors.DATERANGEPICKER_MAX_DATE_INVALID);\n        }\n\n        if (value != null && !DateUtils.isDayRangeInRange(value, dateRange)) {\n            throw new Error(Errors.DATERANGEPICKER_VALUE_INVALID);\n        }\n    }\n\n    private maybeRenderShortcuts() {\n        const propsShortcuts = this.props.shortcuts;\n        if (propsShortcuts == null || propsShortcuts === false) {\n            return undefined;\n        }\n\n        const shortcuts = typeof propsShortcuts === \"boolean\" ? createDefaultShortcuts() : propsShortcuts;\n        const shortcutElements = shortcuts.map((s, i) => (\n            <MenuItem\n                className={Classes.POPOVER_DISMISS_OVERRIDE}\n                key={i}\n                onClick={this.getShorcutClickHandler(s.dateRange)}\n                text={s.label}\n            />\n        ));\n\n        return (\n            <Menu className={DateClasses.DATERANGEPICKER_SHORTCUTS}>\n                {shortcutElements}\n            </Menu>\n        );\n    }\n\n    private renderCaption() {\n        const { maxDate, minDate } = this.props;\n        return (\n            <DatePickerCaption\n                maxDate={maxDate}\n                minDate={minDate}\n                onMonthChange={this.handleMonthSelectChange}\n                onYearChange={this.handleYearSelectChange}\n            />\n        );\n    }\n\n    private handleDayClick = (_e: React.SyntheticEvent<HTMLElement>, day: Date, modifiers: IDatePickerDayModifiers) => {\n        if (modifiers.disabled) {\n            // rerender base component to get around bug where you can navigate past bounds by clicking days\n            this.forceUpdate();\n            return;\n        }\n\n        const [start, end] = this.state.value;\n        let nextValue: DateRange;\n\n        if (start == null && end == null) {\n            nextValue = [day, null];\n        } else if (start != null && end == null) {\n            nextValue = this.createRange(day, start);\n        } else if (start == null && end != null) {\n            nextValue = this.createRange(day, end);\n        } else {\n            const isStart = DateUtils.areSameDay(start, day);\n            const isEnd = DateUtils.areSameDay(end, day);\n            if (isStart && isEnd) {\n                nextValue = [null, null];\n            } else if (isStart) {\n                nextValue = [null, end];\n            } else if (isEnd) {\n                nextValue = [start, null];\n            } else {\n                nextValue = [day, null];\n            }\n        }\n\n        this.handleNextState(nextValue);\n    }\n\n    private createRange(a: Date, b: Date): DateRange {\n        // clicking the same date again will clear it\n        if (!this.props.allowSingleDayRange && DateUtils.areSameDay(a, b)) {\n            return [null, null];\n        }\n        return a < b ? [a, b] : [b, a];\n    }\n\n    private getShorcutClickHandler(nextValue: DateRange) {\n        return () => this.handleNextState(nextValue);\n    }\n\n    private handleNextState(nextValue: DateRange) {\n        const { displayMonth, displayYear, value } = this.state;\n        const nextState = getStateChange(value, nextValue, displayMonth, displayYear);\n\n        if (this.props.value == null) {\n            this.setState(nextState);\n        }\n\n        Utils.safeInvoke(this.props.onChange, nextValue);\n    }\n\n    private handleMonthChange = (newDate: Date) => {\n        const displayMonth = newDate.getMonth();\n        const displayYear = newDate.getFullYear();\n        this.setState({ displayMonth, displayYear });\n    }\n\n    private handleMonthSelectChange = (displayMonth: number) => {\n        this.setState({ displayMonth });\n    }\n\n    private handleYearSelectChange = (displayYear: number) => {\n        const { minDate, maxDate } = this.props;\n        // we display two months, so we want our display max date to be one month earlier than our real max date\n        const adjustedMaxDate = DateUtils.clone(maxDate);\n        adjustedMaxDate.setMonth(adjustedMaxDate.getMonth() - 1);\n\n        const minYear = minDate.getFullYear();\n        const maxYear = adjustedMaxDate.getFullYear();\n        const minMonth = minDate.getMonth();\n        const maxMonth = adjustedMaxDate.getMonth();\n\n        let { displayMonth } = this.state;\n\n        if (displayYear === minYear && displayMonth < minMonth) {\n            displayMonth = minMonth;\n        } else if (displayYear === maxYear && displayMonth > maxMonth) {\n            displayMonth = maxMonth;\n        }\n\n        this.setState({ displayMonth, displayYear });\n    }\n}\n\nfunction getStateChange(value: DateRange,\n                        nextValue: DateRange,\n                        currMonth: number,\n                        currYear: number): IDateRangePickerState {\n    let returnVal: IDateRangePickerState;\n\n    if (value != null && nextValue == null) {\n        returnVal = { value: [null, null] };\n    } else if (value == null && nextValue != null) {\n        // calendar displays first month of the new start date if provided\n        if (nextValue[0] != null) {\n            returnVal = {\n                displayMonth: nextValue[0].getMonth(),\n                displayYear: nextValue[0].getFullYear(),\n                value: nextValue,\n            };\n        } else {\n            returnVal = { value: nextValue };\n        }\n    } else if (value != null && nextValue != null) {\n        const [valueStart, valueEnd] = value;\n        const [nextValueStart, nextValueEnd] = nextValue;\n\n        if (nextValueStart == null) {\n           returnVal = { value: nextValue };\n        } else {\n            const hasEndDateChanged = !DateUtils.areSameDay(valueEnd, nextValueEnd);\n            const isStartDateNowEndDate = DateUtils.areSameDay(valueStart, nextValueEnd);\n\n            const newDate = hasEndDateChanged && !isStartDateNowEndDate && nextValueEnd != null ?\n                nextValueEnd :\n                nextValueStart;\n            returnVal = {\n                displayMonth: newDate.getMonth(),\n                displayYear: newDate.getFullYear(),\n                value: nextValue,\n            };\n        }\n    } else {\n        returnVal = {};\n    }\n\n    // adjust calendar display month as little as possible\n    const { displayMonth, displayYear } = returnVal;\n    if (displayMonth != null && displayYear != null) {\n        const nextMonth = getNextMonth([currMonth, currYear]);\n        const monthToDisplay: DisplayMonth = [displayMonth, displayYear];\n        if (areSameMonth(nextMonth, monthToDisplay)) {\n            returnVal.displayMonth = currMonth;\n            returnVal.displayYear = currYear;\n        } else if (areSameMonth(getNextMonth(nextMonth), monthToDisplay)) {\n           returnVal.displayMonth = nextMonth[0];\n           returnVal.displayYear = nextMonth[1];\n        }\n    }\n\n    return returnVal;\n}\n\ntype DisplayMonth = [number, number];\n\nfunction getNextMonth([month, year]: DisplayMonth): DisplayMonth {\n    return month === 12 ? [0, year + 1] : [month + 1, year];\n}\n\nfunction areSameMonth([month, year]: DisplayMonth, [month2, year2]: DisplayMonth) {\n    return month === month2 && year === year2;\n}\n\nfunction createShortcut(label: string, dateRange: DateRange): IDateRangeShortcut {\n    return { dateRange, label };\n}\n\nfunction createDefaultShortcuts() {\n    const today = new Date();\n    const makeDate = (action: (d: Date) => void) => {\n        const returnVal = DateUtils.clone(today);\n        action(returnVal);\n        returnVal.setDate(returnVal.getDate() + 1);\n        return returnVal;\n    };\n\n    const oneWeekAgo = makeDate((d) => d.setDate(d.getDate() - 7));\n    const oneMonthAgo = makeDate((d) => d.setMonth(d.getMonth() - 1));\n    const threeMonthsAgo = makeDate((d) => d.setMonth(d.getMonth() - 3));\n    const sixMonthsAgo = makeDate((d) => d.setMonth(d.getMonth() - 6));\n    const oneYearAgo = makeDate((d) => d.setFullYear(d.getFullYear() - 1));\n    const twoYearsAgo = makeDate((d) => d.setFullYear(d.getFullYear() - 2));\n\n    return [\n        createShortcut(\"Past Week\", [oneWeekAgo, today]),\n        createShortcut(\"Past Month\", [oneMonthAgo, today]),\n        createShortcut(\"Past 3 Months\", [threeMonthsAgo, today]),\n        createShortcut(\"Past 6 Months\", [sixMonthsAgo, today]),\n        createShortcut(\"Past Year\", [oneYearAgo, today]),\n        createShortcut(\"Past 2 Years\", [twoYearsAgo, today]),\n    ];\n}\n\nexport const DateRangePickerFactory = React.createFactory(DateRangePicker);\n"],"sourceRoot":"/source/"}
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/dateRangePicker.tsx"],"names":[],"mappings":"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","file":"dateRangePicker.js","sourcesContent":["/*\n * Copyright 2016 Palantir Technologies, Inc. All rights reserved.\n * Licensed under the BSD-3 License as modified (the “License”); you may obtain a copy\n * of the license at https://github.com/palantir/blueprint/blob/master/LICENSE\n * and https://github.com/palantir/blueprint/blob/master/PATENTS\n */\n\nimport { AbstractComponent, Classes, IProps, Menu, MenuItem, Utils } from \"@blueprintjs/core\";\nimport * as classNames from \"classnames\";\nimport * as React from \"react\";\nimport * as DayPicker from \"react-day-picker\";\n\nimport * as DateClasses from \"./common/classes\";\nimport * as DateUtils from \"./common/dateUtils\";\nimport { DateRange } from \"./common/dateUtils\";\nimport * as Errors from \"./common/errors\";\n\nimport { DatePickerCaption } from \"./datePickerCaption\";\nimport {\n    combineModifiers,\n    getDefaultMaxDate,\n    getDefaultMinDate,\n    IDatePickerBaseProps,\n    IDatePickerDayModifiers,\n    IDatePickerModifiers,\n    SELECTED_RANGE_MODIFIER,\n} from \"./datePickerCore\";\n\nexport interface IDateRangeShortcut {\n    label: string;\n    dateRange: DateRange;\n}\n\nexport interface IDateRangePickerProps extends IDatePickerBaseProps, IProps {\n    /**\n     * Whether the start and end dates of the range can be the same day.\n     * If `true`, clicking a selected date will create a one-day range.\n     * If `false`, clicking a selected date will clear the selection.\n     * @default false\n     */\n    allowSingleDayRange?: boolean;\n\n    /**\n     * Initial DateRange the calendar will display as selected.\n     * This should not be set if `value` is set.\n     */\n    defaultValue?: DateRange;\n\n    /**\n     * Called when the user selects a day.\n     * If no days are selected, it will pass `[null, null]`.\n     * If a start date is selected but not an end date, it will pass `[selectedDate, null]`.\n     * If both a start and end date are selected, it will pass `[startDate, endDate]`.\n     */\n    onChange?: (selectedDates: DateRange) => void;\n\n    /**\n     * Whether shortcuts to quickly select a range of dates are displayed or not.\n     * If `true`, preset shortcuts will be displayed.\n     * If `false`, no shortcuts will be displayed.\n     * If an array, the custom shortcuts provided will be displayed.\n     * @default true\n     */\n    shortcuts?: boolean | IDateRangeShortcut[];\n\n    /**\n     * The currently selected DateRange.\n     * If this prop is present, the component acts in a controlled manner.\n     */\n    value?: DateRange;\n}\n\nexport interface IDateRangePickerState {\n    displayMonth?: number;\n    displayYear?: number;\n    value?: DateRange;\n}\n\nexport class DateRangePicker\n    extends AbstractComponent<IDateRangePickerProps, IDateRangePickerState> {\n\n    public static defaultProps: IDateRangePickerProps = {\n        allowSingleDayRange: false,\n        maxDate: getDefaultMaxDate(),\n        minDate: getDefaultMinDate(),\n        shortcuts: true,\n    };\n\n    public displayName = \"Blueprint.DateRangePicker\";\n\n    // these will get merged with the user's own\n    private modifiers: IDatePickerModifiers = {\n        [SELECTED_RANGE_MODIFIER]: (day) => {\n            const { value } = this.state;\n            return value[0] != null && value[1] != null && DateUtils.isDayInRange(day, value, true);\n        },\n        [`${SELECTED_RANGE_MODIFIER}-start`]: (day) => DateUtils.areSameDay(this.state.value[0], day),\n        [`${SELECTED_RANGE_MODIFIER}-end`]: (day) => DateUtils.areSameDay(this.state.value[1], day),\n    };\n\n    // these will get passed directly to DayPicker\n    private states = {\n        disabledDays: (day: Date) => !DateUtils.isDayInRange(day, [this.props.minDate, this.props.maxDate]),\n        selectedDays: (day: Date) => {\n            const [start, end] = this.state.value;\n            return DateUtils.areSameDay(start, day) || DateUtils.areSameDay(end, day);\n        },\n    };\n\n    public constructor(props?: IDateRangePickerProps, context?: any) {\n        super(props, context);\n\n        let value: DateRange = [null, null];\n        if (props.value != null) {\n            value = props.value;\n        } else if (props.defaultValue != null) {\n            value = props.defaultValue;\n        }\n\n        let initialMonth: Date;\n        const today = new Date();\n\n        if (props.initialMonth != null) {\n            initialMonth = props.initialMonth;\n        } else if (value[0] != null) {\n            initialMonth = value[0];\n        } else if (DateUtils.isDayInRange(today, [props.minDate, props.maxDate])) {\n            initialMonth = today;\n        } else {\n            initialMonth = DateUtils.getDateBetween([props.minDate, props.maxDate]);\n        }\n\n        // if the initial month is the last month of the picker's\n        // allowable range, the react-day-picker library will show\n        // the max month on the left and the *min* month on the right.\n        // subtracting one avoids that weird, wraparound state (#289).\n        const initialMonthEqualsMinMonth = initialMonth.getMonth() === props.minDate.getMonth();\n        const initalMonthEqualsMaxMonth = initialMonth.getMonth() === props.maxDate.getMonth();\n        if (!initialMonthEqualsMinMonth && initalMonthEqualsMaxMonth) {\n            initialMonth.setMonth(initialMonth.getMonth() - 1);\n        }\n\n        this.state = {\n            displayMonth: initialMonth.getMonth(),\n            displayYear: initialMonth.getFullYear(),\n            value,\n        };\n    }\n\n    public render() {\n        const modifiers = combineModifiers(this.modifiers, this.props.modifiers);\n        const { className, locale, localeUtils, maxDate, minDate } = this.props;\n        const { displayMonth, displayYear } = this.state;\n        const isShowingOneMonth = DateUtils.areSameMonth(this.props.minDate, this.props.maxDate);\n\n        return (\n            <div className={classNames(DateClasses.DATEPICKER, DateClasses.DATERANGEPICKER, className)}>\n                {this.maybeRenderShortcuts()}\n                <DayPicker\n                    canChangeMonth={true}\n                    captionElement={this.renderCaption()}\n                    disabledDays={this.states.disabledDays}\n                    enableOutsideDays={true}\n                    fromMonth={minDate}\n                    initialMonth={new Date(displayYear, displayMonth)}\n                    locale={locale}\n                    localeUtils={localeUtils}\n                    modifiers={modifiers}\n                    numberOfMonths={isShowingOneMonth ? 1 : 2}\n                    onDayClick={this.handleDayClick}\n                    onMonthChange={this.handleMonthChange}\n                    selectedDays={this.states.selectedDays}\n                    toMonth={maxDate}\n                />\n            </div>\n        );\n    }\n\n    public componentWillReceiveProps(nextProps: IDateRangePickerProps) {\n        super.componentWillReceiveProps(nextProps);\n\n        const { displayMonth, displayYear } = this.state;\n        const nextState = getStateChange(this.props.value, nextProps.value, displayMonth, displayYear);\n        this.setState(nextState);\n    }\n\n    protected validateProps(props: IDateRangePickerProps) {\n        const { defaultValue, initialMonth, maxDate, minDate, value } = props;\n        const dateRange: DateRange = [minDate, maxDate];\n\n        if (defaultValue != null && !DateUtils.isDayRangeInRange(defaultValue, dateRange)) {\n            throw new Error(Errors.DATERANGEPICKER_DEFAULT_VALUE_INVALID);\n        }\n\n        if (initialMonth != null && !DateUtils.isMonthInRange(initialMonth, dateRange)) {\n            throw new Error(Errors.DATERANGEPICKER_INITIAL_MONTH_INVALID);\n        }\n\n        if (defaultValue != null && defaultValue[0] == null && defaultValue[1] != null\n            || value != null && value[0] == null && value[1] != null) {\n            throw new Error(Errors.DATERANGEPICKER_INVALID_DATE_RANGE);\n        }\n\n        if (maxDate != null\n                && minDate != null\n                && maxDate < minDate\n                && !DateUtils.areSameDay(maxDate, minDate)) {\n            throw new Error(Errors.DATERANGEPICKER_MAX_DATE_INVALID);\n        }\n\n        if (value != null && !DateUtils.isDayRangeInRange(value, dateRange)) {\n            throw new Error(Errors.DATERANGEPICKER_VALUE_INVALID);\n        }\n    }\n\n    private maybeRenderShortcuts() {\n        const propsShortcuts = this.props.shortcuts;\n        if (propsShortcuts == null || propsShortcuts === false) {\n            return undefined;\n        }\n\n        const shortcuts = typeof propsShortcuts === \"boolean\" ? createDefaultShortcuts() : propsShortcuts;\n        const shortcutElements = shortcuts.map((s, i) => (\n            <MenuItem\n                className={Classes.POPOVER_DISMISS_OVERRIDE}\n                key={i}\n                onClick={this.getShorcutClickHandler(s.dateRange)}\n                text={s.label}\n            />\n        ));\n\n        return (\n            <Menu className={DateClasses.DATERANGEPICKER_SHORTCUTS}>\n                {shortcutElements}\n            </Menu>\n        );\n    }\n\n    private renderCaption() {\n        const { maxDate, minDate } = this.props;\n        return (\n            <DatePickerCaption\n                maxDate={maxDate}\n                minDate={minDate}\n                onMonthChange={this.handleMonthSelectChange}\n                onYearChange={this.handleYearSelectChange}\n            />\n        );\n    }\n\n    private handleDayClick = (_e: React.SyntheticEvent<HTMLElement>, day: Date, modifiers: IDatePickerDayModifiers) => {\n        if (modifiers.disabled) {\n            // rerender base component to get around bug where you can navigate past bounds by clicking days\n            this.forceUpdate();\n            return;\n        }\n\n        const [start, end] = this.state.value;\n        let nextValue: DateRange;\n\n        if (start == null && end == null) {\n            nextValue = [day, null];\n        } else if (start != null && end == null) {\n            nextValue = this.createRange(day, start);\n        } else if (start == null && end != null) {\n            nextValue = this.createRange(day, end);\n        } else {\n            const isStart = DateUtils.areSameDay(start, day);\n            const isEnd = DateUtils.areSameDay(end, day);\n            if (isStart && isEnd) {\n                nextValue = [null, null];\n            } else if (isStart) {\n                nextValue = [null, end];\n            } else if (isEnd) {\n                nextValue = [start, null];\n            } else {\n                nextValue = [day, null];\n            }\n        }\n\n        this.handleNextState(nextValue);\n    }\n\n    private createRange(a: Date, b: Date): DateRange {\n        // clicking the same date again will clear it\n        if (!this.props.allowSingleDayRange && DateUtils.areSameDay(a, b)) {\n            return [null, null];\n        }\n        return a < b ? [a, b] : [b, a];\n    }\n\n    private getShorcutClickHandler(nextValue: DateRange) {\n        return () => this.handleNextState(nextValue);\n    }\n\n    private handleNextState(nextValue: DateRange) {\n        const { displayMonth, displayYear, value } = this.state;\n        const nextState = getStateChange(value, nextValue, displayMonth, displayYear);\n\n        if (this.props.value == null) {\n            this.setState(nextState);\n        }\n\n        Utils.safeInvoke(this.props.onChange, nextValue);\n    }\n\n    private handleMonthChange = (newDate: Date) => {\n        const displayMonth = newDate.getMonth();\n        const displayYear = newDate.getFullYear();\n        this.setState({ displayMonth, displayYear });\n    }\n\n    private handleMonthSelectChange = (displayMonth: number) => {\n        this.setState({ displayMonth });\n    }\n\n    private handleYearSelectChange = (displayYear: number) => {\n        const { minDate, maxDate } = this.props;\n        // we display two months, so we want our display max date to be one month earlier than our real max date\n        const adjustedMaxDate = DateUtils.clone(maxDate);\n        adjustedMaxDate.setMonth(adjustedMaxDate.getMonth() - 1);\n\n        const minYear = minDate.getFullYear();\n        const maxYear = adjustedMaxDate.getFullYear();\n        const minMonth = minDate.getMonth();\n        const maxMonth = adjustedMaxDate.getMonth();\n\n        let { displayMonth } = this.state;\n\n        if (displayYear === minYear && displayMonth < minMonth) {\n            displayMonth = minMonth;\n        } else if (displayYear === maxYear && displayMonth > maxMonth) {\n            displayMonth = maxMonth;\n        }\n\n        this.setState({ displayMonth, displayYear });\n    }\n}\n\nfunction getStateChange(value: DateRange,\n                        nextValue: DateRange,\n                        currMonth: number,\n                        currYear: number): IDateRangePickerState {\n    let returnVal: IDateRangePickerState;\n\n    if (value != null && nextValue == null) {\n        returnVal = { value: [null, null] };\n    } else if (value == null && nextValue != null) {\n        // calendar displays first month of the new start date if provided\n        if (nextValue[0] != null) {\n            returnVal = {\n                displayMonth: nextValue[0].getMonth(),\n                displayYear: nextValue[0].getFullYear(),\n                value: nextValue,\n            };\n        } else {\n            returnVal = { value: nextValue };\n        }\n    } else if (value != null && nextValue != null) {\n        const [valueStart, valueEnd] = value;\n        const [nextValueStart, nextValueEnd] = nextValue;\n\n        if (nextValueStart == null) {\n           returnVal = { value: nextValue };\n        } else {\n            const hasEndDateChanged = !DateUtils.areSameDay(valueEnd, nextValueEnd);\n            const isStartDateNowEndDate = DateUtils.areSameDay(valueStart, nextValueEnd);\n\n            const newDate = hasEndDateChanged && !isStartDateNowEndDate && nextValueEnd != null ?\n                nextValueEnd :\n                nextValueStart;\n            returnVal = {\n                displayMonth: newDate.getMonth(),\n                displayYear: newDate.getFullYear(),\n                value: nextValue,\n            };\n        }\n    } else {\n        returnVal = {};\n    }\n\n    // adjust calendar display month as little as possible\n    const { displayMonth, displayYear } = returnVal;\n    if (displayMonth != null && displayYear != null) {\n        const nextMonth = getNextMonth([currMonth, currYear]);\n        const monthToDisplay: DisplayMonth = [displayMonth, displayYear];\n        if (areSameMonth(nextMonth, monthToDisplay)) {\n            returnVal.displayMonth = currMonth;\n            returnVal.displayYear = currYear;\n        } else if (areSameMonth(getNextMonth(nextMonth), monthToDisplay)) {\n           returnVal.displayMonth = nextMonth[0];\n           returnVal.displayYear = nextMonth[1];\n        }\n    }\n\n    return returnVal;\n}\n\ntype DisplayMonth = [number, number];\n\nfunction getNextMonth([month, year]: DisplayMonth): DisplayMonth {\n    return month === 12 ? [0, year + 1] : [month + 1, year];\n}\n\nfunction areSameMonth([month, year]: DisplayMonth, [month2, year2]: DisplayMonth) {\n    return month === month2 && year === year2;\n}\n\nfunction createShortcut(label: string, dateRange: DateRange): IDateRangeShortcut {\n    return { dateRange, label };\n}\n\nfunction createDefaultShortcuts() {\n    const today = new Date();\n    const makeDate = (action: (d: Date) => void) => {\n        const returnVal = DateUtils.clone(today);\n        action(returnVal);\n        returnVal.setDate(returnVal.getDate() + 1);\n        return returnVal;\n    };\n\n    const oneWeekAgo = makeDate((d) => d.setDate(d.getDate() - 7));\n    const oneMonthAgo = makeDate((d) => d.setMonth(d.getMonth() - 1));\n    const threeMonthsAgo = makeDate((d) => d.setMonth(d.getMonth() - 3));\n    const sixMonthsAgo = makeDate((d) => d.setMonth(d.getMonth() - 6));\n    const oneYearAgo = makeDate((d) => d.setFullYear(d.getFullYear() - 1));\n    const twoYearsAgo = makeDate((d) => d.setFullYear(d.getFullYear() - 2));\n\n    return [\n        createShortcut(\"Past Week\", [oneWeekAgo, today]),\n        createShortcut(\"Past Month\", [oneMonthAgo, today]),\n        createShortcut(\"Past 3 Months\", [threeMonthsAgo, today]),\n        createShortcut(\"Past 6 Months\", [sixMonthsAgo, today]),\n        createShortcut(\"Past Year\", [oneYearAgo, today]),\n        createShortcut(\"Past 2 Years\", [twoYearsAgo, today]),\n    ];\n}\n\nexport const DateRangePickerFactory = React.createFactory(DateRangePicker);\n"],"sourceRoot":"/source/"}
{
"name": "@blueprintjs/datetime",
"version": "1.2.0",
"version": "1.3.0",
"description": "Components for interacting with dates and times",

@@ -9,3 +9,3 @@ "main": "dist/index.js",

"dependencies": {
"@blueprintjs/core": "^1.2.0",
"@blueprintjs/core": "^1.3.0",
"classnames": "^2.2",

@@ -12,0 +12,0 @@ "moment": "^2.14.1",

@@ -12,3 +12,3 @@ /*

*/
export function measureTextWidth(text: string, className = "") {
export function measureTextWidth(text: string, className = "", containerElement = document.body) {
const span = document.createElement("span");

@@ -18,3 +18,3 @@ span.classList.add(className);

document.body.appendChild(span);
containerElement.appendChild(span);
const spanWidth = span.offsetWidth;

@@ -21,0 +21,0 @@ span.remove();

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc