UNPKG

react-lightning-design-components

Version:

Salesforce Lightning Design System components built with React 16

393 lines (337 loc) 34.1 kB
'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 _reactDom = require('react-dom'); var _reactDom2 = _interopRequireDefault(_reactDom); var _classnames = require('classnames'); var _classnames2 = _interopRequireDefault(_classnames); 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 _DropdownMenu = require('./DropdownMenu'); var _DropdownMenu2 = _interopRequireDefault(_DropdownMenu); var _util = require('./util'); var _propTypes = require('prop-types'); var _propTypes2 = _interopRequireDefault(_propTypes); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } var TimeInput = function (_React$Component) { (0, _inherits3.default)(TimeInput, _React$Component); function TimeInput(props) { (0, _classCallCheck3.default)(this, TimeInput); var _this = (0, _possibleConstructorReturn3.default)(this, (TimeInput.__proto__ || (0, _getPrototypeOf2.default)(TimeInput)).call(this, props)); _this.state = { id: 'form-element-' + (0, _uuid2.default)(), opened: props.defaultOpened || false }; _this.onMenuItemClick = _this.onMenuItemClick.bind(_this); _this.inputRef = _this.inputRef.bind(_this); _this.dropdownRef = _this.dropdownRef.bind(_this); _this.timeepoch = { 10: 600, 15: 900, 20: 1200, 25: 1500, 30: 1800, DAY: 86400 }; (0, _util.registerStyle)('no-hover-popup', [['.slds-dropdown-trigger:hover .slds-dropdown--menu.react-slds-no-hover-popup', '{ visibility: hidden; opacity: 0; }'], ['.slds-dropdown-trigger.react-slds-dropdown-opened .slds-dropdown--menu', '{ visibility: visible !important; opacity: 1 !important; }']]); return _this; } (0, _createClass3.default)(TimeInput, [{ key: 'componentWillMount', value: function componentWillMount() { this.options = this.buildTimeOptions(); } }, { 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: 'onMenuItemClick', value: function onMenuItemClick(event) { var value = event.target.textContent; this.closeTimePopUp(); this.setState({ value: value, inputValue: value }); } }, { key: 'onDropdownBlur', value: function onDropdownBlur(e) { // const target = e.currentTarget; var relatedTarget = e.relatedTarget || document.activeElement; var rootElement = _reactDom2.default.findDOMNode(this); if (relatedTarget && !rootElement.contains(relatedTarget)) { this.closeTimePopUp(); } } }, { key: 'onInputKeyDown', value: function onInputKeyDown(e) { var _this2 = this; if (e.keyCode === 13) { // return key e.preventDefault(); e.stopPropagation(); if (this.props.onComplete) { setTimeout(function () { _this2.props.onComplete(); }, 10); } } else if (e.keyCode === 27) { // esc this.closeTimePopUp(); } if (this.props.onKeyDown) { this.props.onKeyDown(e); } } }, { key: 'onInputChange', value: function onInputChange(e) { var inputValue = e.target.value; this.setState({ inputValue: inputValue, value: inputValue }); if (this.props.onChange) { this.props.onChange(e, inputValue); } } }, { key: 'onInputBlur', value: function onInputBlur() { var _this3 = this; setTimeout(function () { if (!_this3.isFocusedInComponent()) { _this3.closeTimePopUp(); if (_this3.props.onBlur) { _this3.props.onBlur(); } if (_this3.props.onComplete) { _this3.props.onComplete(); } } }, 10); } }, { 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: 'focusToTargetItemEl', value: function focusToTargetItemEl() { if (this.state.opened) { var inputEl = _reactDom2.default.findDOMNode(this.input); setTimeout(function () { inputEl.focus(); }, 20); } } }, { key: 'toggleTimemenu', value: function toggleTimemenu() { var _this4 = this; setTimeout(function () { _this4.setState({ opened: !_this4.state.opened }); _this4.focusToTargetItemEl(); }, 10); } }, { key: 'closeTimePopUp', value: function closeTimePopUp() { var _this5 = this; setTimeout(function () { _this5.setState({ opened: false }); }, 10); } }, { key: 'buildTimeOptions', value: function buildTimeOptions() { var _ref = [this.props.resolution, this.props.format, this.props.inputValue], resolution = _ref[0], format = _ref[1], inputValue = _ref[2]; // min 10 - max 30 || default 30 min || format 12||24 var step = resolution in this.timeepoch ? resolution : 30; var loops = this.timeepoch.DAY / this.timeepoch[step] + 1; var hour = 0, min = 0, AMPM = 'AM'; var minToDisplay = 0, hour12format = 0, hour24format = 0, finalOption = 0; var isSelected = 'none'; var options = []; while (loops) { minToDisplay = min === 0 ? '00' : min; hour12format = hour > 12 ? hour - 12 : hour; hour12format = hour === 0 ? 12 : hour12format; hour12format = hour12format < 10 ? '0' + hour12format : hour12format; // optional hour24format = hour < 10 ? '0' + hour : hour; // optional finalOption = format === 12 ? hour12format + ':' + minToDisplay + ' ' + AMPM : hour24format + ':' + minToDisplay; isSelected = finalOption === inputValue ? 'check' : 'none'; options.push(_react2.default.createElement( _DropdownMenu.DropdownMenuItem, { key: loops, onClick: this.onMenuItemClick, icon: isSelected, value: finalOption }, finalOption )); min += step; if (min === 60) { hour += 1; min = 0; } if (hour === 12 && min === 0) { AMPM = AMPM === 'AM' ? 'PM' : 'AM'; } loops--; } return options; } }, { key: 'inputRef', value: function inputRef(ref) { this.input = ref; } }, { key: 'dropdownRef', value: function dropdownRef(ref) { this.dropdown = ref; } }, { key: 'renderInput', value: function renderInput(_ref2) { var inputValue = _ref2.inputValue, openMenuOnInputClick = _ref2.openMenuOnInputClick, dontUseDefaultValue = _ref2.dontUseDefaultValue, props = (0, _objectWithoutProperties3.default)(_ref2, ['inputValue', 'openMenuOnInputClick', 'dontUseDefaultValue']); var internalInputValue = dontUseDefaultValue ? this.state.inputValue : this.state.inputValue || inputValue; return _react2.default.createElement( 'div', { className: 'slds-input-has-icon slds-input-has-icon--right' }, _react2.default.createElement(_Input2.default, (0, _extends3.default)({ ref: this.inputRef }, props, { value: internalInputValue, onKeyDown: this.onInputKeyDown.bind(this), onChange: this.onInputChange.bind(this), onBlur: this.onInputBlur.bind(this), onClick: openMenuOnInputClick ? this.toggleTimemenu.bind(this) : undefined })), _react2.default.createElement(_Icon2.default, { icon: 'clock', className: 'slds-input__icon', style: { cursor: 'pointer' }, onClick: this.toggleTimemenu.bind(this) }) ); } }, { key: 'render', value: function render() { var id = this.props.id || this.state.id; var _props = this.props, className = _props.className, totalCols = _props.totalCols, cols = _props.cols, label = _props.label, required = _props.required, error = _props.error, maxHeight = _props.maxHeight, tooltip = _props.tooltip, props = (0, _objectWithoutProperties3.default)(_props, ['className', 'totalCols', 'cols', 'label', 'required', 'error', 'maxHeight', 'tooltip']); var dropdownClassNames = (0, _classnames2.default)(className, 'slds-dropdown-trigger', { 'react-slds-dropdown-opened': this.state.opened }); var formElemProps = { id: id, totalCols: totalCols, cols: cols, label: label, required: required, error: error, tooltip: tooltip }; delete props.resolution; delete props.onValueChange; return _react2.default.createElement( _FormElement2.default, (0, _extends3.default)({ key: id }, formElemProps), _react2.default.createElement( 'div', { className: dropdownClassNames }, this.renderInput((0, _extends3.default)({ id: id }, props)), _react2.default.createElement( _DropdownMenu2.default, { align: 'left', size: 'small', autoFocus: true, ref: this.dropdownRef, maxHeight: maxHeight, onKeyDown: this.onInputKeyDown.bind(this), onBlur: this.onDropdownBlur.bind(this) }, this.options ) ) ); } }]); return TimeInput; }(_react2.default.Component); exports.default = TimeInput; TimeInput.propTypes = { id: _propTypes2.default.string, className: _propTypes2.default.string, label: _propTypes2.default.string, required: _propTypes2.default.bool, format: _propTypes2.default.number, resolution: _propTypes2.default.number, inputValue: _propTypes2.default.string, maxHeight: _propTypes2.default.number, onMenuItemClick: _propTypes2.default.func, 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, dontUseDefaultValue: _propTypes2.default.bool, openMenuOnInputClick: _propTypes2.default.bool, tooltip: _propTypes2.default.element }; TimeInput.isFormElement = true; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/scripts/TimeInput.js"],"names":["TimeInput","props","state","id","opened","defaultOpened","onMenuItemClick","bind","inputRef","dropdownRef","timeepoch","DAY","options","buildTimeOptions","prevProps","prevState","onValueChange","value","event","target","textContent","closeTimePopUp","setState","inputValue","e","relatedTarget","document","activeElement","rootElement","findDOMNode","contains","keyCode","preventDefault","stopPropagation","onComplete","setTimeout","onKeyDown","onChange","isFocusedInComponent","onBlur","rootEl","targetEl","parentNode","inputEl","input","focus","focusToTargetItemEl","resolution","format","step","loops","hour","min","AMPM","minToDisplay","hour12format","hour24format","finalOption","isSelected","push","ref","dropdown","openMenuOnInputClick","dontUseDefaultValue","internalInputValue","onInputKeyDown","onInputChange","onInputBlur","toggleTimemenu","undefined","cursor","className","totalCols","cols","label","required","error","maxHeight","tooltip","dropdownClassNames","formElemProps","renderInput","onDropdownBlur","Component","propTypes","string","bool","number","func","oneOfType","shape","message","defaultValue","dateFormat","element","isFormElement"],"mappings":"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","file":"TimeInput.js","sourcesContent":["import React from 'react';\nimport ReactDOM from 'react-dom';\nimport classnames from 'classnames';\nimport uuid from 'uuid';\nimport FormElement from './FormElement';\nimport Input from './Input';\nimport Icon from './Icon';\nimport DropdownMenu, { DropdownMenuItem } from './DropdownMenu';\nimport { registerStyle } from './util';\nimport PropTypes from 'prop-types';\n\nexport default class TimeInput extends React.Component {\n  constructor(props) {\n    super(props);\n    this.state = {\n      id: `form-element-${uuid()}`,\n      opened: props.defaultOpened || false,\n    };\n    this.onMenuItemClick = this.onMenuItemClick.bind(this);\n    this.inputRef = this.inputRef.bind(this);\n    this.dropdownRef = this.dropdownRef.bind(this);\n\n    this.timeepoch = {\n      10: 600,\n      15: 900,\n      20: 1200,\n      25: 1500,\n      30: 1800,\n      DAY: 86400,\n    };\n    registerStyle('no-hover-popup', [\n      [\n        '.slds-dropdown-trigger:hover .slds-dropdown--menu.react-slds-no-hover-popup',\n        '{ visibility: hidden; opacity: 0; }',\n      ],\n      [\n        '.slds-dropdown-trigger.react-slds-dropdown-opened .slds-dropdown--menu',\n        '{ visibility: visible !important; opacity: 1 !important; }',\n      ],\n    ]);\n  }\n\n  componentWillMount() {\n    this.options = this.buildTimeOptions();\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  onMenuItemClick(event) {\n    const value = event.target.textContent;\n    this.closeTimePopUp();\n    this.setState({ value, inputValue: value });\n  }\n\n  onDropdownBlur(e) {\n    // const target = e.currentTarget;\n    const relatedTarget = e.relatedTarget || document.activeElement;\n    const rootElement = ReactDOM.findDOMNode(this);\n    if (relatedTarget && !rootElement.contains(relatedTarget)) {\n      this.closeTimePopUp();\n    }\n  }\n\n  onInputKeyDown(e) {\n    if (e.keyCode === 13) {\n      // return key\n      e.preventDefault();\n      e.stopPropagation();\n      if (this.props.onComplete) {\n        setTimeout(() => {\n          this.props.onComplete();\n        }, 10);\n      }\n    } else if (e.keyCode === 27) {\n      // esc\n      this.closeTimePopUp();\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, value: inputValue });\n    if (this.props.onChange) {\n      this.props.onChange(e, inputValue);\n    }\n  }\n\n  onInputBlur() {\n    setTimeout(() => {\n      if (!this.isFocusedInComponent()) {\n        this.closeTimePopUp();\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  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  focusToTargetItemEl() {\n    if (this.state.opened) {\n      const inputEl = ReactDOM.findDOMNode(this.input);\n      setTimeout(() => {\n        inputEl.focus();\n      }, 20);\n    }\n  }\n\n  toggleTimemenu() {\n    setTimeout(() => {\n      this.setState({ opened: !this.state.opened });\n      this.focusToTargetItemEl();\n    }, 10);\n  }\n\n  closeTimePopUp() {\n    setTimeout(() => {\n      this.setState({ opened: false });\n    }, 10);\n  }\n\n  buildTimeOptions() {\n    const [resolution, format, inputValue] = [\n      this.props.resolution,\n      this.props.format,\n      this.props.inputValue,\n    ];\n    // min 10 - max 30 || default 30 min || format 12||24\n    const step = resolution in this.timeepoch ? resolution : 30;\n    let loops = this.timeepoch.DAY / this.timeepoch[step] + 1;\n    let [hour, min, AMPM] = [0, 0, 'AM'];\n    let [minToDisplay, hour12format, hour24format, finalOption] = [0, 0, 0, 0];\n    let isSelected = 'none';\n    const options = [];\n\n    while (loops) {\n      minToDisplay = min === 0 ? '00' : min;\n      hour12format = hour > 12 ? hour - 12 : hour;\n      hour12format = hour === 0 ? 12 : hour12format;\n      hour12format = hour12format < 10 ? `0${hour12format}` : hour12format; // optional\n      hour24format = hour < 10 ? `0${hour}` : hour; // optional\n      finalOption =\n        format === 12\n          ? `${hour12format}:${minToDisplay} ${AMPM}`\n          : `${hour24format}:${minToDisplay}`;\n      isSelected = finalOption === inputValue ? 'check' : 'none';\n      options.push(\n        <DropdownMenuItem\n          key={loops}\n          onClick={this.onMenuItemClick}\n          icon={isSelected}\n          value={finalOption}\n        >\n          {finalOption}\n        </DropdownMenuItem>\n      );\n      min += step;\n      if (min === 60) {\n        hour += 1;\n        min = 0;\n      }\n      if (hour === 12 && min === 0) {\n        AMPM = AMPM === 'AM' ? 'PM' : 'AM';\n      }\n      loops--;\n    }\n    return options;\n  }\n\n  inputRef(ref) {\n    this.input = ref;\n  }\n\n  dropdownRef(ref) {\n    this.dropdown = ref;\n  }\n\n  renderInput({\n    inputValue,\n    openMenuOnInputClick,\n    dontUseDefaultValue,\n    ...props,\n  }) {\n    const internalInputValue = dontUseDefaultValue\n      ? this.state.inputValue\n      : this.state.inputValue || inputValue;\n    return (\n      <div className='slds-input-has-icon slds-input-has-icon--right'>\n        <Input\n          ref={this.inputRef}\n          {...props}\n          value={internalInputValue}\n          onKeyDown={this.onInputKeyDown.bind(this)}\n          onChange={this.onInputChange.bind(this)}\n          onBlur={this.onInputBlur.bind(this)}\n          onClick={\n            openMenuOnInputClick ? this.toggleTimemenu.bind(this) : undefined\n          }\n        />\n        <Icon\n          icon='clock'\n          className='slds-input__icon'\n          style={{ cursor: 'pointer' }}\n          onClick={this.toggleTimemenu.bind(this)}\n        />\n      </div>\n    );\n  }\n\n  render() {\n    const id = this.props.id || this.state.id;\n    const {\n      className,\n      totalCols,\n      cols,\n      label,\n      required,\n      error,\n      maxHeight,\n      tooltip,\n      ...props,\n    } = this.props;\n\n    const dropdownClassNames = classnames(className, 'slds-dropdown-trigger', {\n      'react-slds-dropdown-opened': this.state.opened,\n    });\n\n    const formElemProps = { id, totalCols, cols, label, required, error, tooltip };\n    delete props.resolution;\n    delete props.onValueChange;\n    return (\n      <FormElement key={id} {...formElemProps}>\n        <div className={dropdownClassNames}>\n          {this.renderInput({ id, ...props })}\n          <DropdownMenu\n            align={'left'}\n            size={'small'}\n            autoFocus\n            ref={this.dropdownRef}\n            maxHeight={maxHeight}\n            onKeyDown={this.onInputKeyDown.bind(this)}\n            onBlur={this.onDropdownBlur.bind(this)}\n          >\n            {this.options}\n          </DropdownMenu>\n        </div>\n      </FormElement>\n    );\n  }\n}\n\nTimeInput.propTypes = {\n  id: PropTypes.string,\n  className: PropTypes.string,\n  label: PropTypes.string,\n  required: PropTypes.bool,\n  format: PropTypes.number,\n  resolution: PropTypes.number,\n  inputValue: PropTypes.string,\n  maxHeight: PropTypes.number,\n  onMenuItemClick: PropTypes.func,\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  dontUseDefaultValue: PropTypes.bool,\n  openMenuOnInputClick: PropTypes.bool,\n  tooltip: PropTypes.element,\n};\n\nTimeInput.isFormElement = true;\n"]}