focus-components-v3
Version:
Focus web components to build applications (based on Material Design)
288 lines (228 loc) • 31 kB
JavaScript
Object.defineProperty(exports, "__esModule", {
value: true
});
var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };
var _react = require('react');
var _react2 = _interopRequireDefault(_react);
var _reactDom = require('react-dom');
var _reactDom2 = _interopRequireDefault(_reactDom);
var _moment = require('moment');
var _moment2 = _interopRequireDefault(_moment);
var _i18next = require('i18next');
var _i18next2 = _interopRequireDefault(_i18next);
var _inputText = require('../input-text');
var _inputText2 = _interopRequireDefault(_inputText);
var _reactDatePicker = require('react-date-picker');
var _reactDatePicker2 = _interopRequireDefault(_reactDatePicker);
var _isArray = require('lodash/isArray');
var _isArray2 = _interopRequireDefault(_isArray);
var _uniqueId = require('lodash/uniqueId');
var _uniqueId2 = _interopRequireDefault(_uniqueId);
var _closest = require('closest');
var _closest2 = _interopRequireDefault(_closest);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _defaults(obj, defaults) { var keys = Object.getOwnPropertyNames(defaults); for (var i = 0; i < keys.length; i++) { var key = keys[i]; var value = Object.getOwnPropertyDescriptor(defaults, key); if (value && value.configurable && obj[key] === undefined) { Object.defineProperty(obj, key, value); } } return obj; }
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; }
function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : _defaults(subClass, superClass); } // Dependencies
var isISOString = function isISOString(value) {
return (0, _moment2.default)(value, _moment2.default.ISO_8601).isValid();
};
var InputDate = function (_Component) {
_inherits(InputDate, _Component);
function InputDate(props) {
_classCallCheck(this, InputDate);
var _this = _possibleConstructorReturn(this, _Component.call(this, props));
_this._isInputFormatCorrect = function (value) {
return _this._parseInputDate(value).isValid();
};
_this._parseInputDate = function (inputDate) {
var format = _this.props.format;
return (0, _moment2.default)(inputDate, format);
};
_this._formatDate = function (isoDate) {
var format = _this.props.format;
if (isISOString(isoDate)) {
if ((0, _isArray2.default)(format)) {
format = format[0];
}
return (0, _moment2.default)(isoDate, _moment2.default.ISO_8601).format(format);
} else {
return isoDate;
}
};
_this._onInputChange = function (inputDate, fromBlur) {
if (_this._isInputFormatCorrect(inputDate)) {
var dropDownDate = _this._parseInputDate(inputDate);
_this.setState({ dropDownDate: dropDownDate, inputDate: inputDate });
} else {
_this.setState({ inputDate: inputDate });
}
if (fromBlur !== true) {
_this.props.onChange(inputDate);
}
};
_this._onInputBlur = function () {
var inputDate = _this.state.inputDate;
_this._onInputChange(inputDate, true);
};
_this._onDropDownChange = function (text, date) {
if (date._isValid) {
_this.setState({ displayPicker: false }, function () {
_this.props.onChange(date.toISOString());
_this._onInputChange(_this._formatDate(date.toISOString()), true); // Add 12 hours to avoid skipping a day due to different locales
});
}
};
_this._onInputFocus = function () {
_this.setState({ displayPicker: true });
};
_this._onDocumentClick = function (_ref) {
var target = _ref.target;
var targetClassAttr = target.getAttribute('class');
var isTriggeredFromPicker = targetClassAttr ? targetClassAttr.includes('dp-cell') : false; //this is the only way to check the target comes from picker cause at this stage, month and year div are unmounted by React.
if (!isTriggeredFromPicker) {
//if target was not triggered inside the date picker, we check it was not triggered by the input
if ((0, _closest2.default)(target, '[data-id=\'' + _this._inputDateId + '\']', true) === undefined) {
_this.setState({ displayPicker: false }, function () {
return _this._onInputBlur();
});
}
}
};
_this._handleKeyDown = function (_ref2) {
var key = _ref2.key;
if (key === 'Tab' || key === 'Enter') {
_this.setState({ displayPicker: false }, function () {
return _this._onInputBlur();
});
}
};
_this.getValue = function () {
var inputDate = _this.state.inputDate;
var rawValue = _this._isInputFormatCorrect(inputDate) ? _this._parseInputDate(inputDate).toISOString() : null;
return _this.props.beforeValueGetter(rawValue);
};
_this.validate = function () {
var inputDate = _this.state.inputDate;
var isRequired = _this.props.isRequired;
if ('' === inputDate || !inputDate) {
return {
isValid: !isRequired,
message: 'focus.components.field.required'
};
} else {
return {
isValid: _this._isInputFormatCorrect(inputDate),
message: _i18next2.default.t('focus.components.input.date.invalid', { date: inputDate })
};
}
};
var rawInputValue = props.rawInputValue;
var state = {
dropDownDate: isISOString(rawInputValue) ? (0, _moment2.default)(rawInputValue, _moment2.default.ISO_8601) : (0, _moment2.default)(),
inputDate: _this._formatDate(rawInputValue),
displayPicker: false
};
_this.state = state;
_this._inputDateId = (0, _uniqueId2.default)('input-date-');
return _this;
}
InputDate.prototype.componentWillMount = function componentWillMount() {
_moment2.default.locale(this.props.locale);
document.addEventListener('click', this._onDocumentClick);
};
InputDate.prototype.componentDidMount = function componentDidMount() {
var _props = this.props,
drops = _props.drops,
showDropdowns = _props.showDropdowns;
var startDate = this.state.inputDate;
};
InputDate.prototype.componentWillReceiveProps = function componentWillReceiveProps(_ref3) {
var rawInputValue = _ref3.rawInputValue;
this.setState({
dropDownDate: isISOString(rawInputValue) ? (0, _moment2.default)(rawInputValue, _moment2.default.ISO_8601) : (0, _moment2.default)(),
inputDate: this._formatDate(rawInputValue)
});
};
InputDate.prototype.componentWillUnmount = function componentWillUnmount() {
document.removeEventListener('click', this._onDocumentClick);
};
InputDate.prototype.render = function render() {
var _props2 = this.props,
disabled = _props2.disabled,
error = _props2.error,
locale = _props2.locale,
name = _props2.name,
placeholder = _props2.placeholder,
valid = _props2.valid;
var _state = this.state,
dropDownDate = _state.dropDownDate,
inputDate = _state.inputDate,
displayPicker = _state.displayPicker;
var _onInputBlur = this._onInputBlur,
_onInputChange = this._onInputChange,
_onInputFocus = this._onInputFocus,
_onDropDownChange = this._onDropDownChange,
_onPickerCloserClick = this._onPickerCloserClick,
_handleKeyDown = this._handleKeyDown;
var inputProps = { disabled: disabled };
return _react2.default.createElement(
'div',
{ 'data-focus': 'input-date', 'data-id': this._inputDateId },
_react2.default.createElement(_inputText2.default, _extends({ error: error, name: name, onChange: _onInputChange, onKeyDown: _handleKeyDown, onFocus: _onInputFocus, placeholder: placeholder, ref: 'input', rawInputValue: inputDate, valid: valid }, inputProps)),
displayPicker && _react2.default.createElement(
'div',
{ 'data-focus': 'picker-zone' },
_react2.default.createElement(_reactDatePicker2.default, {
date: dropDownDate,
hideFooter: true,
locale: locale,
onChange: _onDropDownChange,
ref: 'picker' })
)
);
};
return InputDate;
}(_react.Component);
InputDate.displayName = 'InputDate';
InputDate.propTypes = {
drops: _react.PropTypes.oneOf(['up', 'down']).isRequired,
error: _react.PropTypes.oneOfType([_react.PropTypes.string, _react.PropTypes.bool]),
locale: _react.PropTypes.string.isRequired,
name: _react.PropTypes.string.isRequired,
onChange: _react.PropTypes.func.isRequired,
beforeValueGetter: _react.PropTypes.func.isRequired,
placeholder: _react.PropTypes.string,
showDropdowns: _react.PropTypes.bool.isRequired,
rawInputValue: function rawInputValue(props, propName, componentName) {
var prop = props[propName];
if (prop && !isISOString(prop)) {
throw new Error('The date ' + prop + ' provided to the component ' + componentName + ' is not an ISO date. Please provide a valid date string.');
}
},
valid: _react.PropTypes.bool,
validate: _react.PropTypes.func
};
InputDate.defaultProps = {
drops: 'down',
error: 'focus.components.input.date.error.default',
locale: 'en',
format: 'MM/DD/YYYY',
beforeValueGetter: function beforeValueGetter(value) {
return value;
},
/**
* Default onChange prop, that will log an error.
*/
onChange: function onChange() {
console.error('You did not give an onChange method to an input date, please check your code.');
},
showDropdowns: true,
valid: true,
validate: isISOString
};
exports.default = InputDate;
module.exports = exports['default'];
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["fr-FR.js"],"names":["isISOString","value","ISO_8601","isValid","InputDate","props","_isInputFormatCorrect","_parseInputDate","format","inputDate","_formatDate","isoDate","_onInputChange","fromBlur","dropDownDate","setState","onChange","_onInputBlur","state","_onDropDownChange","text","date","_isValid","displayPicker","toISOString","_onInputFocus","_onDocumentClick","target","targetClassAttr","getAttribute","isTriggeredFromPicker","includes","_inputDateId","undefined","_handleKeyDown","key","getValue","rawValue","beforeValueGetter","validate","isRequired","message","t","rawInputValue","componentWillMount","locale","document","addEventListener","componentDidMount","drops","showDropdowns","startDate","componentWillReceiveProps","componentWillUnmount","removeEventListener","render","disabled","error","name","placeholder","valid","_onPickerCloserClick","inputProps","displayName","propTypes","oneOf","oneOfType","string","bool","func","propName","componentName","prop","Error","defaultProps","console"],"mappings":"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","file":"fr-FR.js","sourcesContent":["// Dependencies\r\nimport React, {Component, PropTypes} from 'react';\r\nimport ReactDOM from 'react-dom';\r\nimport moment from 'moment';\r\nimport i18next from 'i18next';\r\nimport InputText from '../input-text';\r\nimport DatePicker from 'react-date-picker';\r\nimport isArray from 'lodash/isArray';\r\nimport uniqueId from 'lodash/uniqueId';\r\nimport closest from 'closest';\r\n\r\nconst isISOString = value => moment(value, moment.ISO_8601).isValid();\r\n\r\nclass InputDate extends Component {\r\n    constructor(props) {\r\n        super(props);\r\n        const {rawInputValue} = props;\r\n        const state = {\r\n            dropDownDate: isISOString(rawInputValue) ? moment(rawInputValue, moment.ISO_8601) : moment(),\r\n            inputDate: this._formatDate(rawInputValue),\r\n            displayPicker: false\r\n        };\r\n        this.state = state;\r\n        this._inputDateId = uniqueId('input-date-');\r\n    }\r\n\r\n    componentWillMount() {\r\n        moment.locale(this.props.locale);\r\n        document.addEventListener('click', this._onDocumentClick);\r\n    }\r\n\r\n\r\n    componentDidMount() {\r\n        const {drops, showDropdowns} = this.props;\r\n        const {inputDate: startDate} = this.state;\r\n    }\r\n\r\n    componentWillReceiveProps({rawInputValue}) {\r\n        this.setState({\r\n            dropDownDate: isISOString(rawInputValue) ? moment(rawInputValue, moment.ISO_8601) : moment(),\r\n            inputDate: this._formatDate(rawInputValue)\r\n        });\r\n    }\r\n\r\n    componentWillUnmount() {\r\n        document.removeEventListener('click', this._onDocumentClick);\r\n    }\r\n\r\n    _isInputFormatCorrect = value => this._parseInputDate(value).isValid();\r\n\r\n    _parseInputDate = inputDate => {\r\n        const {format} = this.props;\r\n        return moment(inputDate, format);\r\n    };\r\n\r\n    _formatDate = isoDate => {\r\n        let {format} = this.props;\r\n        if (isISOString(isoDate)) {\r\n            if (isArray(format)) {\r\n                format = format[0];\r\n            }\r\n            return moment(isoDate, moment.ISO_8601).format(format);\r\n        } else {\r\n            return isoDate;\r\n        }\r\n    };\r\n\r\n    _onInputChange = (inputDate, fromBlur) => {\r\n        if (this._isInputFormatCorrect(inputDate)) {\r\n            const dropDownDate = this._parseInputDate(inputDate);\r\n            this.setState({dropDownDate, inputDate});\r\n        } else {\r\n            this.setState({inputDate});\r\n        }\r\n        if(fromBlur !== true) {\r\n            this.props.onChange(inputDate);\r\n        }\r\n    };\r\n\r\n    _onInputBlur = () => {\r\n        const {inputDate} = this.state;\r\n        this._onInputChange(inputDate, true);\r\n    };\r\n\r\n    _onDropDownChange = (text, date) => {\r\n        if (date._isValid) {\r\n            this.setState({displayPicker: false}, () => {\r\n                this.props.onChange(date.toISOString());\r\n                this._onInputChange(this._formatDate(date.toISOString()), true) // Add 12 hours to avoid skipping a day due to different locales\r\n            });\r\n        }\r\n    };\r\n\r\n    _onInputFocus = () => {\r\n        this.setState({displayPicker: true});\r\n    };\r\n\r\n    _onDocumentClick = ({target}) => {\r\n        const targetClassAttr = target.getAttribute('class');\r\n        const isTriggeredFromPicker = targetClassAttr ? targetClassAttr.includes('dp-cell') : false; //this is the only way to check the target comes from picker cause at this stage, month and year div are unmounted by React.\r\n        if(!isTriggeredFromPicker) {\r\n            //if target was not triggered inside the date picker, we check it was not triggered by the input\r\n            if (closest(target, `[data-id='${this._inputDateId}']`, true) === undefined) {\r\n                this.setState({displayPicker: false}, () => this._onInputBlur());\r\n            }\r\n        }\r\n    };\r\n\r\n    _handleKeyDown = ({key}) => {\r\n        if (key === 'Tab' || key === 'Enter') {\r\n            this.setState({displayPicker: false}, () => this._onInputBlur());\r\n        }\r\n    };\r\n\r\n    getValue = () => {\r\n        const {inputDate} = this.state;\r\n        const rawValue = this._isInputFormatCorrect(inputDate) ? this._parseInputDate(inputDate).toISOString() : null;\r\n        return this.props.beforeValueGetter(rawValue);\r\n    };\r\n\r\n    validate = () => {\r\n        const {inputDate} = this.state;\r\n        const {isRequired} = this.props;\r\n        if ('' === inputDate || !inputDate) {\r\n            return ({\r\n                isValid: !isRequired,\r\n                message: 'focus.components.field.required'\r\n            });\r\n        } else {\r\n            return ({\r\n                isValid: this._isInputFormatCorrect(inputDate),\r\n                message: i18next.t('focus.components.input.date.invalid', {date: inputDate})\r\n            });\r\n        }\r\n    };\r\n\r\n    render() {\r\n        const {disabled, error, locale, name, placeholder, valid} = this.props;\r\n        const {dropDownDate, inputDate, displayPicker} = this.state;\r\n        const {_onInputBlur, _onInputChange, _onInputFocus, _onDropDownChange, _onPickerCloserClick, _handleKeyDown} = this;\r\n        const inputProps = { disabled };\r\n        return (\r\n            <div data-focus='input-date' data-id={this._inputDateId}>\r\n                <InputText error={error} name={name} onChange={_onInputChange} onKeyDown={_handleKeyDown} onFocus={_onInputFocus} placeholder={placeholder} ref='input' rawInputValue={inputDate} valid={valid} {...inputProps} />\r\n                {displayPicker &&\r\n                    <div data-focus='picker-zone'>\r\n                        <DatePicker\r\n                            date={dropDownDate}\r\n                            hideFooter\r\n                            locale={locale}\r\n                            onChange={_onDropDownChange}\r\n                            ref='picker' />\r\n                    </div>\r\n                }\r\n            </div>\r\n        );\r\n    }\r\n}\r\n\r\nInputDate.displayName = 'InputDate';\r\nInputDate.propTypes =  {\r\n    drops: PropTypes.oneOf(['up', 'down']).isRequired,\r\n    error: PropTypes.oneOfType([\r\n        PropTypes.string,\r\n        PropTypes.bool\r\n    ]),\r\n    locale: PropTypes.string.isRequired,\r\n    name: PropTypes.string.isRequired,\r\n    onChange: PropTypes.func.isRequired,\r\n    beforeValueGetter: PropTypes.func.isRequired,\r\n    placeholder: PropTypes.string,\r\n    showDropdowns: PropTypes.bool.isRequired,\r\n    rawInputValue: (props, propName, componentName) => {\r\n        const prop = props[propName];\r\n        if (prop && !isISOString(prop)) {\r\n            throw new Error(`The date ${prop} provided to the component ${componentName} is not an ISO date. Please provide a valid date string.`);\r\n        }\r\n    },\r\n    valid: PropTypes.bool,\r\n    validate: PropTypes.func\r\n};\r\nInputDate.defaultProps =  {\r\n    drops: 'down',\r\n    error: 'focus.components.input.date.error.default',\r\n    locale: 'en',\r\n    format: 'MM/DD/YYYY',\r\n    beforeValueGetter: value => value,\r\n    /**\r\n    * Default onChange prop, that will log an error.\r\n    */\r\n    onChange() {\r\n        console.error('You did not give an onChange method to an input date, please check your code.');\r\n    },\r\n    showDropdowns: true,\r\n    valid: true,\r\n    validate: isISOString\r\n};\r\nexport default InputDate;\r\n"]}
;