@elastic/eui
Version:
Elastic UI Component Library
171 lines (170 loc) • 8.61 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _typeof = require("@babel/runtime/helpers/typeof");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _react = _interopRequireDefault(require("react"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var _day = _interopRequireDefault(require("./day"));
var _week_number = _interopRequireDefault(require("./week_number"));
var utils = _interopRequireWildcard(require("./date_utils"));
var _react2 = require("@emotion/react");
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
function _callSuper(t, o, e) { return o = (0, _getPrototypeOf2.default)(o), (0, _possibleConstructorReturn2.default)(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], (0, _getPrototypeOf2.default)(t).constructor) : o.apply(t, e)); }
function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } /*
* The MIT License (MIT)
*
* Copyright (c) 2018 HackerOne Inc and individual contributors
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in all
* copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
* SOFTWARE.
*
*/
var Week = exports.default = /*#__PURE__*/function (_React$Component) {
function Week() {
var _this;
(0, _classCallCheck2.default)(this, Week);
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
args[_key] = arguments[_key];
}
_this = _callSuper(this, Week, [].concat(args));
(0, _defineProperty2.default)(_this, "handleDayClick", function (day, event) {
if (_this.props.onDayClick) {
_this.props.onDayClick(day, event);
}
});
(0, _defineProperty2.default)(_this, "handleDayMouseEnter", function (day) {
if (_this.props.onDayMouseEnter) {
_this.props.onDayMouseEnter(day);
}
});
(0, _defineProperty2.default)(_this, "handleWeekClick", function (day, weekNumber, event) {
if (typeof _this.props.onWeekSelect === "function") {
_this.props.onWeekSelect(day, weekNumber, event);
}
if (_this.props.shouldCloseOnSelect) {
_this.props.setOpen(false);
}
});
(0, _defineProperty2.default)(_this, "formatWeekNumber", function (startOfWeek) {
if (_this.props.formatWeekNumber) {
return _this.props.formatWeekNumber(startOfWeek);
}
return utils.getWeek(startOfWeek);
});
(0, _defineProperty2.default)(_this, "renderDays", function () {
var startOfWeek = utils.getStartOfWeek(utils.cloneDate(_this.props.day));
var days = [];
var weekNumber = _this.formatWeekNumber(startOfWeek);
if (_this.props.showWeekNumber) {
var onClickAction = _this.props.onWeekSelect ? _this.handleWeekClick.bind(_this, startOfWeek, weekNumber) : undefined;
days.push((0, _react2.jsx)(_week_number.default, {
key: "W",
weekNumber: weekNumber,
onClick: onClickAction
}));
}
return days.concat([0, 1, 2, 3, 4, 5, 6].map(function (offset) {
var day = utils.addDays(utils.cloneDate(startOfWeek), offset);
return (0, _react2.jsx)(_day.default, {
key: offset,
day: day,
month: _this.props.month,
onClick: _this.handleDayClick.bind(_this, day),
onMouseEnter: _this.handleDayMouseEnter.bind(_this, day),
minDate: _this.props.minDate,
maxDate: _this.props.maxDate,
excludeDates: _this.props.excludeDates,
includeDates: _this.props.includeDates,
inline: _this.props.inline,
highlightDates: _this.props.highlightDates,
selectingDate: _this.props.selectingDate,
filterDate: _this.props.filterDate,
preSelection: _this.props.preSelection,
selected: _this.props.selected,
selectsStart: _this.props.selectsStart,
selectsEnd: _this.props.selectsEnd,
startDate: _this.props.startDate,
endDate: _this.props.endDate,
dayClassName: _this.props.dayClassName,
utcOffset: _this.props.utcOffset,
renderDayContents: _this.props.renderDayContents,
disabledKeyboardNavigation: _this.props.disabledKeyboardNavigation,
accessibleMode: _this.props.accessibleMode
});
}));
});
return _this;
}
(0, _inherits2.default)(Week, _React$Component);
return (0, _createClass2.default)(Week, [{
key: "render",
value: function render() {
return (0, _react2.jsx)("div", {
className: "react-datepicker__week"
}, this.renderDays());
}
}], [{
key: "defaultProps",
get: function get() {
return {
shouldCloseOnSelect: true
};
}
}]);
}(_react.default.Component);
(0, _defineProperty2.default)(Week, "propTypes", {
disabledKeyboardNavigation: _propTypes.default.bool,
day: _propTypes.default.object.isRequired,
dayClassName: _propTypes.default.func,
endDate: _propTypes.default.object,
excludeDates: _propTypes.default.array,
filterDate: _propTypes.default.func,
formatWeekNumber: _propTypes.default.func,
highlightDates: _propTypes.default.instanceOf(Map),
includeDates: _propTypes.default.array,
inline: _propTypes.default.bool,
maxDate: _propTypes.default.object,
minDate: _propTypes.default.object,
month: _propTypes.default.number,
onDayClick: _propTypes.default.func,
onDayMouseEnter: _propTypes.default.func,
onWeekSelect: _propTypes.default.func,
preSelection: _propTypes.default.object,
selected: _propTypes.default.object,
selectingDate: _propTypes.default.object,
selectsEnd: _propTypes.default.bool,
selectsStart: _propTypes.default.bool,
showWeekNumber: _propTypes.default.bool,
startDate: _propTypes.default.object,
setOpen: _propTypes.default.func,
shouldCloseOnSelect: _propTypes.default.bool,
utcOffset: _propTypes.default.oneOfType([_propTypes.default.number, _propTypes.default.string]),
renderDayContents: _propTypes.default.func,
accessibleMode: _propTypes.default.bool
});
module.exports = exports.default;