react-lightning-design-components
Version:
Salesforce Lightning Design System components built with React 16
403 lines (343 loc) • 35.1 kB
JavaScript
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
var _extends2 = require('babel-runtime/helpers/extends');
var _extends3 = _interopRequireDefault(_extends2);
var _objectWithoutProperties2 = require('babel-runtime/helpers/objectWithoutProperties');
var _objectWithoutProperties3 = _interopRequireDefault(_objectWithoutProperties2);
var _getPrototypeOf = require('babel-runtime/core-js/object/get-prototype-of');
var _getPrototypeOf2 = _interopRequireDefault(_getPrototypeOf);
var _classCallCheck2 = require('babel-runtime/helpers/classCallCheck');
var _classCallCheck3 = _interopRequireDefault(_classCallCheck2);
var _createClass2 = require('babel-runtime/helpers/createClass');
var _createClass3 = _interopRequireDefault(_createClass2);
var _possibleConstructorReturn2 = require('babel-runtime/helpers/possibleConstructorReturn');
var _possibleConstructorReturn3 = _interopRequireDefault(_possibleConstructorReturn2);
var _inherits2 = require('babel-runtime/helpers/inherits');
var _inherits3 = _interopRequireDefault(_inherits2);
var _react = require('react');
var _react2 = _interopRequireDefault(_react);
var _propTypes = require('prop-types');
var _propTypes2 = _interopRequireDefault(_propTypes);
var _reactDom = require('react-dom');
var _reactDom2 = _interopRequireDefault(_reactDom);
var _classnames = require('classnames');
var _classnames2 = _interopRequireDefault(_classnames);
var _moment = require('moment');
var _moment2 = _interopRequireDefault(_moment);
var _uuid = require('uuid');
var _uuid2 = _interopRequireDefault(_uuid);
var _FormElement = require('./FormElement');
var _FormElement2 = _interopRequireDefault(_FormElement);
var _Input = require('./Input');
var _Input2 = _interopRequireDefault(_Input);
var _Icon = require('./Icon');
var _Icon2 = _interopRequireDefault(_Icon);
var _Datepicker = require('./Datepicker');
var _Datepicker2 = _interopRequireDefault(_Datepicker);
var _reactOnclickoutside = require('react-onclickoutside');
var _reactOnclickoutside2 = _interopRequireDefault(_reactOnclickoutside);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
var DateInput = function (_Component) {
(0, _inherits3.default)(DateInput, _Component);
function DateInput(props) {
(0, _classCallCheck3.default)(this, DateInput);
var _this = (0, _possibleConstructorReturn3.default)(this, (DateInput.__proto__ || (0, _getPrototypeOf2.default)(DateInput)).call(this, props));
_this.handleClickOutside = _this.handleClickOutside.bind(_this);
_this.state = {
id: 'form-element-' + (0, _uuid2.default)(),
opened: props.defaultOpened || false
};
_this.onDateIconClick = _this.onDateIconClick.bind(_this);
_this.onInputKeyDown = _this.onInputKeyDown.bind(_this);
_this.onInputChange = _this.onInputChange.bind(_this);
_this.onInputBlur = _this.onInputBlur.bind(_this);
_this.onDatepickerSelect = _this.onDatepickerSelect.bind(_this);
_this.onDatepickerBlur = _this.onDatepickerBlur.bind(_this);
_this.onDatepickerClose = _this.onDatepickerClose.bind(_this);
_this.inputRef = _this.inputRef.bind(_this);
return _this;
}
(0, _createClass3.default)(DateInput, [{
key: 'componentDidUpdate',
value: function componentDidUpdate(prevProps, prevState) {
if (this.props.onValueChange && prevState.value !== this.state.value) {
this.props.onValueChange(this.state.value, prevState.value);
}
}
}, {
key: 'onDateIconClick',
value: function onDateIconClick() {
var _this2 = this;
setTimeout(function () {
if (_this2.props.inputFocused) {
var inputEl = _reactDom2.default.findDOMNode(_this2.input);
if (inputEl) {
inputEl.focus();
}
}
_this2.showDatepicker();
}, 10);
}
}, {
key: 'onInputKeyDown',
value: function onInputKeyDown(e) {
var _this3 = this;
if (e.keyCode === 13) {
// return key
this.onDatepickerClose();
e.preventDefault();
e.stopPropagation();
this.setValueFromInput(e.target.value);
if (this.props.onComplete) {
setTimeout(function () {
_this3.props.onComplete();
}, 10);
}
} else if (e.keyCode === 40) {
// down key
this.showDatepicker();
e.preventDefault();
e.stopPropagation();
} else if (e.keyCode === 27) {
// ESC
this.onDatepickerClose();
e.preventDefault();
e.stopPropagation();
}
if (this.props.onKeyDown) {
this.props.onKeyDown(e);
}
}
}, {
key: 'onInputChange',
value: function onInputChange(e) {
var inputValue = e.target.value;
this.setState({ inputValue: inputValue });
if (this.props.onChange) {
this.props.onChange(e, inputValue);
}
}
}, {
key: 'onInputBlur',
value: function onInputBlur(e) {
var _this4 = this;
this.setValueFromInput(e.target.value);
setTimeout(function () {
if (!_this4.isFocusedInComponent()) {
if (_this4.props.onBlur) {
_this4.props.onBlur();
}
if (_this4.props.onComplete) {
_this4.props.onComplete();
}
}
}, 10);
}
}, {
key: 'onDatepickerSelect',
value: function onDatepickerSelect(value) {
var _this5 = this;
this.setState({ value: value, inputValue: undefined });
setTimeout(function () {
_this5.setState({ opened: false });
var inputEl = _reactDom2.default.findDOMNode(_this5.input);
if (inputEl) {
inputEl.focus();
inputEl.select();
}
if (_this5.props.onComplete) {
_this5.props.onComplete();
}
}, 200);
}
}, {
key: 'onDatepickerBlur',
value: function onDatepickerBlur() {
var _this6 = this;
this.setState({ opened: false });
setTimeout(function () {
if (!_this6.isFocusedInComponent()) {
if (_this6.props.onBlur) {
_this6.props.onBlur();
}
if (_this6.props.onComplete) {
_this6.props.onComplete();
}
}
}, 10);
}
}, {
key: 'onDatepickerClose',
value: function onDatepickerClose() {
this.setState({ opened: false });
var inputEl = _reactDom2.default.findDOMNode(this.input);
if (inputEl) {
inputEl.focus();
inputEl.select();
}
}
}, {
key: 'setValueFromInput',
value: function setValueFromInput(inputValue) {
var value = this.state.value;
if (!inputValue) {
value = '';
} else {
value = (0, _moment2.default)(inputValue, this.props.dateFormat);
if (value.isValid()) {
value = value.format('YYYY-MM-DD');
} else {
value = inputValue;
}
}
this.setState({ value: value, inputValue: undefined });
}
}, {
key: 'inputRef',
value: function inputRef(ref) {
this.input = ref;
}
// provided by 'react-onclickoutside' HOC
}, {
key: 'handleClickOutside',
value: function handleClickOutside() {
if (!this.state.opened) {
return;
}
this.onDatepickerClose();
}
}, {
key: 'isFocusedInComponent',
value: function isFocusedInComponent() {
var rootEl = _reactDom2.default.findDOMNode(this);
var targetEl = document.activeElement;
while (targetEl && targetEl !== rootEl) {
targetEl = targetEl.parentNode;
}
return !!targetEl;
}
}, {
key: 'showDatepicker',
value: function showDatepicker() {
var value = this.state.value;
if (typeof this.state.inputValue !== 'undefined') {
value = (0, _moment2.default)(this.state.inputValue, this.props.dateFormat);
if (value.isValid()) {
value = value.format('YYYY-MM-DD');
} else {
value = this.state.value;
}
}
this.setState({ opened: !this.state.opened, value: value });
}
}, {
key: 'renderInput',
value: function renderInput(_ref) {
var inputValue = _ref.inputValue,
props = (0, _objectWithoutProperties3.default)(_ref, ['inputValue']);
var inputDateClassNames = (0, _classnames2.default)('slds-input-has-icon', 'slds-input-has-icon--right', props.className);
var pprops = props;
delete pprops.onValueChange;
delete pprops.defaultOpened;
delete pprops.inputFocused;
delete pprops.disableOnClickOutside;
delete pprops.enableOnClickOutside;
delete pprops.outsideClickIgnoreClass;
delete pprops.preventDefault;
delete pprops.eventTypes;
delete pprops.stopPropagation;
return _react2.default.createElement(
'div',
{ className: inputDateClassNames },
_react2.default.createElement(_Input2.default, (0, _extends3.default)({
ref: this.inputRef,
value: inputValue
}, props, {
onKeyDown: this.onInputKeyDown,
onChange: this.onInputChange,
onBlur: this.onInputBlur,
onClick: this.onDateIconClick
})),
_react2.default.createElement(_Icon2.default, {
icon: 'event',
className: 'slds-input__icon',
style: { cursor: 'pointer' },
onClick: this.onDateIconClick
})
);
}
}, {
key: 'renderDropdown',
value: function renderDropdown(dateValue) {
var datepickerClassNames = (0, _classnames2.default)('slds-dropdown', 'slds-dropdown--left');
return this.state.opened ? _react2.default.createElement(_Datepicker2.default, {
className: datepickerClassNames,
selectedDate: dateValue,
autoFocus: !this.props.inputFocused,
onSelect: this.onDatepickerSelect,
onBlur: this.onDatepickerBlur,
onClose: this.onDatepickerClose,
disablePastDateSelection: this.props.disablePastDateSelection
}) : _react2.default.createElement('div', null);
}
}, {
key: 'render',
value: function render() {
var id = this.props.id || this.state.id;
var _props = this.props,
totalCols = _props.totalCols,
cols = _props.cols,
label = _props.label,
required = _props.required,
error = _props.error,
defaultValue = _props.defaultValue,
value = _props.value,
dateFormat = _props.dateFormat,
tooltip = _props.tooltip,
props = (0, _objectWithoutProperties3.default)(_props, ['totalCols', 'cols', 'label', 'required', 'error', 'defaultValue', 'value', 'dateFormat', 'tooltip']);
var dateValue = typeof value !== 'undefined' ? value : typeof this.state.value !== 'undefined' ? this.state.value : defaultValue;
var mvalue = (0, _moment2.default)(dateValue, 'YYYY-MM-DD');
var inputValue = typeof this.state.inputValue !== 'undefined' ? this.state.inputValue : typeof dateValue !== 'undefined' ? mvalue.isValid() ? mvalue.format(dateFormat) : dateValue : undefined;
var dropdown = this.renderDropdown(dateValue);
var formElemProps = { id: id, totalCols: totalCols, cols: cols, label: label, required: required, error: error, dropdown: dropdown, tooltip: tooltip };
return _react2.default.createElement(
_FormElement2.default,
formElemProps,
this.renderInput((0, _extends3.default)({ id: id, inputValue: inputValue }, props))
);
}
}]);
return DateInput;
}(_react.Component);
DateInput.propTypes = {
id: _propTypes2.default.string,
className: _propTypes2.default.string,
label: _propTypes2.default.string,
required: _propTypes2.default.bool,
error: _propTypes2.default.oneOfType([_propTypes2.default.bool, _propTypes2.default.string, _propTypes2.default.shape({
message: _propTypes2.default.string
})]),
totalCols: _propTypes2.default.number,
cols: _propTypes2.default.number,
value: _propTypes2.default.string,
onKeyDown: _propTypes2.default.func,
onBlur: _propTypes2.default.func,
defaultValue: _propTypes2.default.string,
defaultOpened: _propTypes2.default.bool,
dateFormat: _propTypes2.default.string,
onChange: _propTypes2.default.func,
onValueChange: _propTypes2.default.func,
onComplete: _propTypes2.default.func,
disablePastDateSelection: _propTypes2.default.bool,
inputFocused: _propTypes2.default.bool,
tooltip: _propTypes2.default.element
};
DateInput.defaultProps = {
dateFormat: 'L',
inputFocused: false
};
DateInput.isFormElement = true;
exports.default = (0, _reactOnclickoutside2.default)(DateInput);
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/scripts/DateInput.js"],"names":["DateInput","props","handleClickOutside","bind","state","id","opened","defaultOpened","onDateIconClick","onInputKeyDown","onInputChange","onInputBlur","onDatepickerSelect","onDatepickerBlur","onDatepickerClose","inputRef","prevProps","prevState","onValueChange","value","setTimeout","inputFocused","inputEl","findDOMNode","input","focus","showDatepicker","e","keyCode","preventDefault","stopPropagation","setValueFromInput","target","onComplete","onKeyDown","inputValue","setState","onChange","isFocusedInComponent","onBlur","undefined","select","dateFormat","isValid","format","ref","rootEl","targetEl","document","activeElement","parentNode","inputDateClassNames","className","pprops","disableOnClickOutside","enableOnClickOutside","outsideClickIgnoreClass","eventTypes","cursor","dateValue","datepickerClassNames","disablePastDateSelection","totalCols","cols","label","required","error","defaultValue","tooltip","mvalue","dropdown","renderDropdown","formElemProps","renderInput","propTypes","string","bool","oneOfType","shape","message","number","func","element","defaultProps","isFormElement"],"mappings":"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","file":"DateInput.js","sourcesContent":["import React, { Component } from 'react';\nimport PropTypes from 'prop-types';\nimport ReactDOM from 'react-dom';\nimport classnames from 'classnames';\nimport moment from 'moment';\nimport uuid from 'uuid';\nimport FormElement from './FormElement';\nimport Input from './Input';\nimport Icon from './Icon';\nimport Datepicker from './Datepicker';\nimport onClickOutside from 'react-onclickoutside';\n\nclass DateInput extends Component {\n  constructor(props) {\n    super(props);\n    this.handleClickOutside = this.handleClickOutside.bind(this);\n    this.state = {\n      id: `form-element-${uuid()}`,\n      opened: (props.defaultOpened || false),\n    };\n\n    this.onDateIconClick = this.onDateIconClick.bind(this);\n    this.onInputKeyDown = this.onInputKeyDown.bind(this);\n    this.onInputChange = this.onInputChange.bind(this);\n    this.onInputBlur = this.onInputBlur.bind(this);\n\n    this.onDatepickerSelect = this.onDatepickerSelect.bind(this);\n    this.onDatepickerBlur = this.onDatepickerBlur.bind(this);\n    this.onDatepickerClose = this.onDatepickerClose.bind(this);\n\n    this.inputRef = this.inputRef.bind(this);\n  }\n\n  componentDidUpdate(prevProps, prevState) {\n    if (this.props.onValueChange && prevState.value !== this.state.value) {\n      this.props.onValueChange(this.state.value, prevState.value);\n    }\n  }\n\n  onDateIconClick() {\n    setTimeout(() => {\n      if (this.props.inputFocused) {\n        const inputEl = ReactDOM.findDOMNode(this.input);\n        if (inputEl) {\n          inputEl.focus();\n        }\n      }\n      this.showDatepicker();\n    }, 10);\n  }\n\n  onInputKeyDown(e) {\n    if (e.keyCode === 13) { // return key\n      this.onDatepickerClose();\n      e.preventDefault();\n      e.stopPropagation();\n      this.setValueFromInput(e.target.value);\n      if (this.props.onComplete) {\n        setTimeout(() => {\n          this.props.onComplete();\n        }, 10);\n      }\n    } else if (e.keyCode === 40) { // down key\n      this.showDatepicker();\n      e.preventDefault();\n      e.stopPropagation();\n    } else if (e.keyCode === 27) { // ESC\n      this.onDatepickerClose();\n      e.preventDefault();\n      e.stopPropagation();\n    }\n    if (this.props.onKeyDown) {\n      this.props.onKeyDown(e);\n    }\n  }\n\n  onInputChange(e) {\n    const inputValue = e.target.value;\n    this.setState({ inputValue });\n    if (this.props.onChange) {\n      this.props.onChange(e, inputValue);\n    }\n  }\n\n  onInputBlur(e) {\n    this.setValueFromInput(e.target.value);\n    setTimeout(() => {\n      if (!this.isFocusedInComponent()) {\n        if (this.props.onBlur) {\n          this.props.onBlur();\n        }\n        if (this.props.onComplete) {\n          this.props.onComplete();\n        }\n      }\n    }, 10);\n  }\n\n  onDatepickerSelect(value) {\n    this.setState({ value, inputValue: undefined });\n    setTimeout(() => {\n      this.setState({ opened: false });\n      const inputEl = ReactDOM.findDOMNode(this.input);\n      if (inputEl) {\n        inputEl.focus();\n        inputEl.select();\n      }\n      if (this.props.onComplete) {\n        this.props.onComplete();\n      }\n    }, 200);\n  }\n\n  onDatepickerBlur() {\n    this.setState({ opened: false });\n    setTimeout(() => {\n      if (!this.isFocusedInComponent()) {\n        if (this.props.onBlur) {\n          this.props.onBlur();\n        }\n        if (this.props.onComplete) {\n          this.props.onComplete();\n        }\n      }\n    }, 10);\n  }\n\n  onDatepickerClose() {\n    this.setState({ opened: false });\n    const inputEl = ReactDOM.findDOMNode(this.input);\n    if (inputEl) {\n      inputEl.focus();\n      inputEl.select();\n    }\n  }\n\n  setValueFromInput(inputValue) {\n    let value = this.state.value;\n    if (!inputValue) {\n      value = '';\n    } else {\n      value = moment(inputValue, this.props.dateFormat);\n      if (value.isValid()) {\n        value = value.format('YYYY-MM-DD');\n      } else {\n        value = inputValue;\n      }\n    }\n    this.setState({ value, inputValue: undefined });\n  }\n\n  inputRef(ref) {\n    this.input = ref;\n  }\n\n  // provided by 'react-onclickoutside' HOC\n  handleClickOutside() {\n    if (!this.state.opened) {\n      return;\n    }\n    this.onDatepickerClose();\n  }\n\n  isFocusedInComponent() {\n    const rootEl = ReactDOM.findDOMNode(this);\n    let targetEl = document.activeElement;\n    while (targetEl && targetEl !== rootEl) {\n      targetEl = targetEl.parentNode;\n    }\n    return !!targetEl;\n  }\n\n  showDatepicker() {\n    let value = this.state.value;\n    if (typeof this.state.inputValue !== 'undefined') {\n      value = moment(this.state.inputValue, this.props.dateFormat);\n      if (value.isValid()) {\n        value = value.format('YYYY-MM-DD');\n      } else {\n        value = this.state.value;\n      }\n    }\n    this.setState({ opened: !this.state.opened, value });\n  }\n\n  renderInput({ inputValue, ...props }) {\n    const inputDateClassNames = classnames(\n      'slds-input-has-icon',\n      'slds-input-has-icon--right',\n      props.className\n    );\n    const pprops = props;\n    delete pprops.onValueChange;\n    delete pprops.defaultOpened;\n    delete pprops.inputFocused;\n    delete pprops.disableOnClickOutside;\n    delete pprops.enableOnClickOutside;\n    delete pprops.outsideClickIgnoreClass;\n    delete pprops.preventDefault;\n    delete pprops.eventTypes;\n    delete pprops.stopPropagation;\n\n    return (\n      <div className={inputDateClassNames}>\n        <Input\n          ref={this.inputRef}\n          value={ inputValue }\n          { ...props }\n          onKeyDown={ this.onInputKeyDown }\n          onChange={ this.onInputChange }\n          onBlur={ this.onInputBlur }\n          onClick={ this.onDateIconClick }\n        />\n        <Icon\n          icon='event'\n          className='slds-input__icon'\n          style={ { cursor: 'pointer' } }\n          onClick={ this.onDateIconClick }\n        />\n      </div>\n    );\n  }\n\n  renderDropdown(dateValue) {\n    const datepickerClassNames = classnames(\n      'slds-dropdown',\n      'slds-dropdown--left'\n    );\n    return (\n      this.state.opened ?\n        <Datepicker\n          className={ datepickerClassNames }\n          selectedDate={ dateValue }\n          autoFocus={!this.props.inputFocused}\n          onSelect={ this.onDatepickerSelect }\n          onBlur={ this.onDatepickerBlur }\n          onClose={ this.onDatepickerClose }\n          disablePastDateSelection={this.props.disablePastDateSelection}\n        /> :\n        <div />\n    );\n  }\n\n  render() {\n    const id = this.props.id || this.state.id;\n    const {\n      totalCols, cols, label, required, error,\n      defaultValue, value, dateFormat, tooltip,\n      ...props,\n    } = this.props;\n    const dateValue =\n      typeof value !== 'undefined' ? value :\n      typeof this.state.value !== 'undefined' ? this.state.value :\n      defaultValue;\n    const mvalue = moment(dateValue, 'YYYY-MM-DD');\n    const inputValue =\n      typeof this.state.inputValue !== 'undefined' ? this.state.inputValue :\n      typeof dateValue !== 'undefined' ?\n        (mvalue.isValid() ? mvalue.format(dateFormat) : dateValue) : undefined;\n    const dropdown = this.renderDropdown(dateValue);\n    const formElemProps = { id, totalCols, cols, label, required, error, dropdown, tooltip };\n    return (\n      <FormElement { ...formElemProps }>\n        { this.renderInput({ id, inputValue, ...props }) }\n      </FormElement>\n    );\n  }\n}\n\nDateInput.propTypes = {\n  id: PropTypes.string,\n  className: PropTypes.string,\n  label: PropTypes.string,\n  required: PropTypes.bool,\n  error: PropTypes.oneOfType([\n    PropTypes.bool,\n    PropTypes.string,\n    PropTypes.shape({\n      message: PropTypes.string,\n    }),\n  ]),\n  totalCols: PropTypes.number,\n  cols: PropTypes.number,\n  value: PropTypes.string,\n  onKeyDown: PropTypes.func,\n  onBlur: PropTypes.func,\n  defaultValue: PropTypes.string,\n  defaultOpened: PropTypes.bool,\n  dateFormat: PropTypes.string,\n  onChange: PropTypes.func,\n  onValueChange: PropTypes.func,\n  onComplete: PropTypes.func,\n  disablePastDateSelection: PropTypes.bool,\n  inputFocused: PropTypes.bool,\n  tooltip: PropTypes.element,\n};\n\nDateInput.defaultProps = {\n  dateFormat: 'L',\n  inputFocused: false,\n};\n\nDateInput.isFormElement = true;\n\nexport default onClickOutside(DateInput);\n"]}