@i-novus/n2o-components 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/index.js +0 -0
- package/lib/display/Alerts/Alert.d.ts +2 -0
- package/lib/display/Alerts/Alert.js +121 -0
- package/lib/display/Alerts/AlertSection.d.ts +18 -0
- package/lib/display/Alerts/AlertSection.js +64 -0
- package/lib/display/Alerts/AlertWrapper.d.ts +6 -0
- package/lib/display/Alerts/AlertWrapper.js +39 -0
- package/lib/display/Alerts/DefaultAlert.d.ts +6 -0
- package/lib/display/Alerts/DefaultAlert.js +125 -0
- package/lib/display/Alerts/LoaderAlert.d.ts +5 -0
- package/lib/display/Alerts/LoaderAlert.js +36 -0
- package/lib/display/Alerts/types.d.ts +49 -0
- package/lib/display/Alerts/types.js +24 -0
- package/lib/display/Alerts/utils.d.ts +15 -0
- package/lib/display/Alerts/utils.js +102 -0
- package/lib/display/Badge/Badge.d.ts +16 -0
- package/lib/display/Badge/Badge.js +77 -0
- package/lib/display/Badge/enums.d.ts +9 -0
- package/lib/display/Badge/enums.js +23 -0
- package/lib/display/Badge/utils.d.ts +9 -0
- package/lib/display/Badge/utils.js +49 -0
- package/lib/display/Block.d.ts +369 -0
- package/lib/display/Block.js +38 -0
- package/lib/display/CodeViewer/CodeViewer.d.ts +13 -0
- package/lib/display/CodeViewer/CodeViewer.js +96 -0
- package/lib/display/Drawer/Drawer.d.ts +25 -0
- package/lib/display/Drawer/Drawer.js +99 -0
- package/lib/display/DropdownCustomItem.d.ts +7 -0
- package/lib/display/DropdownCustomItem.js +23 -0
- package/lib/display/Filter/Buttons.d.ts +11 -0
- package/lib/display/Filter/Buttons.js +42 -0
- package/lib/display/Filter/Filter.d.ts +8 -0
- package/lib/display/Filter/Filter.js +38 -0
- package/lib/display/HelpPopover.d.ts +16 -0
- package/lib/display/HelpPopover.js +104 -0
- package/lib/display/Html.d.ts +8 -0
- package/lib/display/Html.js +29 -0
- package/lib/display/Icon/Icon.d.ts +11 -0
- package/lib/display/Icon/Icon.js +42 -0
- package/lib/display/Image/Image.d.ts +30 -0
- package/lib/display/Image/Image.js +93 -0
- package/lib/display/Image/ImageInfo.d.ts +7 -0
- package/lib/display/Image/ImageInfo.js +23 -0
- package/lib/display/InputIcon.d.ts +13 -0
- package/lib/display/InputIcon.js +33 -0
- package/lib/display/NavItemImage/NavItemImage.d.ts +9 -0
- package/lib/display/NavItemImage/NavItemImage.js +35 -0
- package/lib/display/OutputList.d.ts +12 -0
- package/lib/display/OutputList.js +46 -0
- package/lib/display/OutputListItem.d.ts +10 -0
- package/lib/display/OutputListItem.js +58 -0
- package/lib/display/OutputText.d.ts +15 -0
- package/lib/display/OutputText.js +170 -0
- package/lib/display/Pagination/Pagination.d.ts +2 -0
- package/lib/display/Pagination/Pagination.js +273 -0
- package/lib/display/Pagination/PaginationButton.d.ts +13 -0
- package/lib/display/Pagination/PaginationButton.js +53 -0
- package/lib/display/Pagination/types.d.ts +62 -0
- package/lib/display/Pagination/types.js +36 -0
- package/lib/display/PopoverConfirm/PopoverConfirm.d.ts +30 -0
- package/lib/display/PopoverConfirm/PopoverConfirm.js +87 -0
- package/lib/display/ProgressControl/ProgressControl.d.ts +17 -0
- package/lib/display/ProgressControl/ProgressControl.js +68 -0
- package/lib/display/Slider.d.ts +23 -0
- package/lib/display/Slider.js +107 -0
- package/lib/display/Status.d.ts +9 -0
- package/lib/display/Status.js +40 -0
- package/lib/display/StatusText/StatusText.d.ts +10 -0
- package/lib/display/StatusText/StatusText.js +35 -0
- package/lib/display/StatusText/types.d.ts +18 -0
- package/lib/display/StatusText/types.js +19 -0
- package/lib/display/StatusText/utils.d.ts +3 -0
- package/lib/display/StatusText/utils.js +29 -0
- package/lib/display/Text.d.ts +12 -0
- package/lib/display/Text.js +38 -0
- package/lib/display/Typography/Base.d.ts +32 -0
- package/lib/display/Typography/Base.js +259 -0
- package/lib/display/Typography/ContentEditable.d.ts +15 -0
- package/lib/display/Typography/ContentEditable.js +86 -0
- package/lib/display/Typography/Paragraph.d.ts +4 -0
- package/lib/display/Typography/Paragraph.js +23 -0
- package/lib/display/Typography/Text.d.ts +9 -0
- package/lib/display/Typography/Text.js +37 -0
- package/lib/display/Typography/Title.d.ts +7 -0
- package/lib/display/Typography/Title.js +28 -0
- package/lib/display/Typography/utils.d.ts +13 -0
- package/lib/display/Typography/utils.js +75 -0
- package/lib/helpers/HelpPopover.d.ts +9 -0
- package/lib/helpers/HelpPopover.js +46 -0
- package/lib/helpers/withRightPlaceholder.d.ts +9 -0
- package/lib/helpers/withRightPlaceholder.js +35 -0
- package/lib/inputs/Checkbox/Checkbox.d.ts +29 -0
- package/lib/inputs/Checkbox/Checkbox.js +117 -0
- package/lib/inputs/Checkbox/CheckboxControl.d.ts +7 -0
- package/lib/inputs/Checkbox/CheckboxControl.js +33 -0
- package/lib/inputs/CheckboxGroup/CheckboxGroup.d.ts +11 -0
- package/lib/inputs/CheckboxGroup/CheckboxGroup.js +84 -0
- package/lib/inputs/CodeEditor/CodeEditor.d.ts +21 -0
- package/lib/inputs/CodeEditor/CodeEditor.js +85 -0
- package/lib/inputs/DatePicker/Calendar.d.ts +65 -0
- package/lib/inputs/DatePicker/Calendar.js +556 -0
- package/lib/inputs/DatePicker/CalendarHeader.d.ts +26 -0
- package/lib/inputs/DatePicker/CalendarHeader.js +213 -0
- package/lib/inputs/DatePicker/Clock.d.ts +10 -0
- package/lib/inputs/DatePicker/Clock.js +45 -0
- package/lib/inputs/DatePicker/DateInput.d.ts +44 -0
- package/lib/inputs/DatePicker/DateInput.js +262 -0
- package/lib/inputs/DatePicker/DateInputGroup.d.ts +20 -0
- package/lib/inputs/DatePicker/DateInputGroup.js +77 -0
- package/lib/inputs/DatePicker/DateInterval.d.ts +24 -0
- package/lib/inputs/DatePicker/DateInterval.js +92 -0
- package/lib/inputs/DatePicker/DatePicker.d.ts +22 -0
- package/lib/inputs/DatePicker/DatePicker.js +36 -0
- package/lib/inputs/DatePicker/DateTimeControl.d.ts +98 -0
- package/lib/inputs/DatePicker/DateTimeControl.js +452 -0
- package/lib/inputs/DatePicker/Day.d.ts +14 -0
- package/lib/inputs/DatePicker/Day.js +50 -0
- package/lib/inputs/DatePicker/PopUp.d.ts +19 -0
- package/lib/inputs/DatePicker/PopUp.js +71 -0
- package/lib/inputs/DatePicker/types.d.ts +31 -0
- package/lib/inputs/DatePicker/types.js +25 -0
- package/lib/inputs/DatePicker/utils.d.ts +39 -0
- package/lib/inputs/DatePicker/utils.js +304 -0
- package/lib/inputs/Input.d.ts +51 -0
- package/lib/inputs/Input.js +200 -0
- package/lib/inputs/InputMask/InputMask.d.ts +23 -0
- package/lib/inputs/InputMask/InputMask.js +310 -0
- package/lib/inputs/InputMoney/InputMoney.d.ts +101 -0
- package/lib/inputs/InputMoney/InputMoney.js +258 -0
- package/lib/inputs/InputNumber/InputNumber.d.ts +29 -0
- package/lib/inputs/InputNumber/InputNumber.js +316 -0
- package/lib/inputs/InputNumber/index.d.ts +1 -0
- package/lib/inputs/InputNumber/index.js +14 -0
- package/lib/inputs/InputNumber/types.d.ts +18 -0
- package/lib/inputs/InputNumber/types.js +14 -0
- package/lib/inputs/InputNumber/utils.d.ts +6 -0
- package/lib/inputs/InputNumber/utils.js +86 -0
- package/lib/inputs/InputPassword/InputPassword.d.ts +10 -0
- package/lib/inputs/InputPassword/InputPassword.js +81 -0
- package/lib/inputs/InputSelect/InputAddon.d.ts +17 -0
- package/lib/inputs/InputSelect/InputAddon.js +31 -0
- package/lib/inputs/InputSelect/InputContent.d.ts +63 -0
- package/lib/inputs/InputSelect/InputContent.js +188 -0
- package/lib/inputs/InputSelect/InputSelect.d.ts +296 -0
- package/lib/inputs/InputSelect/InputSelect.js +795 -0
- package/lib/inputs/InputSelect/InputSelectGroup.d.ts +43 -0
- package/lib/inputs/InputSelect/InputSelectGroup.js +113 -0
- package/lib/inputs/InputSelect/PopupItems.d.ts +55 -0
- package/lib/inputs/InputSelect/PopupItems.js +357 -0
- package/lib/inputs/InputSelect/PopupList.d.ts +82 -0
- package/lib/inputs/InputSelect/PopupList.js +138 -0
- package/lib/inputs/InputSelect/SelectedItems.d.ts +17 -0
- package/lib/inputs/InputSelect/SelectedItems.js +125 -0
- package/lib/inputs/InputSelect/constants.d.ts +4 -0
- package/lib/inputs/InputSelect/constants.js +15 -0
- package/lib/inputs/InputSelect/types.d.ts +16 -0
- package/lib/inputs/InputSelect/types.js +16 -0
- package/lib/inputs/InputSelect/utils.d.ts +9 -0
- package/lib/inputs/InputSelect/utils.js +142 -0
- package/lib/inputs/InputSelectTree/InputSelectTree.d.ts +114 -0
- package/lib/inputs/InputSelectTree/InputSelectTree.js +466 -0
- package/lib/inputs/InputSelectTree/TreeSelectNode.d.ts +36 -0
- package/lib/inputs/InputSelectTree/TreeSelectNode.js +63 -0
- package/lib/inputs/InputSelectTree/allProps.d.ts +123 -0
- package/lib/inputs/InputSelectTree/allProps.js +48 -0
- package/lib/inputs/InputSelectTree/until.d.ts +4 -0
- package/lib/inputs/InputSelectTree/until.js +83 -0
- package/lib/inputs/InputText.d.ts +41 -0
- package/lib/inputs/InputText.js +170 -0
- package/lib/inputs/NumberPicker/NumberPicker.d.ts +15 -0
- package/lib/inputs/NumberPicker/NumberPicker.js +129 -0
- package/lib/inputs/NumberPicker/NumberPickerButton.d.ts +8 -0
- package/lib/inputs/NumberPicker/NumberPickerButton.js +64 -0
- package/lib/inputs/NumberPicker/index.d.ts +1 -0
- package/lib/inputs/NumberPicker/index.js +14 -0
- package/lib/inputs/NumberPicker/utils.d.ts +2 -0
- package/lib/inputs/NumberPicker/utils.js +31 -0
- package/lib/inputs/RadioGroup/default/Group.d.ts +15 -0
- package/lib/inputs/RadioGroup/default/Group.js +63 -0
- package/lib/inputs/RadioGroup/default/Input.d.ts +17 -0
- package/lib/inputs/RadioGroup/default/Input.js +77 -0
- package/lib/inputs/RadioGroup/tabs/Group.d.ts +3 -0
- package/lib/inputs/RadioGroup/tabs/Group.js +24 -0
- package/lib/inputs/RadioGroup/tabs/Input.d.ts +3 -0
- package/lib/inputs/RadioGroup/tabs/Input.js +21 -0
- package/lib/inputs/Rating/Rating.d.ts +30 -0
- package/lib/inputs/Rating/Rating.js +212 -0
- package/lib/inputs/Select/Popup.d.ts +31 -0
- package/lib/inputs/Select/Popup.js +131 -0
- package/lib/inputs/Select/Select.d.ts +225 -0
- package/lib/inputs/Select/Select.js +705 -0
- package/lib/inputs/Select/SelectInput.d.ts +19 -0
- package/lib/inputs/Select/SelectInput.js +85 -0
- package/lib/inputs/Select/utils.d.ts +1 -0
- package/lib/inputs/Select/utils.js +28 -0
- package/lib/inputs/Switch/Switch.d.ts +11 -0
- package/lib/inputs/Switch/Switch.js +41 -0
- package/lib/inputs/TextArea.d.ts +12 -0
- package/lib/inputs/TextArea.js +54 -0
- package/lib/inputs/TextEditor/TextEditor.d.ts +11 -0
- package/lib/inputs/TextEditor/TextEditor.js +89 -0
- package/lib/inputs/TimePicker/TimePicker.d.ts +50 -0
- package/lib/inputs/TimePicker/TimePicker.js +398 -0
- package/lib/inputs/utils.d.ts +5 -0
- package/lib/inputs/utils.js +39 -0
- package/lib/layouts/ScrollContainer.d.ts +218 -0
- package/lib/layouts/ScrollContainer.js +128 -0
- package/lib/layouts/Spinner/CoverSpinner.d.ts +29 -0
- package/lib/layouts/Spinner/CoverSpinner.js +153 -0
- package/lib/layouts/Spinner/InlineSpinner.d.ts +5 -0
- package/lib/layouts/Spinner/InlineSpinner.js +27 -0
- package/lib/layouts/Spinner/Spinner.d.ts +31 -0
- package/lib/layouts/Spinner/Spinner.js +178 -0
- package/lib/styles/components/Calendar.scss +125 -0
- package/lib/styles/components/CalendarHeader.scss +75 -0
- package/lib/styles/components/DateInputGroup.scss +39 -0
- package/lib/styles/components/DatePicker.scss +18 -0
- package/lib/styles/components/Day.scss +29 -0
- package/lib/styles/components/OutputList.scss +14 -0
- package/lib/styles/components/OutputText.scss +50 -0
- package/lib/styles/controls/CodeEditor.scss +4 -0
- package/lib/styles/controls/InputNumber.scss +36 -0
- package/lib/styles/controls/InputPassword.scss +17 -0
- package/lib/styles/controls/InputText.scss +59 -0
- package/lib/styles/controls/NumberPicker.scss +36 -0
- package/lib/styles/controls/ProgressControl.scss +3 -0
- package/lib/styles/controls/Slider.scss +32 -0
- package/lib/styles/controls/Switch.scss +105 -0
- package/lib/styles/controls/TextEditor.scss +23 -0
- package/lib/styles/controls/TimePicker.scss +32 -0
- package/lib/styles/n2o/variables.scss +328 -0
- package/lib/styles/theme/variables.scss +81 -0
- package/lib/styles/variables.scss +10 -0
- package/lib/types.d.ts +25 -0
- package/lib/types.js +6 -0
- package/lib/utils/id.d.ts +3 -0
- package/lib/utils/id.js +46 -0
- package/lib/utils/isEmptyModel.d.ts +1 -0
- package/lib/utils/isEmptyModel.js +21 -0
- package/lib/utils/parseFormatter.js +153 -0
- package/package.json +196 -0
|
@@ -0,0 +1,556 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports.Calendar = void 0;
|
|
9
|
+
|
|
10
|
+
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
|
|
11
|
+
|
|
12
|
+
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
|
|
13
|
+
|
|
14
|
+
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
|
|
15
|
+
|
|
16
|
+
var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
|
|
17
|
+
|
|
18
|
+
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
|
|
19
|
+
|
|
20
|
+
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
|
|
21
|
+
|
|
22
|
+
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
|
|
23
|
+
|
|
24
|
+
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
25
|
+
|
|
26
|
+
var _react = _interopRequireDefault(require("react"));
|
|
27
|
+
|
|
28
|
+
var _isNull = _interopRequireDefault(require("lodash/isNull"));
|
|
29
|
+
|
|
30
|
+
var _moment = _interopRequireDefault(require("moment/moment"));
|
|
31
|
+
|
|
32
|
+
var _classnames = _interopRequireDefault(require("classnames"));
|
|
33
|
+
|
|
34
|
+
var _Day = require("./Day");
|
|
35
|
+
|
|
36
|
+
var _CalendarHeader = require("./CalendarHeader");
|
|
37
|
+
|
|
38
|
+
var _utils = require("./utils");
|
|
39
|
+
|
|
40
|
+
var _DateTimeControl = require("./DateTimeControl");
|
|
41
|
+
|
|
42
|
+
var _types = require("./types");
|
|
43
|
+
|
|
44
|
+
require("../../styles/components/Calendar.scss");
|
|
45
|
+
|
|
46
|
+
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
|
|
47
|
+
|
|
48
|
+
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
|
|
49
|
+
|
|
50
|
+
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; }
|
|
51
|
+
|
|
52
|
+
function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
|
|
53
|
+
|
|
54
|
+
var Calendar = /*#__PURE__*/function (_React$Component) {
|
|
55
|
+
(0, _inherits2["default"])(Calendar, _React$Component);
|
|
56
|
+
|
|
57
|
+
var _super = _createSuper(Calendar);
|
|
58
|
+
|
|
59
|
+
function Calendar(props) {
|
|
60
|
+
var _this;
|
|
61
|
+
|
|
62
|
+
(0, _classCallCheck2["default"])(this, Calendar);
|
|
63
|
+
_this = _super.call(this, props);
|
|
64
|
+
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "hourRef", null);
|
|
65
|
+
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "minuteRef", null);
|
|
66
|
+
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "secondRef", null);
|
|
67
|
+
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "changeCalendarType", function (type) {
|
|
68
|
+
_this.setState({
|
|
69
|
+
calendarType: type
|
|
70
|
+
});
|
|
71
|
+
});
|
|
72
|
+
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "setHourRef", function (el) {
|
|
73
|
+
_this.hourRef = el;
|
|
74
|
+
});
|
|
75
|
+
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "setMinuteRef", function (el) {
|
|
76
|
+
_this.minuteRef = el;
|
|
77
|
+
});
|
|
78
|
+
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "setSecondRef", function (el) {
|
|
79
|
+
_this.secondRef = el;
|
|
80
|
+
});
|
|
81
|
+
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "prevMonth", function () {
|
|
82
|
+
var displayesMonth = _this.state.displayesMonth;
|
|
83
|
+
|
|
84
|
+
_this.setState({
|
|
85
|
+
displayesMonth: displayesMonth.subtract(1, 'months')
|
|
86
|
+
});
|
|
87
|
+
});
|
|
88
|
+
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "nextMonth", function () {
|
|
89
|
+
var displayesMonth = _this.state.displayesMonth;
|
|
90
|
+
|
|
91
|
+
_this.setState({
|
|
92
|
+
displayesMonth: displayesMonth.add(1, 'months')
|
|
93
|
+
});
|
|
94
|
+
});
|
|
95
|
+
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "prevYear", function () {
|
|
96
|
+
var displayesMonth = _this.state.displayesMonth;
|
|
97
|
+
|
|
98
|
+
_this.setState({
|
|
99
|
+
displayesMonth: displayesMonth.subtract(1, 'years')
|
|
100
|
+
});
|
|
101
|
+
});
|
|
102
|
+
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "nextYear", function () {
|
|
103
|
+
var displayesMonth = _this.state.displayesMonth;
|
|
104
|
+
|
|
105
|
+
_this.setState({
|
|
106
|
+
displayesMonth: displayesMonth.add(1, 'years')
|
|
107
|
+
});
|
|
108
|
+
});
|
|
109
|
+
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "nextDecade", function () {
|
|
110
|
+
var displayesMonth = _this.state.displayesMonth;
|
|
111
|
+
|
|
112
|
+
_this.setState({
|
|
113
|
+
displayesMonth: displayesMonth.add(10, 'years')
|
|
114
|
+
});
|
|
115
|
+
});
|
|
116
|
+
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "prevDecade", function () {
|
|
117
|
+
var displayesMonth = _this.state.displayesMonth;
|
|
118
|
+
|
|
119
|
+
_this.setState({
|
|
120
|
+
displayesMonth: displayesMonth.subtract(10, 'years')
|
|
121
|
+
});
|
|
122
|
+
});
|
|
123
|
+
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onItemClick", function (itemType, item, i) {
|
|
124
|
+
if (itemType === 'month-item') {
|
|
125
|
+
_this.setDate('month', i);
|
|
126
|
+
} else {
|
|
127
|
+
_this.setDate('year', item);
|
|
128
|
+
}
|
|
129
|
+
|
|
130
|
+
_this.changeCalendarType(_types.CalendarType.BY_DAYS);
|
|
131
|
+
});
|
|
132
|
+
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "setTimeUnit", function (value, unit) {
|
|
133
|
+
var tempTimeObj = _this.state.tempTimeObj;
|
|
134
|
+
|
|
135
|
+
_this.setState({
|
|
136
|
+
tempTimeObj: _objectSpread(_objectSpread({}, tempTimeObj), {}, (0, _defineProperty2["default"])({}, unit, value))
|
|
137
|
+
});
|
|
138
|
+
});
|
|
139
|
+
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "setTime", function () {
|
|
140
|
+
var _this$props = _this.props,
|
|
141
|
+
value = _this$props.value,
|
|
142
|
+
inputName = _this$props.inputName,
|
|
143
|
+
markTimeAsSet = _this$props.markTimeAsSet,
|
|
144
|
+
select = _this$props.select;
|
|
145
|
+
var tempTimeObj = _this.state.tempTimeObj;
|
|
146
|
+
|
|
147
|
+
var _ref = tempTimeObj || {},
|
|
148
|
+
hours = _ref.hours,
|
|
149
|
+
minutes = _ref.minutes,
|
|
150
|
+
seconds = _ref.seconds;
|
|
151
|
+
|
|
152
|
+
var copyValue = value || (0, _moment["default"])();
|
|
153
|
+
|
|
154
|
+
_this.changeCalendarType(_types.CalendarType.BY_DAYS);
|
|
155
|
+
|
|
156
|
+
markTimeAsSet(inputName);
|
|
157
|
+
select((0, _utils.addTime)(copyValue.clone().startOf('day'), hours, minutes, seconds), inputName, false);
|
|
158
|
+
});
|
|
159
|
+
_this.state = {
|
|
160
|
+
displayesMonth: props.value ? props.value.clone().startOf('month') : (0, _moment["default"])().startOf('month'),
|
|
161
|
+
calendarType: _types.CalendarType.BY_DAYS,
|
|
162
|
+
tempTimeObj: props.value ? (0, _utils.objFromTime)(props.value) : props.time
|
|
163
|
+
};
|
|
164
|
+
return _this;
|
|
165
|
+
}
|
|
166
|
+
|
|
167
|
+
(0, _createClass2["default"])(Calendar, [{
|
|
168
|
+
key: "componentWillReceiveProps",
|
|
169
|
+
value: // eslint-disable-next-line react/no-deprecated
|
|
170
|
+
function componentWillReceiveProps(props) {
|
|
171
|
+
if (props.value) {
|
|
172
|
+
this.setState({
|
|
173
|
+
displayesMonth: props.value ? props.value.clone().startOf('month') : (0, _moment["default"])().startOf('month'),
|
|
174
|
+
tempTimeObj: props.value ? (0, _utils.objFromTime)(props.value) : props.time
|
|
175
|
+
});
|
|
176
|
+
}
|
|
177
|
+
}
|
|
178
|
+
}, {
|
|
179
|
+
key: "renderHeader",
|
|
180
|
+
value: function renderHeader() {
|
|
181
|
+
var _this$state = this.state,
|
|
182
|
+
displayesMonth = _this$state.displayesMonth,
|
|
183
|
+
calendarType = _this$state.calendarType;
|
|
184
|
+
var _this$props2 = this.props,
|
|
185
|
+
_this$props2$locale = _this$props2.locale,
|
|
186
|
+
locale = _this$props2$locale === void 0 ? 'ru' : _this$props2$locale,
|
|
187
|
+
t = _this$props2.t;
|
|
188
|
+
var nextMonth = this.nextMonth,
|
|
189
|
+
nextYear = this.nextYear,
|
|
190
|
+
prevMonth = this.prevMonth,
|
|
191
|
+
prevYear = this.prevYear,
|
|
192
|
+
nextDecade = this.nextDecade,
|
|
193
|
+
prevDecade = this.prevDecade,
|
|
194
|
+
changeCalendarType = this.changeCalendarType;
|
|
195
|
+
return /*#__PURE__*/_react["default"].createElement(_CalendarHeader.CalendarHeader, {
|
|
196
|
+
nextMonth: nextMonth,
|
|
197
|
+
nextYear: nextYear,
|
|
198
|
+
prevMonth: prevMonth,
|
|
199
|
+
prevYear: prevYear,
|
|
200
|
+
nextDecade: nextDecade,
|
|
201
|
+
prevDecade: prevDecade,
|
|
202
|
+
displayesMonth: displayesMonth,
|
|
203
|
+
locale: locale,
|
|
204
|
+
calendarType: calendarType,
|
|
205
|
+
changeCalendarType: changeCalendarType,
|
|
206
|
+
t: t
|
|
207
|
+
});
|
|
208
|
+
}
|
|
209
|
+
}, {
|
|
210
|
+
key: "setDate",
|
|
211
|
+
value: function setDate(unit, value) {
|
|
212
|
+
var displayesMonth = this.state.displayesMonth;
|
|
213
|
+
this.setState({
|
|
214
|
+
displayesMonth: displayesMonth.set(unit, Number(value))
|
|
215
|
+
});
|
|
216
|
+
}
|
|
217
|
+
}, {
|
|
218
|
+
key: "renderNameOfDays",
|
|
219
|
+
value: function renderNameOfDays() {
|
|
220
|
+
var _this$props$locale = this.props.locale,
|
|
221
|
+
locale = _this$props$locale === void 0 ? 'ru' : _this$props$locale;
|
|
222
|
+
var nameOfDays = locale === 'ru' ? ['Пн', 'Вт', 'Ср', 'Чт', 'Пт', 'Сб', 'Вс'] : ['Mo', 'Tu', 'We', 'Th', 'Fr', 'Sa', 'Su'];
|
|
223
|
+
return /*#__PURE__*/_react["default"].createElement("tr", null, nameOfDays.map(function (day, i) {
|
|
224
|
+
return (
|
|
225
|
+
/*#__PURE__*/
|
|
226
|
+
// eslint-disable-next-line react/no-array-index-key
|
|
227
|
+
_react["default"].createElement("td", {
|
|
228
|
+
key: i
|
|
229
|
+
}, day)
|
|
230
|
+
);
|
|
231
|
+
}));
|
|
232
|
+
}
|
|
233
|
+
}, {
|
|
234
|
+
key: "renderWeeks",
|
|
235
|
+
value: function renderWeeks() {
|
|
236
|
+
var _this2 = this;
|
|
237
|
+
|
|
238
|
+
var _this$state2 = this.state,
|
|
239
|
+
displayesMonth = _this$state2.displayesMonth,
|
|
240
|
+
tempTimeObj = _this$state2.tempTimeObj;
|
|
241
|
+
|
|
242
|
+
var _ref2 = tempTimeObj || {},
|
|
243
|
+
hours = _ref2.hours,
|
|
244
|
+
minutes = _ref2.minutes,
|
|
245
|
+
seconds = _ref2.seconds;
|
|
246
|
+
|
|
247
|
+
var firstDay = (0, _utils.addTime)(displayesMonth.clone().startOf('isoWeek'), hours, minutes, seconds);
|
|
248
|
+
return (0, _utils.weeks)(firstDay).map(function (week, i) {
|
|
249
|
+
return _this2.renderWeek(week, i);
|
|
250
|
+
});
|
|
251
|
+
}
|
|
252
|
+
}, {
|
|
253
|
+
key: "renderWeek",
|
|
254
|
+
value: function renderWeek(week, i) {
|
|
255
|
+
var _this3 = this;
|
|
256
|
+
|
|
257
|
+
return /*#__PURE__*/_react["default"].createElement("tr", {
|
|
258
|
+
key: i
|
|
259
|
+
}, week.map(function (day, i) {
|
|
260
|
+
return _this3.renderDay(day, i);
|
|
261
|
+
}));
|
|
262
|
+
} // eslint-disable-next-line complexity
|
|
263
|
+
|
|
264
|
+
}, {
|
|
265
|
+
key: "renderDay",
|
|
266
|
+
value: function renderDay(day, i) {
|
|
267
|
+
var _this$props3 = this.props,
|
|
268
|
+
min = _this$props3.min,
|
|
269
|
+
max = _this$props3.max,
|
|
270
|
+
value = _this$props3.value,
|
|
271
|
+
select = _this$props3.select,
|
|
272
|
+
inputName = _this$props3.inputName,
|
|
273
|
+
type = _this$props3.type,
|
|
274
|
+
index = _this$props3.index,
|
|
275
|
+
values = _this$props3.values,
|
|
276
|
+
dateFormat = _this$props3.dateFormat;
|
|
277
|
+
var disabled = false;
|
|
278
|
+
|
|
279
|
+
if (min && max) {
|
|
280
|
+
disabled = day.isBefore(min) || day.isAfter(max);
|
|
281
|
+
} else if (min) {
|
|
282
|
+
disabled = day.isBefore(min);
|
|
283
|
+
} else if (max) {
|
|
284
|
+
disabled = day.isAfter(max);
|
|
285
|
+
}
|
|
286
|
+
|
|
287
|
+
if (type === _DateTimeControl.ControlType.DATE_INTERVAL) {
|
|
288
|
+
var begin = values.begin;
|
|
289
|
+
|
|
290
|
+
var disableDaysBefore = function disableDaysBefore(range) {
|
|
291
|
+
return day.isBefore(range);
|
|
292
|
+
};
|
|
293
|
+
|
|
294
|
+
var disableDaysAfter = function disableDaysAfter(range) {
|
|
295
|
+
return day.isAfter(range);
|
|
296
|
+
};
|
|
297
|
+
|
|
298
|
+
var disabledDaysBeyondTheScopeMinMax = disableDaysBefore(min) || disableDaysAfter(max);
|
|
299
|
+
var disabledDaysBeyondTheScopeBeginMax = disableDaysBefore(begin) || disableDaysAfter(max); // eslint-disable-next-line no-unused-vars,no-return-assign, @typescript-eslint/no-unused-vars
|
|
300
|
+
|
|
301
|
+
var rangeMinMax = function rangeMinMax(disabledDays) {
|
|
302
|
+
return disabledDays = disabledDaysBeyondTheScopeMinMax;
|
|
303
|
+
}; // если не выбрана дата(begin) || min or max
|
|
304
|
+
|
|
305
|
+
|
|
306
|
+
var hasMinOrMaxAndNullBegin = (0, _isNull["default"])(begin) && (min || max) || (0, _isNull["default"])(begin) && min && max; // если hasMinOrMaxAndNullBegin, устанавливаем default range (min or max)
|
|
307
|
+
|
|
308
|
+
if (hasMinOrMaxAndNullBegin) {
|
|
309
|
+
rangeMinMax(disabled);
|
|
310
|
+
} else if (min && max) {
|
|
311
|
+
disabled = index === 0 ? disabledDaysBeyondTheScopeMinMax : disabledDaysBeyondTheScopeBeginMax;
|
|
312
|
+
} else if (min) {
|
|
313
|
+
disabled = index === 0 ? disableDaysBefore(min) : index === 1 && disableDaysBefore(begin);
|
|
314
|
+
} else if (max) {
|
|
315
|
+
disabled = index === 0 ? disableDaysAfter(max) : index === 1 && disableDaysAfter(begin);
|
|
316
|
+
} else {
|
|
317
|
+
// не указан range (min, max)
|
|
318
|
+
disabled = index === 1 && disableDaysBefore(begin);
|
|
319
|
+
}
|
|
320
|
+
}
|
|
321
|
+
|
|
322
|
+
var displayesMonth = this.state.displayesMonth;
|
|
323
|
+
var otherMonth = (0, _utils.isDateFromNextMonth)(day, displayesMonth) || (0, _utils.isDateFromPrevMonth)(day, displayesMonth);
|
|
324
|
+
var selected = day.isSame(value);
|
|
325
|
+
var current = day.format('DD.MM.YYYY') === (0, _moment["default"])().format('DD.MM.YYYY');
|
|
326
|
+
var props = {
|
|
327
|
+
day: day,
|
|
328
|
+
otherMonth: otherMonth,
|
|
329
|
+
selected: selected,
|
|
330
|
+
disabled: disabled,
|
|
331
|
+
select: select,
|
|
332
|
+
inputName: inputName,
|
|
333
|
+
current: current,
|
|
334
|
+
dateFormat: dateFormat
|
|
335
|
+
};
|
|
336
|
+
return /*#__PURE__*/_react["default"].createElement(_Day.Day, (0, _extends2["default"])({
|
|
337
|
+
key: i
|
|
338
|
+
}, props));
|
|
339
|
+
}
|
|
340
|
+
}, {
|
|
341
|
+
key: "renderTime",
|
|
342
|
+
value: function renderTime() {
|
|
343
|
+
var _this$props4 = this.props,
|
|
344
|
+
value = _this$props4.value,
|
|
345
|
+
hasDefaultTime = _this$props4.hasDefaultTime,
|
|
346
|
+
timeFormat = _this$props4.timeFormat,
|
|
347
|
+
t = _this$props4.t;
|
|
348
|
+
|
|
349
|
+
if (hasDefaultTime) {
|
|
350
|
+
if (value) {
|
|
351
|
+
return value.format(timeFormat);
|
|
352
|
+
}
|
|
353
|
+
|
|
354
|
+
return '00:00:00';
|
|
355
|
+
}
|
|
356
|
+
|
|
357
|
+
if (t) {
|
|
358
|
+
return t('chooseTime');
|
|
359
|
+
}
|
|
360
|
+
|
|
361
|
+
return null;
|
|
362
|
+
}
|
|
363
|
+
}, {
|
|
364
|
+
key: "renderByDays",
|
|
365
|
+
value: function renderByDays() {
|
|
366
|
+
var _this4 = this;
|
|
367
|
+
|
|
368
|
+
var timeFormat = this.props.timeFormat;
|
|
369
|
+
return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, /*#__PURE__*/_react["default"].createElement("table", {
|
|
370
|
+
className: "n2o-calendar-table"
|
|
371
|
+
}, /*#__PURE__*/_react["default"].createElement("thead", null, this.renderNameOfDays()), /*#__PURE__*/_react["default"].createElement("tbody", null, this.renderWeeks())), timeFormat && /*#__PURE__*/_react["default"].createElement("a", {
|
|
372
|
+
className: "n2o-calendar-time-container",
|
|
373
|
+
href: "/test",
|
|
374
|
+
onClick: function onClick(e) {
|
|
375
|
+
e.preventDefault();
|
|
376
|
+
|
|
377
|
+
_this4.changeCalendarType(_types.CalendarType.TIME_PICKER);
|
|
378
|
+
}
|
|
379
|
+
}, this.renderTime()));
|
|
380
|
+
}
|
|
381
|
+
}, {
|
|
382
|
+
key: "renderByMonths",
|
|
383
|
+
value: function renderByMonths() {
|
|
384
|
+
var _this$props$locale2 = this.props.locale,
|
|
385
|
+
locale = _this$props$locale2 === void 0 ? 'ru' : _this$props$locale2;
|
|
386
|
+
return /*#__PURE__*/_react["default"].createElement("div", {
|
|
387
|
+
className: "n2o-calendar-body"
|
|
388
|
+
}, this.renderList(_moment["default"].localeData(locale).months(), 'month-item'));
|
|
389
|
+
}
|
|
390
|
+
}, {
|
|
391
|
+
key: "renderList",
|
|
392
|
+
value: function renderList(list, className) {
|
|
393
|
+
var _this5 = this;
|
|
394
|
+
|
|
395
|
+
var value = this.props.value;
|
|
396
|
+
|
|
397
|
+
var isActive = function isActive(className, item, i) {
|
|
398
|
+
if (!value) {
|
|
399
|
+
return false;
|
|
400
|
+
}
|
|
401
|
+
|
|
402
|
+
if (className !== 'month-item') {
|
|
403
|
+
return item === value.year();
|
|
404
|
+
}
|
|
405
|
+
|
|
406
|
+
return i === value.month();
|
|
407
|
+
};
|
|
408
|
+
|
|
409
|
+
var isOtherDecade = function isOtherDecade(i) {
|
|
410
|
+
return className === 'year-item' && (i === 0 || i === 11);
|
|
411
|
+
};
|
|
412
|
+
|
|
413
|
+
return list.map(function (item, i) {
|
|
414
|
+
return /*#__PURE__*/_react["default"].createElement("div", {
|
|
415
|
+
className: (0, _classnames["default"])('n2o-calendar-body-item', className, {
|
|
416
|
+
active: isActive(className, item, i),
|
|
417
|
+
'other-decade': isOtherDecade(i)
|
|
418
|
+
}),
|
|
419
|
+
onClick: function onClick() {
|
|
420
|
+
return _this5.onItemClick(className, item, i);
|
|
421
|
+
}
|
|
422
|
+
}, item);
|
|
423
|
+
});
|
|
424
|
+
}
|
|
425
|
+
}, {
|
|
426
|
+
key: "renderByYears",
|
|
427
|
+
value: function renderByYears() {
|
|
428
|
+
var displayesMonth = this.state.displayesMonth;
|
|
429
|
+
var decadeStart = parseInt(String(Number(displayesMonth.format('YYYY')) / 10), 10) * 10;
|
|
430
|
+
var years = Array.from(new Array(12), function (val, index) {
|
|
431
|
+
return decadeStart + index - 1;
|
|
432
|
+
});
|
|
433
|
+
return /*#__PURE__*/_react["default"].createElement("div", {
|
|
434
|
+
className: "n2o-calendar-body"
|
|
435
|
+
}, this.renderList(years, 'year-item'));
|
|
436
|
+
}
|
|
437
|
+
}, {
|
|
438
|
+
key: "componentDidUpdate",
|
|
439
|
+
value: function componentDidUpdate() {
|
|
440
|
+
var calendarType = this.state.calendarType;
|
|
441
|
+
|
|
442
|
+
if (calendarType === _types.CalendarType.TIME_PICKER) {
|
|
443
|
+
if (this.minuteRef) {
|
|
444
|
+
this.minuteRef.scrollIntoView();
|
|
445
|
+
}
|
|
446
|
+
|
|
447
|
+
if (this.secondRef) {
|
|
448
|
+
this.secondRef.scrollIntoView();
|
|
449
|
+
}
|
|
450
|
+
|
|
451
|
+
if (this.hourRef) {
|
|
452
|
+
this.hourRef.scrollIntoView();
|
|
453
|
+
}
|
|
454
|
+
}
|
|
455
|
+
}
|
|
456
|
+
}, {
|
|
457
|
+
key: "renderTimePicker",
|
|
458
|
+
value: function renderTimePicker() {
|
|
459
|
+
var _this6 = this;
|
|
460
|
+
|
|
461
|
+
var tempTimeObj = this.state.tempTimeObj;
|
|
462
|
+
|
|
463
|
+
var _ref3 = tempTimeObj || {},
|
|
464
|
+
minutes = _ref3.minutes,
|
|
465
|
+
seconds = _ref3.seconds,
|
|
466
|
+
hours = _ref3.hours;
|
|
467
|
+
/* eslint-disable react/jsx-one-expression-per-line */
|
|
468
|
+
|
|
469
|
+
|
|
470
|
+
return /*#__PURE__*/_react["default"].createElement("div", null, /*#__PURE__*/_react["default"].createElement("div", {
|
|
471
|
+
className: "n2o-calendar-timepicker"
|
|
472
|
+
}, /*#__PURE__*/_react["default"].createElement("div", {
|
|
473
|
+
className: "n2o-calendar-picker hour-picker"
|
|
474
|
+
}, Array.from(new Array(24), function (val, index) {
|
|
475
|
+
return /*#__PURE__*/_react["default"].createElement("div", {
|
|
476
|
+
className: (0, _classnames["default"])('n2o-calendar-time-unit', {
|
|
477
|
+
active: index === hours
|
|
478
|
+
}),
|
|
479
|
+
onClick: function onClick() {
|
|
480
|
+
return _this6.setTimeUnit(index, 'hours');
|
|
481
|
+
},
|
|
482
|
+
ref: index === hours ? _this6.setHourRef : null
|
|
483
|
+
}, index);
|
|
484
|
+
})), /*#__PURE__*/_react["default"].createElement("div", {
|
|
485
|
+
className: "n2o-calendar-picker minute-picker"
|
|
486
|
+
}, Array.from(new Array(60), function (val, index) {
|
|
487
|
+
return /*#__PURE__*/_react["default"].createElement("div", {
|
|
488
|
+
className: (0, _classnames["default"])('n2o-calendar-time-unit', {
|
|
489
|
+
active: index === minutes
|
|
490
|
+
}),
|
|
491
|
+
ref: index === minutes ? _this6.setMinuteRef : null,
|
|
492
|
+
onClick: function onClick() {
|
|
493
|
+
return _this6.setTimeUnit(index, 'minutes');
|
|
494
|
+
}
|
|
495
|
+
}, index);
|
|
496
|
+
})), /*#__PURE__*/_react["default"].createElement("div", {
|
|
497
|
+
className: "n2o-calendar-picker second-picker"
|
|
498
|
+
}, Array.from(new Array(60), function (val, index) {
|
|
499
|
+
return /*#__PURE__*/_react["default"].createElement("div", {
|
|
500
|
+
className: (0, _classnames["default"])('n2o-calendar-time-unit', {
|
|
501
|
+
active: index === seconds
|
|
502
|
+
}),
|
|
503
|
+
ref: index === seconds ? _this6.setSecondRef : null,
|
|
504
|
+
onClick: function onClick() {
|
|
505
|
+
return _this6.setTimeUnit(index, 'seconds');
|
|
506
|
+
}
|
|
507
|
+
}, index);
|
|
508
|
+
}))), /*#__PURE__*/_react["default"].createElement("div", {
|
|
509
|
+
className: "n2o-calendar-time-buttons"
|
|
510
|
+
}, /*#__PURE__*/_react["default"].createElement("button", {
|
|
511
|
+
type: "button",
|
|
512
|
+
className: "btn btn-secondary btn-sm",
|
|
513
|
+
onClick: function onClick() {
|
|
514
|
+
return _this6.changeCalendarType(_types.CalendarType.BY_DAYS);
|
|
515
|
+
}
|
|
516
|
+
}, ' ', "\u041D\u0430\u0437\u0430\u0434"), /*#__PURE__*/_react["default"].createElement("button", {
|
|
517
|
+
className: "btn btn-primary btn-sm",
|
|
518
|
+
onClick: this.setTime,
|
|
519
|
+
type: "button"
|
|
520
|
+
}, ' ', "\u0412\u044B\u0431\u0440\u0430\u0442\u044C")));
|
|
521
|
+
}
|
|
522
|
+
}, {
|
|
523
|
+
key: "renderBody",
|
|
524
|
+
value: function renderBody(type) {
|
|
525
|
+
switch (type) {
|
|
526
|
+
case _types.CalendarType.BY_MONTHS:
|
|
527
|
+
return this.renderByMonths();
|
|
528
|
+
|
|
529
|
+
case _types.CalendarType.BY_YEARS:
|
|
530
|
+
return this.renderByYears();
|
|
531
|
+
|
|
532
|
+
case _types.CalendarType.TIME_PICKER:
|
|
533
|
+
return this.renderTimePicker();
|
|
534
|
+
|
|
535
|
+
case _types.CalendarType.BY_DAYS:
|
|
536
|
+
default:
|
|
537
|
+
return this.renderByDays();
|
|
538
|
+
}
|
|
539
|
+
}
|
|
540
|
+
}, {
|
|
541
|
+
key: "render",
|
|
542
|
+
value: function render() {
|
|
543
|
+
var calendarType = this.state.calendarType;
|
|
544
|
+
var timeFormat = this.props.timeFormat;
|
|
545
|
+
return /*#__PURE__*/_react["default"].createElement("div", {
|
|
546
|
+
className: (0, _classnames["default"])('n2o-calendar', {
|
|
547
|
+
time: timeFormat
|
|
548
|
+
})
|
|
549
|
+
}, this.renderHeader(), this.renderBody(calendarType));
|
|
550
|
+
}
|
|
551
|
+
}]);
|
|
552
|
+
return Calendar;
|
|
553
|
+
}(_react["default"].Component);
|
|
554
|
+
|
|
555
|
+
exports.Calendar = Calendar;
|
|
556
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/inputs/DatePicker/Calendar.tsx"],"names":["Calendar","props","type","setState","calendarType","el","hourRef","minuteRef","secondRef","displayesMonth","state","subtract","add","itemType","item","i","setDate","changeCalendarType","CalendarType","BY_DAYS","value","unit","tempTimeObj","inputName","markTimeAsSet","select","hours","minutes","seconds","copyValue","clone","startOf","time","locale","t","nextMonth","nextYear","prevMonth","prevYear","nextDecade","prevDecade","set","Number","nameOfDays","map","day","firstDay","week","renderWeek","renderDay","min","max","index","values","dateFormat","disabled","isBefore","isAfter","ControlType","DATE_INTERVAL","begin","disableDaysBefore","range","disableDaysAfter","disabledDaysBeyondTheScopeMinMax","disabledDaysBeyondTheScopeBeginMax","rangeMinMax","disabledDays","hasMinOrMaxAndNullBegin","otherMonth","selected","isSame","current","format","hasDefaultTime","timeFormat","renderNameOfDays","renderWeeks","e","preventDefault","TIME_PICKER","renderTime","renderList","moment","localeData","months","list","className","isActive","year","month","isOtherDecade","active","onItemClick","decadeStart","parseInt","String","years","Array","from","val","scrollIntoView","setTimeUnit","setHourRef","setMinuteRef","setSecondRef","setTime","BY_MONTHS","renderByMonths","BY_YEARS","renderByYears","renderTimePicker","renderByDays","renderHeader","renderBody","React","Component"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AAEA;;AACA;;AACA;;AAMA;;AACA;;AAEA;;;;;;;;;;IA6BaA,Q;;;;;AAOT,oBAAYC,KAAZ,EAAkC;AAAA;;AAAA;AAC9B,8BAAMA,KAAN;AAD8B,gGANO,IAMP;AAAA,kGAJS,IAIT;AAAA,kGAFS,IAET;AAAA,2GAWb,UAACC,IAAD,EAAwB;AACzC,YAAKC,QAAL,CAAc;AAAEC,QAAAA,YAAY,EAAEF;AAAhB,OAAd;AACH,KAbiC;AAAA,mGA2BrB,UAACG,EAAD,EAAwB;AACjC,YAAKC,OAAL,GAAeD,EAAf;AACH,KA7BiC;AAAA,qGA+BnB,UAACA,EAAD,EAAwB;AACnC,YAAKE,SAAL,GAAiBF,EAAjB;AACH,KAjCiC;AAAA,qGAmCnB,UAACA,EAAD,EAAwB;AACnC,YAAKG,SAAL,GAAiBH,EAAjB;AACH,KArCiC;AAAA,kGAqEtB,YAAM;AACd,UAAQI,cAAR,GAA2B,MAAKC,KAAhC,CAAQD,cAAR;;AAEA,YAAKN,QAAL,CAAc;AAAEM,QAAAA,cAAc,EAAEA,cAAc,CAACE,QAAf,CAAwB,CAAxB,EAA2B,QAA3B;AAAlB,OAAd;AACH,KAzEiC;AAAA,kGA2EtB,YAAM;AACd,UAAQF,cAAR,GAA2B,MAAKC,KAAhC,CAAQD,cAAR;;AAEA,YAAKN,QAAL,CAAc;AAAEM,QAAAA,cAAc,EAAEA,cAAc,CAACG,GAAf,CAAmB,CAAnB,EAAsB,QAAtB;AAAlB,OAAd;AACH,KA/EiC;AAAA,iGAiFvB,YAAM;AACb,UAAQH,cAAR,GAA2B,MAAKC,KAAhC,CAAQD,cAAR;;AAEA,YAAKN,QAAL,CAAc;AAAEM,QAAAA,cAAc,EAAEA,cAAc,CAACE,QAAf,CAAwB,CAAxB,EAA2B,OAA3B;AAAlB,OAAd;AACH,KArFiC;AAAA,iGAuFvB,YAAM;AACb,UAAQF,cAAR,GAA2B,MAAKC,KAAhC,CAAQD,cAAR;;AAEA,YAAKN,QAAL,CAAc;AAAEM,QAAAA,cAAc,EAAEA,cAAc,CAACG,GAAf,CAAmB,CAAnB,EAAsB,OAAtB;AAAlB,OAAd;AACH,KA3FiC;AAAA,mGA6FrB,YAAM;AACf,UAAQH,cAAR,GAA2B,MAAKC,KAAhC,CAAQD,cAAR;;AAEA,YAAKN,QAAL,CAAc;AAAEM,QAAAA,cAAc,EAAEA,cAAc,CAACG,GAAf,CAAmB,EAAnB,EAAuB,OAAvB;AAAlB,OAAd;AACH,KAjGiC;AAAA,mGAmGrB,YAAM;AACf,UAAQH,cAAR,GAA2B,MAAKC,KAAhC,CAAQD,cAAR;;AAEA,YAAKN,QAAL,CAAc;AAAEM,QAAAA,cAAc,EAAEA,cAAc,CAACE,QAAf,CAAwB,EAAxB,EAA4B,OAA5B;AAAlB,OAAd;AACH,KAvGiC;AAAA,oGAoRpB,UAACE,QAAD,EAAmBC,IAAnB,EAA0CC,CAA1C,EAAwD;AAClE,UAAIF,QAAQ,KAAK,YAAjB,EAA+B;AAC3B,cAAKG,OAAL,CAAa,OAAb,EAAsBD,CAAtB;AACH,OAFD,MAEO;AACH,cAAKC,OAAL,CAAa,MAAb,EAAqBF,IAArB;AACH;;AACD,YAAKG,kBAAL,CAAwBC,oBAAaC,OAArC;AACH,KA3RiC;AAAA,oGAsVpB,UAACC,KAAD,EAAgBC,IAAhB,EAAiC;AAC3C,UAAQC,WAAR,GAAwB,MAAKZ,KAA7B,CAAQY,WAAR;;AAEA,YAAKnB,QAAL,CAAc;AACVmB,QAAAA,WAAW,kCAAOA,WAAP,4CAAqBD,IAArB,EAA4BD,KAA5B;AADD,OAAd;AAGH,KA5ViC;AAAA,gGA8VxB,YAAM;AACZ,wBAAoD,MAAKnB,KAAzD;AAAA,UAAQmB,KAAR,eAAQA,KAAR;AAAA,UAAeG,SAAf,eAAeA,SAAf;AAAA,UAA0BC,aAA1B,eAA0BA,aAA1B;AAAA,UAAyCC,MAAzC,eAAyCA,MAAzC;AACA,UAAQH,WAAR,GAAwB,MAAKZ,KAA7B,CAAQY,WAAR;;AACA,iBAAoCA,WAAW,IAAI,EAAnD;AAAA,UAAQI,KAAR,QAAQA,KAAR;AAAA,UAAeC,OAAf,QAAeA,OAAf;AAAA,UAAwBC,OAAxB,QAAwBA,OAAxB;;AACA,UAAMC,SAAS,GAAGT,KAAK,IAAI,yBAA3B;;AAEA,YAAKH,kBAAL,CAAwBC,oBAAaC,OAArC;;AACAK,MAAAA,aAAa,CAACD,SAAD,CAAb;AAEAE,MAAAA,MAAM,CACF,oBAAQI,SAAS,CAACC,KAAV,GAAkBC,OAAlB,CAA0B,KAA1B,CAAR,EAA0CL,KAA1C,EAAiDC,OAAjD,EAA0DC,OAA1D,CADE,EAEFL,SAFE,EAGF,KAHE,CAAN;AAKH,KA5WiC;AAE9B,UAAKb,KAAL,GAAa;AACTD,MAAAA,cAAc,EAAER,KAAK,CAACmB,KAAN,GACVnB,KAAK,CAACmB,KAAN,CAAYU,KAAZ,GAAoBC,OAApB,CAA4B,OAA5B,CADU,GAEV,0BAASA,OAAT,CAAiB,OAAjB,CAHG;AAIT3B,MAAAA,YAAY,EAAEc,oBAAaC,OAJlB;AAKTG,MAAAA,WAAW,EAAErB,KAAK,CAACmB,KAAN,GAAc,wBAAYnB,KAAK,CAACmB,KAAlB,CAAd,GAAyCnB,KAAK,CAAC+B;AALnD,KAAb;AAF8B;AASjC;;;;WAMD;AACA,uCAA0B/B,KAA1B,EAAgD;AAC5C,UAAIA,KAAK,CAACmB,KAAV,EAAiB;AACb,aAAKjB,QAAL,CAAc;AACVM,UAAAA,cAAc,EAAER,KAAK,CAACmB,KAAN,GACVnB,KAAK,CAACmB,KAAN,CAAYU,KAAZ,GAAoBC,OAApB,CAA4B,OAA5B,CADU,GAEV,0BAASA,OAAT,CAAiB,OAAjB,CAHI;AAIVT,UAAAA,WAAW,EAAErB,KAAK,CAACmB,KAAN,GAAc,wBAAYnB,KAAK,CAACmB,KAAlB,CAAd,GAAyCnB,KAAK,CAAC+B;AAJlD,SAAd;AAMH;AACJ;;;WAcD,wBAAe;AACX,wBAAyC,KAAKtB,KAA9C;AAAA,UAAQD,cAAR,eAAQA,cAAR;AAAA,UAAwBL,YAAxB,eAAwBA,YAAxB;AACA,yBAA6B,KAAKH,KAAlC;AAAA,6CAAQgC,MAAR;AAAA,UAAQA,MAAR,oCAAiB,IAAjB;AAAA,UAAuBC,CAAvB,gBAAuBA,CAAvB;AACA,UACIC,SADJ,GAQI,IARJ,CACIA,SADJ;AAAA,UAEIC,QAFJ,GAQI,IARJ,CAEIA,QAFJ;AAAA,UAGIC,SAHJ,GAQI,IARJ,CAGIA,SAHJ;AAAA,UAIIC,QAJJ,GAQI,IARJ,CAIIA,QAJJ;AAAA,UAKIC,UALJ,GAQI,IARJ,CAKIA,UALJ;AAAA,UAMIC,UANJ,GAQI,IARJ,CAMIA,UANJ;AAAA,UAOIvB,kBAPJ,GAQI,IARJ,CAOIA,kBAPJ;AAUA,0BACI,gCAAC,8BAAD;AACI,QAAA,SAAS,EAAEkB,SADf;AAEI,QAAA,QAAQ,EAAEC,QAFd;AAGI,QAAA,SAAS,EAAEC,SAHf;AAII,QAAA,QAAQ,EAAEC,QAJd;AAKI,QAAA,UAAU,EAAEC,UALhB;AAMI,QAAA,UAAU,EAAEC,UANhB;AAOI,QAAA,cAAc,EAAE/B,cAPpB;AAQI,QAAA,MAAM,EAAEwB,MARZ;AASI,QAAA,YAAY,EAAE7B,YATlB;AAUI,QAAA,kBAAkB,EAAEa,kBAVxB;AAWI,QAAA,CAAC,EAAEiB;AAXP,QADJ;AAeH;;;WAsCD,iBAAQb,IAAR,EAAsBD,KAAtB,EAA8C;AAC1C,UAAQX,cAAR,GAA2B,KAAKC,KAAhC,CAAQD,cAAR;AAEA,WAAKN,QAAL,CAAc;AAAEM,QAAAA,cAAc,EAAEA,cAAc,CAACgC,GAAf,CAAmBpB,IAAnB,EAA2CqB,MAAM,CAACtB,KAAD,CAAjD;AAAlB,OAAd;AACH;;;WAED,4BAAmB;AACf,+BAA0B,KAAKnB,KAA/B,CAAQgC,MAAR;AAAA,UAAQA,MAAR,mCAAiB,IAAjB;AACA,UAAMU,UAAU,GAAGV,MAAM,KAAK,IAAX,GACb,CAAC,IAAD,EAAO,IAAP,EAAa,IAAb,EAAmB,IAAnB,EAAyB,IAAzB,EAA+B,IAA/B,EAAqC,IAArC,CADa,GAEb,CAAC,IAAD,EAAO,IAAP,EAAa,IAAb,EAAmB,IAAnB,EAAyB,IAAzB,EAA+B,IAA/B,EAAqC,IAArC,CAFN;AAIA,0BACI,4CACKU,UAAU,CAACC,GAAX,CAAe,UAACC,GAAD,EAAM9B,CAAN;AAAA;AAAA;AACZ;AACA;AAAI,YAAA,GAAG,EAAEA;AAAT,aAAa8B,GAAb;AAFY;AAAA,OAAf,CADL,CADJ;AAQH;;;WAED,uBAAc;AAAA;;AACV,yBAAwC,KAAKnC,KAA7C;AAAA,UAAQD,cAAR,gBAAQA,cAAR;AAAA,UAAwBa,WAAxB,gBAAwBA,WAAxB;;AACA,kBAAoCA,WAAW,IAAI,EAAnD;AAAA,UAAQI,KAAR,SAAQA,KAAR;AAAA,UAAeC,OAAf,SAAeA,OAAf;AAAA,UAAwBC,OAAxB,SAAwBA,OAAxB;;AACA,UAAMkB,QAAQ,GAAG,oBACbrC,cAAc,CAACqB,KAAf,GAAuBC,OAAvB,CAA+B,SAA/B,CADa,EAEbL,KAFa,EAGbC,OAHa,EAIbC,OAJa,CAAjB;AAOA,aAAO,kBAAMkB,QAAN,EAAgBF,GAAhB,CAAoB,UAACG,IAAD,EAAOhC,CAAP;AAAA,eAAa,MAAI,CAACiC,UAAL,CAAgBD,IAAhB,EAAsBhC,CAAtB,CAAb;AAAA,OAApB,CAAP;AACH;;;WAED,oBAAWgC,IAAX,EAA2BhC,CAA3B,EAAsC;AAAA;;AAClC,0BAAO;AAAI,QAAA,GAAG,EAAEA;AAAT,SAAagC,IAAI,CAACH,GAAL,CAAS,UAACC,GAAD,EAAM9B,CAAN;AAAA,eAAY,MAAI,CAACkC,SAAL,CAAeJ,GAAf,EAAoB9B,CAApB,CAAZ;AAAA,OAAT,CAAb,CAAP;AACH,K,CAED;;;;WACA,mBAAU8B,GAAV,EAAuB9B,CAAvB,EAAkC;AAC9B,yBAUI,KAAKd,KAVT;AAAA,UACIiD,GADJ,gBACIA,GADJ;AAAA,UAEIC,GAFJ,gBAEIA,GAFJ;AAAA,UAGI/B,KAHJ,gBAGIA,KAHJ;AAAA,UAIIK,MAJJ,gBAIIA,MAJJ;AAAA,UAKIF,SALJ,gBAKIA,SALJ;AAAA,UAMIrB,IANJ,gBAMIA,IANJ;AAAA,UAOIkD,KAPJ,gBAOIA,KAPJ;AAAA,UAQIC,MARJ,gBAQIA,MARJ;AAAA,UASIC,UATJ,gBASIA,UATJ;AAYA,UAAIC,QAAQ,GAAG,KAAf;;AAEA,UAAIL,GAAG,IAAIC,GAAX,EAAgB;AACZI,QAAAA,QAAQ,GAAGV,GAAG,CAACW,QAAJ,CAAaN,GAAb,KAAqBL,GAAG,CAACY,OAAJ,CAAYN,GAAZ,CAAhC;AACH,OAFD,MAEO,IAAID,GAAJ,EAAS;AACZK,QAAAA,QAAQ,GAAGV,GAAG,CAACW,QAAJ,CAAaN,GAAb,CAAX;AACH,OAFM,MAEA,IAAIC,GAAJ,EAAS;AACZI,QAAAA,QAAQ,GAAGV,GAAG,CAACY,OAAJ,CAAYN,GAAZ,CAAX;AACH;;AAED,UAAIjD,IAAI,KAAKwD,6BAAYC,aAAzB,EAAwC;AACpC,YAAQC,KAAR,GAAkBP,MAAlB,CAAQO,KAAR;;AAEA,YAAMC,iBAAiB,GAAG,SAApBA,iBAAoB,CAACC,KAAD;AAAA,iBAAwBjB,GAAG,CAACW,QAAJ,CAAaM,KAAb,CAAxB;AAAA,SAA1B;;AACA,YAAMC,gBAAgB,GAAG,SAAnBA,gBAAmB,CAACD,KAAD;AAAA,iBAAwBjB,GAAG,CAACY,OAAJ,CAAYK,KAAZ,CAAxB;AAAA,SAAzB;;AAEA,YAAME,gCAAgC,GAAGH,iBAAiB,CAACX,GAAD,CAAjB,IAA0Ba,gBAAgB,CAACZ,GAAD,CAAnF;AACA,YAAMc,kCAAkC,GAAGJ,iBAAiB,CAACD,KAAD,CAAjB,IAA4BG,gBAAgB,CAACZ,GAAD,CAAvF,CAPoC,CASpC;;AACA,YAAMe,WAAW,GAAG,SAAdA,WAAc,CAACC,YAAD;AAAA,iBAA4BA,YAAY,GAAGH,gCAA3C;AAAA,SAApB,CAVoC,CAYpC;;;AACA,YAAMI,uBAAuB,GAAI,wBAAOR,KAAP,MAAkBV,GAAG,IAAIC,GAAzB,CAAD,IAAoC,wBAAOS,KAAP,KAAkBV,GAAG,IAAIC,GAA7F,CAboC,CAepC;;AACA,YAAIiB,uBAAJ,EAA6B;AACzBF,UAAAA,WAAW,CAACX,QAAD,CAAX;AACH,SAFD,MAEO,IAAIL,GAAG,IAAIC,GAAX,EAAgB;AACnBI,UAAAA,QAAQ,GAAGH,KAAK,KAAK,CAAV,GACLY,gCADK,GAELC,kCAFN;AAGH,SAJM,MAIA,IAAIf,GAAJ,EAAS;AACZK,UAAAA,QAAQ,GAAGH,KAAK,KAAK,CAAV,GACLS,iBAAiB,CAACX,GAAD,CADZ,GAELE,KAAK,KAAK,CAAV,IAAeS,iBAAiB,CAACD,KAAD,CAFtC;AAGH,SAJM,MAIA,IAAIT,GAAJ,EAAS;AACZI,UAAAA,QAAQ,GAAGH,KAAK,KAAK,CAAV,GACLW,gBAAgB,CAACZ,GAAD,CADX,GAELC,KAAK,KAAK,CAAV,IAAeW,gBAAgB,CAACH,KAAD,CAFrC;AAGH,SAJM,MAIA;AACH;AACAL,UAAAA,QAAQ,GAAGH,KAAK,KAAK,CAAV,IAAeS,iBAAiB,CAACD,KAAD,CAA3C;AACH;AACJ;;AAED,UAAQnD,cAAR,GAA2B,KAAKC,KAAhC,CAAQD,cAAR;AACA,UAAM4D,UAAU,GAAG,gCAAoBxB,GAApB,EAAyBpC,cAAzB,KACf,gCAAoBoC,GAApB,EAAyBpC,cAAzB,CADJ;AAEA,UAAM6D,QAAQ,GAAGzB,GAAG,CAAC0B,MAAJ,CAAWnD,KAAX,CAAjB;AACA,UAAMoD,OAAO,GAAG3B,GAAG,CAAC4B,MAAJ,CAAW,YAAX,MAA6B,0BAASA,MAAT,CAAgB,YAAhB,CAA7C;AACA,UAAMxE,KAAK,GAAG;AACV4C,QAAAA,GAAG,EAAHA,GADU;AAEVwB,QAAAA,UAAU,EAAVA,UAFU;AAGVC,QAAAA,QAAQ,EAARA,QAHU;AAIVf,QAAAA,QAAQ,EAARA,QAJU;AAKV9B,QAAAA,MAAM,EAANA,MALU;AAMVF,QAAAA,SAAS,EAATA,SANU;AAOViD,QAAAA,OAAO,EAAPA,OAPU;AAQVlB,QAAAA,UAAU,EAAVA;AARU,OAAd;AAWA,0BAAO,gCAAC,QAAD;AAAK,QAAA,GAAG,EAAEvC;AAAV,SAAiBd,KAAjB,EAAP;AACH;;;WAED,sBAAa;AACT,yBAAiD,KAAKA,KAAtD;AAAA,UAAQmB,KAAR,gBAAQA,KAAR;AAAA,UAAesD,cAAf,gBAAeA,cAAf;AAAA,UAA+BC,UAA/B,gBAA+BA,UAA/B;AAAA,UAA2CzC,CAA3C,gBAA2CA,CAA3C;;AAEA,UAAIwC,cAAJ,EAAoB;AAChB,YAAItD,KAAJ,EAAW;AACP,iBAAOA,KAAK,CAACqD,MAAN,CAAaE,UAAb,CAAP;AACH;;AAED,eAAO,UAAP;AACH;;AAED,UAAIzC,CAAJ,EAAO;AACH,eAAOA,CAAC,CAAC,YAAD,CAAR;AACH;;AAED,aAAO,IAAP;AACH;;;WAED,wBAAe;AAAA;;AACX,UAAQyC,UAAR,GAAuB,KAAK1E,KAA5B,CAAQ0E,UAAR;AAEA,0BACI,+EACI;AAAO,QAAA,SAAS,EAAC;AAAjB,sBACI,+CAAQ,KAAKC,gBAAL,EAAR,CADJ,eAEI,+CAAQ,KAAKC,WAAL,EAAR,CAFJ,CADJ,EAKKF,UAAU,iBACP;AACI,QAAA,SAAS,EAAC,6BADd;AAEI,QAAA,IAAI,EAAC,OAFT;AAGI,QAAA,OAAO,EAAE,iBAACG,CAAD,EAAO;AACZA,UAAAA,CAAC,CAACC,cAAF;;AACA,UAAA,MAAI,CAAC9D,kBAAL,CAAwBC,oBAAa8D,WAArC;AACH;AANL,SAQK,KAAKC,UAAL,EARL,CANR,CADJ;AAoBH;;;WAED,0BAAiB;AACb,gCAA0B,KAAKhF,KAA/B,CAAQgC,MAAR;AAAA,UAAQA,MAAR,oCAAiB,IAAjB;AAEA,0BACI;AAAK,QAAA,SAAS,EAAC;AAAf,SACK,KAAKiD,UAAL,CAAgBC,mBAAOC,UAAP,CAAkBnD,MAAlB,EAA0BoD,MAA1B,EAAhB,EAAoD,YAApD,CADL,CADJ;AAKH;;;WAWD,oBAAWC,IAAX,EAAyCC,SAAzC,EAA4D;AAAA;;AACxD,UAAQnE,KAAR,GAAkB,KAAKnB,KAAvB,CAAQmB,KAAR;;AAEA,UAAMoE,QAAQ,GAAG,SAAXA,QAAW,CAACD,SAAD,EAAoBzE,IAApB,EAA2CC,CAA3C,EAAyD;AACtE,YAAI,CAACK,KAAL,EAAY;AAAE,iBAAO,KAAP;AAAc;;AAC5B,YAAImE,SAAS,KAAK,YAAlB,EAAgC;AAC5B,iBAAOzE,IAAI,KAAKM,KAAK,CAACqE,IAAN,EAAhB;AACH;;AAED,eAAO1E,CAAC,KAAKK,KAAK,CAACsE,KAAN,EAAb;AACH,OAPD;;AAQA,UAAMC,aAAa,GAAG,SAAhBA,aAAgB,CAAC5E,CAAD;AAAA,eAAewE,SAAS,KAAK,WAAd,KAA8BxE,CAAC,KAAK,CAAN,IAAWA,CAAC,KAAK,EAA/C,CAAf;AAAA,OAAtB;;AAEA,aAAOuE,IAAI,CAAC1C,GAAL,CAAS,UAAC9B,IAAD,EAAOC,CAAP;AAAA,4BACZ;AACI,UAAA,SAAS,EAAE,4BAAG,wBAAH,EAA6BwE,SAA7B,EAAwC;AAC/CK,YAAAA,MAAM,EAAEJ,QAAQ,CAACD,SAAD,EAAYzE,IAAZ,EAAkBC,CAAlB,CAD+B;AAE/C,4BAAgB4E,aAAa,CAAC5E,CAAD;AAFkB,WAAxC,CADf;AAKI,UAAA,OAAO,EAAE;AAAA,mBAAM,MAAI,CAAC8E,WAAL,CAAiBN,SAAjB,EAA4BzE,IAA5B,EAAkCC,CAAlC,CAAN;AAAA;AALb,WAOKD,IAPL,CADY;AAAA,OAAT,CAAP;AAWH;;;WAED,yBAAgB;AACZ,UAAQL,cAAR,GAA2B,KAAKC,KAAhC,CAAQD,cAAR;AACA,UAAMqF,WAAW,GAAGC,QAAQ,CAACC,MAAM,CAACtD,MAAM,CAACjC,cAAc,CAACgE,MAAf,CAAsB,MAAtB,CAAD,CAAN,GAAwC,EAAzC,CAAP,EAAqD,EAArD,CAAR,GAAmE,EAAvF;AACA,UAAMwB,KAAK,GAAGC,KAAK,CAACC,IAAN,CACV,IAAID,KAAJ,CAAU,EAAV,CADU,EAEV,UAACE,GAAD,EAAMhD,KAAN;AAAA,eAAgB0C,WAAW,GAAG1C,KAAd,GAAsB,CAAtC;AAAA,OAFU,CAAd;AAKA,0BACI;AAAK,QAAA,SAAS,EAAC;AAAf,SACK,KAAK8B,UAAL,CAAgBe,KAAhB,EAAuB,WAAvB,CADL,CADJ;AAKH;;;WAED,8BAAqB;AACjB,UAAQ7F,YAAR,GAAyB,KAAKM,KAA9B,CAAQN,YAAR;;AAEA,UAAIA,YAAY,KAAKc,oBAAa8D,WAAlC,EAA+C;AAC3C,YAAI,KAAKzE,SAAT,EAAoB;AAChB,eAAKA,SAAL,CAAe8F,cAAf;AACH;;AACD,YAAI,KAAK7F,SAAT,EAAoB;AAChB,eAAKA,SAAL,CAAe6F,cAAf;AACH;;AACD,YAAI,KAAK/F,OAAT,EAAkB;AACd,eAAKA,OAAL,CAAa+F,cAAb;AACH;AACJ;AACJ;;;WA0BD,4BAAmB;AAAA;;AACf,UAAQ/E,WAAR,GAAwB,KAAKZ,KAA7B,CAAQY,WAAR;;AACA,kBAAoCA,WAAW,IAAI,EAAnD;AAAA,UAAQK,OAAR,SAAQA,OAAR;AAAA,UAAiBC,OAAjB,SAAiBA,OAAjB;AAAA,UAA0BF,KAA1B,SAA0BA,KAA1B;AAEA;;;AACA,0BACI,0DACI;AAAK,QAAA,SAAS,EAAC;AAAf,sBACI;AAAK,QAAA,SAAS,EAAC;AAAf,SACKwE,KAAK,CAACC,IAAN,CAAW,IAAID,KAAJ,CAAU,EAAV,CAAX,EAA0B,UAACE,GAAD,EAAMhD,KAAN;AAAA,4BACvB;AACI,UAAA,SAAS,EAAE,4BAAG,wBAAH,EAA6B;AACpCwC,YAAAA,MAAM,EAAExC,KAAK,KAAK1B;AADkB,WAA7B,CADf;AAII,UAAA,OAAO,EAAE;AAAA,mBAAM,MAAI,CAAC4E,WAAL,CAAiBlD,KAAjB,EAAwB,OAAxB,CAAN;AAAA,WAJb;AAKI,UAAA,GAAG,EAAEA,KAAK,KAAK1B,KAAV,GAAkB,MAAI,CAAC6E,UAAvB,GAAoC;AAL7C,WAOKnD,KAPL,CADuB;AAAA,OAA1B,CADL,CADJ,eAcI;AAAK,QAAA,SAAS,EAAC;AAAf,SACK8C,KAAK,CAACC,IAAN,CAAW,IAAID,KAAJ,CAAU,EAAV,CAAX,EAA0B,UAACE,GAAD,EAAMhD,KAAN;AAAA,4BACvB;AACI,UAAA,SAAS,EAAE,4BAAG,wBAAH,EAA6B;AACpCwC,YAAAA,MAAM,EAAExC,KAAK,KAAKzB;AADkB,WAA7B,CADf;AAII,UAAA,GAAG,EAAEyB,KAAK,KAAKzB,OAAV,GAAoB,MAAI,CAAC6E,YAAzB,GAAwC,IAJjD;AAKI,UAAA,OAAO,EAAE;AAAA,mBAAM,MAAI,CAACF,WAAL,CAAiBlD,KAAjB,EAAwB,SAAxB,CAAN;AAAA;AALb,WAOKA,KAPL,CADuB;AAAA,OAA1B,CADL,CAdJ,eA2BI;AAAK,QAAA,SAAS,EAAC;AAAf,SACK8C,KAAK,CAACC,IAAN,CAAW,IAAID,KAAJ,CAAU,EAAV,CAAX,EAA0B,UAACE,GAAD,EAAMhD,KAAN;AAAA,4BACvB;AACI,UAAA,SAAS,EAAE,4BAAG,wBAAH,EAA6B;AACpCwC,YAAAA,MAAM,EAAExC,KAAK,KAAKxB;AADkB,WAA7B,CADf;AAII,UAAA,GAAG,EAAEwB,KAAK,KAAKxB,OAAV,GAAoB,MAAI,CAAC6E,YAAzB,GAAwC,IAJjD;AAKI,UAAA,OAAO,EAAE;AAAA,mBAAM,MAAI,CAACH,WAAL,CAAiBlD,KAAjB,EAAwB,SAAxB,CAAN;AAAA;AALb,WAOKA,KAPL,CADuB;AAAA,OAA1B,CADL,CA3BJ,CADJ,eA0CI;AAAK,QAAA,SAAS,EAAC;AAAf,sBACI;AACI,QAAA,IAAI,EAAC,QADT;AAEI,QAAA,SAAS,EAAC,0BAFd;AAGI,QAAA,OAAO,EAAE;AAAA,iBAAM,MAAI,CAACnC,kBAAL,CAAwBC,oBAAaC,OAArC,CAAN;AAAA;AAHb,SAKK,GALL,mCADJ,eAUI;AAAQ,QAAA,SAAS,EAAC,wBAAlB;AAA2C,QAAA,OAAO,EAAE,KAAKuF,OAAzD;AAAkE,QAAA,IAAI,EAAC;AAAvE,SACK,GADL,+CAVJ,CA1CJ,CADJ;AA6DH;;;WAED,oBAAWxG,IAAX,EAAyB;AACrB,cAAQA,IAAR;AACI,aAAKgB,oBAAayF,SAAlB;AACI,iBAAO,KAAKC,cAAL,EAAP;;AACJ,aAAK1F,oBAAa2F,QAAlB;AACI,iBAAO,KAAKC,aAAL,EAAP;;AACJ,aAAK5F,oBAAa8D,WAAlB;AACI,iBAAO,KAAK+B,gBAAL,EAAP;;AACJ,aAAK7F,oBAAaC,OAAlB;AACA;AACI,iBAAO,KAAK6F,YAAL,EAAP;AATR;AAWH;;;WAED,kBAAS;AACL,UAAQ5G,YAAR,GAAyB,KAAKM,KAA9B,CAAQN,YAAR;AACA,UAAQuE,UAAR,GAAuB,KAAK1E,KAA5B,CAAQ0E,UAAR;AAEA,0BACI;AACI,QAAA,SAAS,EAAE,4BAAG,cAAH,EAAmB;AAC1B3C,UAAAA,IAAI,EAAE2C;AADoB,SAAnB;AADf,SAKK,KAAKsC,YAAL,EALL,EAMK,KAAKC,UAAL,CAAgB9G,YAAhB,CANL,CADJ;AAUH;;;EArdyB+G,kBAAMC,S","sourcesContent":["import React, { ReactNode } from 'react'\nimport isNull from 'lodash/isNull'\nimport moment, { Moment, MomentInput, unitOfTime } from 'moment/moment'\nimport cx from 'classnames'\n\nimport { Day } from './Day'\nimport { CalendarHeader } from './CalendarHeader'\nimport {\n    weeks,\n    isDateFromPrevMonth,\n    isDateFromNextMonth,\n    addTime, objFromTime,\n} from './utils'\nimport { ControlType } from './DateTimeControl'\nimport { CalendarType, Time } from './types'\n\nimport '../../styles/components/Calendar.scss'\n\ntype CalendarProps = {\n    auto?: boolean,\n    dateFormat: string,\n    hasDefaultTime?: boolean,\n    index: number,\n    inputName: string,\n    locale: 'en' | 'ru',\n    markTimeAsSet(str: string): void,\n    max?: Moment | Date | string,\n    min?: Moment | Date | string,\n    select(day: Moment, name: string, type?: boolean): void,\n    setPlacement?(): void,\n    setVisibility?(): void,\n    t(key: string): ReactNode,\n    time: Time,\n    timeFormat?: string,\n    type?: string,\n    value: Moment | null,\n    values: Record<string, MomentInput>\n}\n\ntype CalendarState = {\n    calendarType: CalendarType,\n    displayesMonth: Moment,\n    tempTimeObj: Time\n}\n\nexport class Calendar extends React.Component<CalendarProps, CalendarState> {\n    private hourRef: HTMLDivElement | null = null\n\n    private minuteRef: HTMLDivElement | null = null\n\n    private secondRef: HTMLDivElement | null = null\n\n    constructor(props: CalendarProps) {\n        super(props)\n        this.state = {\n            displayesMonth: props.value\n                ? props.value.clone().startOf('month')\n                : moment().startOf('month'),\n            calendarType: CalendarType.BY_DAYS,\n            tempTimeObj: props.value ? objFromTime(props.value) : props.time,\n        }\n    }\n\n    changeCalendarType = (type: CalendarType) => {\n        this.setState({ calendarType: type })\n    }\n\n    // eslint-disable-next-line react/no-deprecated\n    componentWillReceiveProps(props: CalendarProps) {\n        if (props.value) {\n            this.setState({\n                displayesMonth: props.value\n                    ? props.value.clone().startOf('month')\n                    : moment().startOf('month'),\n                tempTimeObj: props.value ? objFromTime(props.value) : props.time,\n            })\n        }\n    }\n\n    setHourRef = (el: HTMLDivElement) => {\n        this.hourRef = el\n    }\n\n    setMinuteRef = (el: HTMLDivElement) => {\n        this.minuteRef = el\n    }\n\n    setSecondRef = (el: HTMLDivElement) => {\n        this.secondRef = el\n    }\n\n    renderHeader() {\n        const { displayesMonth, calendarType } = this.state\n        const { locale = 'ru', t } = this.props\n        const {\n            nextMonth,\n            nextYear,\n            prevMonth,\n            prevYear,\n            nextDecade,\n            prevDecade,\n            changeCalendarType,\n        } = this\n\n        return (\n            <CalendarHeader\n                nextMonth={nextMonth}\n                nextYear={nextYear}\n                prevMonth={prevMonth}\n                prevYear={prevYear}\n                nextDecade={nextDecade}\n                prevDecade={prevDecade}\n                displayesMonth={displayesMonth}\n                locale={locale}\n                calendarType={calendarType}\n                changeCalendarType={changeCalendarType}\n                t={t}\n            />\n        )\n    }\n\n    prevMonth = () => {\n        const { displayesMonth } = this.state\n\n        this.setState({ displayesMonth: displayesMonth.subtract(1, 'months') })\n    }\n\n    nextMonth = () => {\n        const { displayesMonth } = this.state\n\n        this.setState({ displayesMonth: displayesMonth.add(1, 'months') })\n    }\n\n    prevYear = () => {\n        const { displayesMonth } = this.state\n\n        this.setState({ displayesMonth: displayesMonth.subtract(1, 'years') })\n    }\n\n    nextYear = () => {\n        const { displayesMonth } = this.state\n\n        this.setState({ displayesMonth: displayesMonth.add(1, 'years') })\n    }\n\n    nextDecade = () => {\n        const { displayesMonth } = this.state\n\n        this.setState({ displayesMonth: displayesMonth.add(10, 'years') })\n    }\n\n    prevDecade = () => {\n        const { displayesMonth } = this.state\n\n        this.setState({ displayesMonth: displayesMonth.subtract(10, 'years') })\n    }\n\n    setDate(unit: string, value: number | string) {\n        const { displayesMonth } = this.state\n\n        this.setState({ displayesMonth: displayesMonth.set(unit as unitOfTime.All, Number(value)) })\n    }\n\n    renderNameOfDays() {\n        const { locale = 'ru' } = this.props\n        const nameOfDays = locale === 'ru'\n            ? ['Пн', 'Вт', 'Ср', 'Чт', 'Пт', 'Сб', 'Вс']\n            : ['Mo', 'Tu', 'We', 'Th', 'Fr', 'Sa', 'Su']\n\n        return (\n            <tr>\n                {nameOfDays.map((day, i) => (\n                    // eslint-disable-next-line react/no-array-index-key\n                    <td key={i}>{day}</td>\n                ))}\n            </tr>\n        )\n    }\n\n    renderWeeks() {\n        const { displayesMonth, tempTimeObj } = this.state\n        const { hours, minutes, seconds } = tempTimeObj || {}\n        const firstDay = addTime(\n            displayesMonth.clone().startOf('isoWeek'),\n            hours,\n            minutes,\n            seconds,\n        )\n\n        return weeks(firstDay).map((week, i) => this.renderWeek(week, i))\n    }\n\n    renderWeek(week: Moment[], i: number) {\n        return <tr key={i}>{week.map((day, i) => this.renderDay(day, i))}</tr>\n    }\n\n    // eslint-disable-next-line complexity\n    renderDay(day: Moment, i: number) {\n        const {\n            min,\n            max,\n            value,\n            select,\n            inputName,\n            type,\n            index,\n            values,\n            dateFormat,\n        } = this.props\n\n        let disabled = false\n\n        if (min && max) {\n            disabled = day.isBefore(min) || day.isAfter(max)\n        } else if (min) {\n            disabled = day.isBefore(min)\n        } else if (max) {\n            disabled = day.isAfter(max)\n        }\n\n        if (type === ControlType.DATE_INTERVAL) {\n            const { begin } = values\n\n            const disableDaysBefore = (range: MomentInput) => day.isBefore(range)\n            const disableDaysAfter = (range: MomentInput) => day.isAfter(range)\n\n            const disabledDaysBeyondTheScopeMinMax = disableDaysBefore(min) || disableDaysAfter(max)\n            const disabledDaysBeyondTheScopeBeginMax = disableDaysBefore(begin) || disableDaysAfter(max)\n\n            // eslint-disable-next-line no-unused-vars,no-return-assign, @typescript-eslint/no-unused-vars\n            const rangeMinMax = (disabledDays: boolean) => (disabledDays = disabledDaysBeyondTheScopeMinMax)\n\n            // если не выбрана дата(begin) ||  min or max\n            const hasMinOrMaxAndNullBegin = (isNull(begin) && (min || max)) || (isNull(begin) && (min && max))\n\n            // если hasMinOrMaxAndNullBegin, устанавливаем default range (min or max)\n            if (hasMinOrMaxAndNullBegin) {\n                rangeMinMax(disabled)\n            } else if (min && max) {\n                disabled = index === 0\n                    ? disabledDaysBeyondTheScopeMinMax\n                    : disabledDaysBeyondTheScopeBeginMax\n            } else if (min) {\n                disabled = index === 0\n                    ? disableDaysBefore(min)\n                    : index === 1 && disableDaysBefore(begin)\n            } else if (max) {\n                disabled = index === 0\n                    ? disableDaysAfter(max)\n                    : index === 1 && disableDaysAfter(begin)\n            } else {\n                // не указан range (min, max)\n                disabled = index === 1 && disableDaysBefore(begin)\n            }\n        }\n\n        const { displayesMonth } = this.state\n        const otherMonth = isDateFromNextMonth(day, displayesMonth) ||\n            isDateFromPrevMonth(day, displayesMonth)\n        const selected = day.isSame(value)\n        const current = day.format('DD.MM.YYYY') === moment().format('DD.MM.YYYY')\n        const props = {\n            day,\n            otherMonth,\n            selected,\n            disabled,\n            select,\n            inputName,\n            current,\n            dateFormat,\n        }\n\n        return <Day key={i} {...props} />\n    }\n\n    renderTime() {\n        const { value, hasDefaultTime, timeFormat, t } = this.props\n\n        if (hasDefaultTime) {\n            if (value) {\n                return value.format(timeFormat)\n            }\n\n            return '00:00:00'\n        }\n\n        if (t) {\n            return t('chooseTime')\n        }\n\n        return null\n    }\n\n    renderByDays() {\n        const { timeFormat } = this.props\n\n        return (\n            <>\n                <table className=\"n2o-calendar-table\">\n                    <thead>{this.renderNameOfDays()}</thead>\n                    <tbody>{this.renderWeeks()}</tbody>\n                </table>\n                {timeFormat && (\n                    <a\n                        className=\"n2o-calendar-time-container\"\n                        href=\"/test\"\n                        onClick={(e) => {\n                            e.preventDefault()\n                            this.changeCalendarType(CalendarType.TIME_PICKER)\n                        }}\n                    >\n                        {this.renderTime()}\n                    </a>\n                )}\n            </>\n        )\n    }\n\n    renderByMonths() {\n        const { locale = 'ru' } = this.props\n\n        return (\n            <div className=\"n2o-calendar-body\">\n                {this.renderList(moment.localeData(locale).months(), 'month-item')}\n            </div>\n        )\n    }\n\n    onItemClick = (itemType: string, item: string | number, i: number) => {\n        if (itemType === 'month-item') {\n            this.setDate('month', i)\n        } else {\n            this.setDate('year', item)\n        }\n        this.changeCalendarType(CalendarType.BY_DAYS)\n    }\n\n    renderList(list: Array<string | number>, className: string) {\n        const { value } = this.props\n\n        const isActive = (className: string, item: string | number, i: number) => {\n            if (!value) { return false }\n            if (className !== 'month-item') {\n                return item === value.year()\n            }\n\n            return i === value.month()\n        }\n        const isOtherDecade = (i: number) => className === 'year-item' && (i === 0 || i === 11)\n\n        return list.map((item, i) => (\n            <div\n                className={cx('n2o-calendar-body-item', className, {\n                    active: isActive(className, item, i),\n                    'other-decade': isOtherDecade(i),\n                })}\n                onClick={() => this.onItemClick(className, item, i)}\n            >\n                {item}\n            </div>\n        ))\n    }\n\n    renderByYears() {\n        const { displayesMonth } = this.state\n        const decadeStart = parseInt(String(Number(displayesMonth.format('YYYY')) / 10), 10) * 10\n        const years = Array.from(\n            new Array(12),\n            (val, index) => decadeStart + index - 1,\n        )\n\n        return (\n            <div className=\"n2o-calendar-body\">\n                {this.renderList(years, 'year-item')}\n            </div>\n        )\n    }\n\n    componentDidUpdate() {\n        const { calendarType } = this.state\n\n        if (calendarType === CalendarType.TIME_PICKER) {\n            if (this.minuteRef) {\n                this.minuteRef.scrollIntoView()\n            }\n            if (this.secondRef) {\n                this.secondRef.scrollIntoView()\n            }\n            if (this.hourRef) {\n                this.hourRef.scrollIntoView()\n            }\n        }\n    }\n\n    setTimeUnit = (value: number, unit: string) => {\n        const { tempTimeObj } = this.state\n\n        this.setState({\n            tempTimeObj: { ...tempTimeObj, [unit]: value },\n        })\n    }\n\n    setTime = () => {\n        const { value, inputName, markTimeAsSet, select } = this.props\n        const { tempTimeObj } = this.state\n        const { hours, minutes, seconds } = tempTimeObj || {}\n        const copyValue = value || moment()\n\n        this.changeCalendarType(CalendarType.BY_DAYS)\n        markTimeAsSet(inputName)\n\n        select(\n            addTime(copyValue.clone().startOf('day'), hours, minutes, seconds),\n            inputName,\n            false,\n        )\n    }\n\n    renderTimePicker() {\n        const { tempTimeObj } = this.state\n        const { minutes, seconds, hours } = tempTimeObj || {}\n\n        /* eslint-disable react/jsx-one-expression-per-line */\n        return (\n            <div>\n                <div className=\"n2o-calendar-timepicker\">\n                    <div className=\"n2o-calendar-picker hour-picker\">\n                        {Array.from(new Array(24), (val, index) => (\n                            <div\n                                className={cx('n2o-calendar-time-unit', {\n                                    active: index === hours,\n                                })}\n                                onClick={() => this.setTimeUnit(index, 'hours')}\n                                ref={index === hours ? this.setHourRef : null}\n                            >\n                                {index}\n                            </div>\n                        ))}\n                    </div>\n                    <div className=\"n2o-calendar-picker minute-picker\">\n                        {Array.from(new Array(60), (val, index) => (\n                            <div\n                                className={cx('n2o-calendar-time-unit', {\n                                    active: index === minutes,\n                                })}\n                                ref={index === minutes ? this.setMinuteRef : null}\n                                onClick={() => this.setTimeUnit(index, 'minutes')}\n                            >\n                                {index}\n                            </div>\n                        ))}\n                    </div>\n                    <div className=\"n2o-calendar-picker second-picker\">\n                        {Array.from(new Array(60), (val, index) => (\n                            <div\n                                className={cx('n2o-calendar-time-unit', {\n                                    active: index === seconds,\n                                })}\n                                ref={index === seconds ? this.setSecondRef : null}\n                                onClick={() => this.setTimeUnit(index, 'seconds')}\n                            >\n                                {index}\n                            </div>\n                        ))}\n                    </div>\n                </div>\n                <div className=\"n2o-calendar-time-buttons\">\n                    <button\n                        type=\"button\"\n                        className=\"btn btn-secondary btn-sm\"\n                        onClick={() => this.changeCalendarType(CalendarType.BY_DAYS)}\n                    >\n                        {' '}\n\n                        Назад\n                    </button>\n                    <button className=\"btn btn-primary btn-sm\" onClick={this.setTime} type=\"button\">\n                        {' '}\n\n                        Выбрать\n                    </button>\n                </div>\n            </div>\n        )\n    }\n\n    renderBody(type: string) {\n        switch (type) {\n            case CalendarType.BY_MONTHS:\n                return this.renderByMonths()\n            case CalendarType.BY_YEARS:\n                return this.renderByYears()\n            case CalendarType.TIME_PICKER:\n                return this.renderTimePicker()\n            case CalendarType.BY_DAYS:\n            default:\n                return this.renderByDays()\n        }\n    }\n\n    render() {\n        const { calendarType } = this.state\n        const { timeFormat } = this.props\n\n        return (\n            <div\n                className={cx('n2o-calendar', {\n                    time: timeFormat,\n                })}\n            >\n                {this.renderHeader()}\n                {this.renderBody(calendarType)}\n            </div>\n        )\n    }\n}\n"]}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import React, { ReactNode } from 'react';
|
|
2
|
+
import type { Moment } from 'moment';
|
|
3
|
+
import 'moment/locale/ru';
|
|
4
|
+
import { CalendarType } from './types';
|
|
5
|
+
import '../../styles/components/CalendarHeader.scss';
|
|
6
|
+
declare type CalendarHeaderProps = {
|
|
7
|
+
calendarType: CalendarType;
|
|
8
|
+
changeCalendarType(type?: CalendarType): void;
|
|
9
|
+
displayesMonth: Moment;
|
|
10
|
+
locale: string;
|
|
11
|
+
nextDecade(): void;
|
|
12
|
+
nextMonth(): void;
|
|
13
|
+
nextYear(): void;
|
|
14
|
+
prevDecade(): void;
|
|
15
|
+
prevMonth(): void;
|
|
16
|
+
prevYear(): void;
|
|
17
|
+
t(str: string): ReactNode;
|
|
18
|
+
};
|
|
19
|
+
export declare class CalendarHeader extends React.Component<CalendarHeaderProps> {
|
|
20
|
+
renderHeaderValue(displayesMonth: Moment, locale: string, type?: CalendarType): string | JSX.Element | null;
|
|
21
|
+
static nextType: (type: CalendarType) => CalendarType.BY_MONTHS | CalendarType.BY_YEARS | CalendarType.TIME_PICKER | undefined;
|
|
22
|
+
nextView: (type: CalendarType) => void;
|
|
23
|
+
prevView: (type: CalendarType) => void;
|
|
24
|
+
render(): JSX.Element;
|
|
25
|
+
}
|
|
26
|
+
export {};
|