react-lightning-design-components
Version:
Salesforce Lightning Design System components built with React 16
408 lines (365 loc) • 37 kB
JavaScript
'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"]}