UNPKG

react-lightning-design-components

Version:

Salesforce Lightning Design System components built with React 16

408 lines (365 loc) 37 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); 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 _Button = require('./Button'); var _Button2 = _interopRequireDefault(_Button); var _Picklist = require('./Picklist'); var _Picklist2 = _interopRequireDefault(_Picklist); var _reactOnclickoutside = require('react-onclickoutside'); var _reactOnclickoutside2 = _interopRequireDefault(_reactOnclickoutside); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function createCalendarObject(date) { var d = (0, _moment2.default)(date, 'YYYY-MM-DD'); if (!d.isValid()) { d = (0, _moment2.default)(); } var year = d.year(); var month = d.month(); var first = (0, _moment2.default)(d).startOf('month').startOf('week'); var last = (0, _moment2.default)(d).endOf('month').endOf('week'); var weeks = []; var days = []; for (var dd = first; dd.isBefore(last); dd = dd.add(1, 'd')) { days.push({ year: dd.year(), month: dd.month(), date: dd.date(), value: dd.format('YYYY-MM-DD') }); if (days.length === 7) { weeks.push(days); days = []; } } return { year: year, month: month, weeks: weeks }; } function cancelEvent(e) { e.preventDefault(); e.stopPropagation(); } var Datepicker = function (_Component) { (0, _inherits3.default)(Datepicker, _Component); function Datepicker(props) { (0, _classCallCheck3.default)(this, Datepicker); var _this = (0, _possibleConstructorReturn3.default)(this, (Datepicker.__proto__ || (0, _getPrototypeOf2.default)(Datepicker)).call(this, props)); _this.handleClickOutside = _this.handleClickOutside.bind(_this); var targetDate = _this.props.selectedDate || (0, _moment2.default)().format('YYYY-MM-DD'); _this.state = { targetDate: targetDate }; _this.monthRef = _this.monthRef.bind(_this); _this.datepickerRef = _this.datepickerRef.bind(_this); return _this; } (0, _createClass3.default)(Datepicker, [{ key: 'componentDidMount', value: function componentDidMount() { if (this.props.autoFocus) { var targetDate = this.props.selectedDate || (0, _moment2.default)().format('YYYY-MM-DD'); this.focusDate(targetDate); } } }, { key: 'componentDidUpdate', value: function componentDidUpdate() { if (this.state.focusDate && (this.state.targetDate || this.props.selectedDate)) { this.focusDate(this.state.targetDate || this.props.selectedDate); /* eslint-disable react/no-did-update-set-state */ this.setState({ focusDate: false }); } } }, { key: 'onDateKeyDown', value: function onDateKeyDown(date, e) { var targetDate = this.state.targetDate || this.props.selectedDate; if (e.keyCode === 13 || e.keyCode === 32) { // return / space this.onDateClick(date); e.preventDefault(); e.stopPropagation(); } else if (e.keyCode >= 37 && e.keyCode <= 40) { // cursor key if (e.keyCode === 37) { targetDate = (0, _moment2.default)(targetDate).add(-1, e.shiftKey ? 'months' : 'days'); } else if (e.keyCode === 39) { // right arrow key targetDate = (0, _moment2.default)(targetDate).add(1, e.shiftKey ? 'months' : 'days'); } else if (e.keyCode === 38) { // up arrow key targetDate = (0, _moment2.default)(targetDate).add(-1, e.shiftKey ? 'years' : 'weeks'); } else if (e.keyCode === 40) { // down arrow key targetDate = (0, _moment2.default)(targetDate).add(1, e.shiftKey ? 'years' : 'weeks'); } targetDate = targetDate.format('YYYY-MM-DD'); this.setState({ targetDate: targetDate, focusDate: true }); e.preventDefault(); e.stopPropagation(); } } }, { key: 'onDateClick', value: function onDateClick(date) { if (this.props.onSelect) { this.props.onSelect(date); } } }, { key: 'onDateFocus', value: function onDateFocus(date) { if (this.state.targetDate !== date) { this.setState({ targetDate: date }); } } }, { key: 'onYearChange', value: function onYearChange(item) { var targetDate = this.state.targetDate || this.props.selectedDate; targetDate = (0, _moment2.default)(targetDate).year(item.value).format('YYYY-MM-DD'); this.setState({ targetDate: targetDate }); } }, { key: 'onMonthChange', value: function onMonthChange(month) { var targetDate = this.state.targetDate || this.props.selectedDate; targetDate = (0, _moment2.default)(targetDate).add(month, 'months').format('YYYY-MM-DD'); this.setState({ targetDate: targetDate }); } }, { key: 'onKeyDown', value: function onKeyDown(e) { if (e.keyCode === 27) { // ESC if (this.props.onClose) { this.props.onClose(); } } } // provided by 'react-onclickoutside' }, { key: 'handleClickOutside', value: function handleClickOutside(e) { if (this.props.onBlur) { this.props.onBlur(e); } } }, { key: 'focusDate', value: function focusDate(date) { var el = _reactDom2.default.findDOMNode(this.month); var dateEl = el.querySelector('.slds-day[data-date-value="' + date + '"]'); if (dateEl) { dateEl.focus(); } } }, { key: 'monthRef', value: function monthRef(ref) { this.month = ref; } }, { key: 'datepickerRef', value: function datepickerRef(ref) { this.datepicker = ref; } }, { key: 'renderFilter', value: function renderFilter(cal) { /* eslint-disable max-len */ var startYear = this.props.userCurrentYear ? (0, _moment2.default)().year() : cal.year; var minYear = startYear - this.props.backRange; return _react2.default.createElement( 'div', { className: 'slds-datepicker__filter slds-grid' }, _react2.default.createElement( 'div', { className: 'slds-datepicker__filter--month slds-grid slds-grid--align-spread slds-size--2-of-3' }, _react2.default.createElement( 'div', { className: 'slds-align-middle' }, _react2.default.createElement(_Button2.default, { className: 'slds-align-middle', type: 'icon-container', icon: 'left', size: 'small', alt: 'Previous Month', onClick: this.onMonthChange.bind(this, -1) }) ), _react2.default.createElement( 'h2', { className: 'slds-align-middle' }, _moment2.default.monthsShort()[cal.month] ), _react2.default.createElement( 'div', { className: 'slds-align-middle' }, _react2.default.createElement(_Button2.default, { className: 'slds-align-middle', type: 'icon-container', icon: 'right', size: 'small', alt: 'Next Month', onClick: this.onMonthChange.bind(this, 1) }) ) ), _react2.default.createElement( 'div', { className: 'slds-size--1-of-3' }, _react2.default.createElement( _Picklist2.default, { className: 'slds-picklist--fluid slds-shrink-none', value: cal.year, maxHeight: this.props.pickListHeight, onSelect: this.onYearChange.bind(this) }, new Array(this.props.backRange + this.props.futureRange).join('_').split('_').map(function (a, i) { var year = minYear + i; return _react2.default.createElement(_Picklist.PicklistItem, { key: year, label: year, value: year }); }) ) ) ); } }, { key: 'renderMonth', value: function renderMonth(cal, selectedDate, today) { var _this2 = this; return _react2.default.createElement( 'table', { className: 'datepicker__month', role: 'grid', 'aria-labelledby': 'month', ref: this.monthRef }, _react2.default.createElement( 'thead', null, _react2.default.createElement( 'tr', null, _moment2.default.weekdaysMin(true).map(function (wd, i) { return _react2.default.createElement( 'th', { key: i }, _react2.default.createElement( 'abbr', { title: _moment2.default.weekdays(true, i) }, wd ) ); }) ) ), _react2.default.createElement( 'tbody', null, cal.weeks.map(function (days, i) { return _react2.default.createElement( 'tr', { key: i }, days.map(_this2.renderDate.bind(_this2, cal, selectedDate, today)) ); }) ) ); } }, { key: 'renderDate', value: function renderDate(cal, selectedDate, today, d, i) { var enabled = d.year === cal.year && d.month === cal.month; if (this.props.disablePastDateSelection) enabled = d.value >= today; var selected = d.value === selectedDate; var isToday = d.value === today; var dateClassName = (0, _classnames2.default)({ 'slds-disabled-text': !enabled, 'slds-is-selected': selected, 'slds-is-today': isToday }); return _react2.default.createElement( 'td', { className: dateClassName, key: i, headers: _moment2.default.weekdays(i), role: 'gridcell', 'aria-disabled': !enabled, 'aria-selected': selected }, _react2.default.createElement( 'span', { className: 'slds-day', tabIndex: enabled ? 0 : -1, onClick: enabled ? this.onDateClick.bind(this, d.value) : null, onKeyDown: enabled ? this.onDateKeyDown.bind(this, d.value) : null, onFocus: enabled ? this.onDateFocus.bind(this, d.value) : cancelEvent, 'data-date-value': d.value }, d.date ) ); } }, { key: 'render', value: function render() { var _props = this.props, className = _props.className, selectedDate = _props.selectedDate; var today = (0, _moment2.default)().format('YYYY-MM-DD'); var targetDate = this.state.targetDate || selectedDate; var cal = createCalendarObject(targetDate); var datepickerClassNames = (0, _classnames2.default)('slds-datepicker', className); return _react2.default.createElement( 'div', { className: datepickerClassNames, ref: this.datepickerRef, 'aria-hidden': false, onKeyDown: this.onKeyDown.bind(this) }, this.renderFilter(cal), this.renderMonth(cal, selectedDate, today) ); } }]); return Datepicker; }(_react.Component); Datepicker.defaultProps = { backRange: 100, futureRange: 30, userCurrentYear: true, pickListHeight: 5 }; Datepicker.propTypes = { className: _propTypes2.default.string, selectedDate: _propTypes2.default.string, autoFocus: _propTypes2.default.bool, onSelect: _propTypes2.default.func, onBlur: _propTypes2.default.func, onClose: _propTypes2.default.func, disablePastDateSelection: _propTypes2.default.bool, userCurrentYear: _propTypes2.default.bool, backRange: _propTypes2.default.number, futureRange: _propTypes2.default.number, pickListHeight: _propTypes2.default.oneOf([5, 7, 10]) }; exports.default = (0, _reactOnclickoutside2.default)(Datepicker); //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/scripts/Datepicker.js"],"names":["createCalendarObject","date","d","isValid","year","month","first","startOf","last","endOf","weeks","days","dd","isBefore","add","push","value","format","length","cancelEvent","e","preventDefault","stopPropagation","Datepicker","props","handleClickOutside","bind","targetDate","selectedDate","state","monthRef","datepickerRef","autoFocus","focusDate","setState","keyCode","onDateClick","shiftKey","onSelect","item","onClose","onBlur","el","findDOMNode","dateEl","querySelector","focus","ref","datepicker","cal","startYear","userCurrentYear","minYear","backRange","onMonthChange","monthsShort","pickListHeight","onYearChange","Array","futureRange","join","split","map","a","i","today","weekdaysMin","wd","weekdays","renderDate","enabled","disablePastDateSelection","selected","isToday","dateClassName","onDateKeyDown","onDateFocus","className","datepickerClassNames","onKeyDown","renderFilter","renderMonth","defaultProps","propTypes","string","bool","func","number","oneOf"],"mappings":"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","file":"Datepicker.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 Button from './Button';\nimport { default as Picklist, PicklistItem } from './Picklist';\nimport onClickOutside from 'react-onclickoutside';\n\nfunction createCalendarObject(date) {\n  let d = moment(date, 'YYYY-MM-DD');\n  if (!d.isValid()) {\n    d = moment();\n  }\n  const year = d.year();\n  const month = d.month();\n  const first = moment(d).startOf('month').startOf('week');\n  const last = moment(d).endOf('month').endOf('week');\n  const weeks = [];\n  let days = [];\n  for (let dd = first; dd.isBefore(last); dd = dd.add(1, 'd')) {\n    days.push({\n      year: dd.year(),\n      month: dd.month(),\n      date: dd.date(),\n      value: dd.format('YYYY-MM-DD'),\n    });\n    if (days.length === 7) {\n      weeks.push(days);\n      days = [];\n    }\n  }\n  return { year, month, weeks };\n}\n\nfunction cancelEvent(e) {\n  e.preventDefault();\n  e.stopPropagation();\n}\n\nclass Datepicker extends Component {\n  constructor(props) {\n    super(props);\n    this.handleClickOutside = this.handleClickOutside.bind(this);\n    const targetDate = this.props.selectedDate || moment().format('YYYY-MM-DD');\n    this.state = { targetDate };\n    this.monthRef = this.monthRef.bind(this);\n    this.datepickerRef = this.datepickerRef.bind(this);\n  }\n\n  componentDidMount() {\n    if (this.props.autoFocus) {\n      const targetDate = this.props.selectedDate || moment().format('YYYY-MM-DD');\n      this.focusDate(targetDate);\n    }\n  }\n\n  componentDidUpdate() {\n    if (this.state.focusDate && (this.state.targetDate || this.props.selectedDate)) {\n      this.focusDate(this.state.targetDate || this.props.selectedDate);\n      /* eslint-disable react/no-did-update-set-state */\n      this.setState({ focusDate: false });\n    }\n  }\n\n  onDateKeyDown(date, e) {\n    let targetDate = this.state.targetDate || this.props.selectedDate;\n    if (e.keyCode === 13 || e.keyCode === 32) { // return / space\n      this.onDateClick(date);\n      e.preventDefault();\n      e.stopPropagation();\n    } else if (e.keyCode >= 37 && e.keyCode <= 40) { // cursor key\n      if (e.keyCode === 37) {\n        targetDate = moment(targetDate).add(-1, e.shiftKey ? 'months' : 'days');\n      } else if (e.keyCode === 39) { // right arrow key\n        targetDate = moment(targetDate).add(1, e.shiftKey ? 'months' : 'days');\n      } else if (e.keyCode === 38) { // up arrow key\n        targetDate = moment(targetDate).add(-1, e.shiftKey ? 'years' : 'weeks');\n      } else if (e.keyCode === 40) { // down arrow key\n        targetDate = moment(targetDate).add(1, e.shiftKey ? 'years' : 'weeks');\n      }\n      targetDate = targetDate.format('YYYY-MM-DD');\n      this.setState({ targetDate, focusDate: true });\n      e.preventDefault();\n      e.stopPropagation();\n    }\n  }\n\n  onDateClick(date) {\n    if (this.props.onSelect) {\n      this.props.onSelect(date);\n    }\n  }\n\n  onDateFocus(date) {\n    if (this.state.targetDate !== date) {\n      this.setState({ targetDate: date });\n    }\n  }\n\n  onYearChange(item) {\n    let targetDate = this.state.targetDate || this.props.selectedDate;\n    targetDate = moment(targetDate).year(item.value).format('YYYY-MM-DD');\n    this.setState({ targetDate });\n  }\n\n  onMonthChange(month) {\n    let targetDate = this.state.targetDate || this.props.selectedDate;\n    targetDate = moment(targetDate).add(month, 'months').format('YYYY-MM-DD');\n    this.setState({ targetDate });\n  }\n\n  onKeyDown(e) {\n    if (e.keyCode === 27) { // ESC\n      if (this.props.onClose) {\n        this.props.onClose();\n      }\n    }\n  }\n\n  // provided by 'react-onclickoutside'\n  handleClickOutside(e) {\n    if (this.props.onBlur) {\n      this.props.onBlur(e);\n    }\n  }\n\n  focusDate(date) {\n    const el = ReactDOM.findDOMNode(this.month);\n    const dateEl = el.querySelector(`.slds-day[data-date-value=\"${date}\"]`);\n    if (dateEl) {\n      dateEl.focus();\n    }\n  }\n\n  monthRef(ref) {\n    this.month = ref;\n  }\n\n  datepickerRef(ref) {\n    this.datepicker = ref;\n  }\n\n  renderFilter(cal) {\n    /* eslint-disable max-len */\n    const startYear = this.props.userCurrentYear ? moment().year() : cal.year;\n    const minYear = startYear - this.props.backRange;\n    return (\n      <div className='slds-datepicker__filter slds-grid'>\n        <div className='slds-datepicker__filter--month slds-grid slds-grid--align-spread slds-size--2-of-3'>\n          <div className='slds-align-middle'>\n            <Button\n              className='slds-align-middle'\n              type='icon-container'\n              icon='left'\n              size='small'\n              alt='Previous Month'\n              onClick={ this.onMonthChange.bind(this, -1) }\n            />\n          </div>\n          <h2 className='slds-align-middle'>{ moment.monthsShort()[cal.month] }</h2>\n          <div className='slds-align-middle'>\n            <Button\n              className='slds-align-middle'\n              type='icon-container'\n              icon='right'\n              size='small'\n              alt='Next Month'\n              onClick={ this.onMonthChange.bind(this, 1) }\n            />\n          </div>\n        </div>\n        <div className='slds-size--1-of-3'>\n          <Picklist\n            className='slds-picklist--fluid slds-shrink-none'\n            value={ cal.year }\n            maxHeight={this.props.pickListHeight}\n            onSelect={ this.onYearChange.bind(this) }\n          >\n            {\n              new Array((this.props.backRange + this.props.futureRange)).join('_').split('_')\n                .map((a, i) => {\n                  let year = minYear + i;\n                  return <PicklistItem key={ year } label={ year } value={ year } />;\n                })\n            }\n          </Picklist>\n        </div>\n      </div>\n    );\n  }\n\n  renderMonth(cal, selectedDate, today) {\n    return (\n      <table className='datepicker__month' role='grid' aria-labelledby='month' ref={this.monthRef}>\n        <thead>\n          <tr>\n            {\n              moment.weekdaysMin(true).map((wd, i) => (\n                <th key={ i }>\n                  <abbr title={ moment.weekdays(true, i) }>{ wd }</abbr>\n                </th>\n              ))\n            }\n          </tr>\n        </thead>\n        <tbody>\n          {\n            cal.weeks.map((days, i) => (\n              <tr key={ i }>{ days.map(this.renderDate.bind(this, cal, selectedDate, today)) }</tr>\n            ))\n          }\n        </tbody>\n      </table>\n    );\n  }\n\n  renderDate(cal, selectedDate, today, d, i) {\n    let enabled = d.year === cal.year && d.month === cal.month;\n    if (this.props.disablePastDateSelection) enabled = d.value >= today;\n    const selected = d.value === selectedDate;\n    const isToday = d.value === today;\n    const dateClassName = classnames({\n      'slds-disabled-text': !enabled,\n      'slds-is-selected': selected,\n      'slds-is-today': isToday,\n    });\n    return (\n      <td\n        className={ dateClassName }\n        key={ i }\n        headers={ moment.weekdays(i) }\n        role='gridcell'\n        aria-disabled={ !enabled }\n        aria-selected={ selected }\n      >\n        <span\n          className='slds-day'\n          tabIndex={ enabled ? 0 : -1 }\n          onClick={ enabled ? this.onDateClick.bind(this, d.value) : null }\n          onKeyDown={ enabled ? this.onDateKeyDown.bind(this, d.value) : null }\n          onFocus={ enabled ? this.onDateFocus.bind(this, d.value) : cancelEvent }\n          data-date-value={ d.value }\n        >{ d.date }</span>\n      </td>\n    );\n  }\n\n  render() {\n    const { className, selectedDate } = this.props;\n    const today = moment().format('YYYY-MM-DD');\n    const targetDate = this.state.targetDate || selectedDate;\n    const cal = createCalendarObject(targetDate);\n    const datepickerClassNames = classnames('slds-datepicker', className);\n    return (\n      <div\n        className={ datepickerClassNames }\n        ref={this.datepickerRef}\n        aria-hidden={ false }\n        onKeyDown={ this.onKeyDown.bind(this) }\n      >\n        { this.renderFilter(cal) }\n        { this.renderMonth(cal, selectedDate, today) }\n      </div>\n    );\n  }\n}\n\nDatepicker.defaultProps = {\n  backRange: 100,\n  futureRange: 30,\n  userCurrentYear: true,\n  pickListHeight: 5,\n\n};\n\nDatepicker.propTypes = {\n  className: PropTypes.string,\n  selectedDate: PropTypes.string,\n  autoFocus: PropTypes.bool,\n  onSelect: PropTypes.func,\n  onBlur: PropTypes.func,\n  onClose: PropTypes.func,\n  disablePastDateSelection: PropTypes.bool,\n  userCurrentYear: PropTypes.bool,\n  backRange: PropTypes.number,\n  futureRange: PropTypes.number,\n  pickListHeight: PropTypes.oneOf([5, 7, 10]),\n};\n\nexport default onClickOutside(Datepicker);\n"]}