@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.
Files changed (241) hide show
  1. package/index.js +0 -0
  2. package/lib/display/Alerts/Alert.d.ts +2 -0
  3. package/lib/display/Alerts/Alert.js +121 -0
  4. package/lib/display/Alerts/AlertSection.d.ts +18 -0
  5. package/lib/display/Alerts/AlertSection.js +64 -0
  6. package/lib/display/Alerts/AlertWrapper.d.ts +6 -0
  7. package/lib/display/Alerts/AlertWrapper.js +39 -0
  8. package/lib/display/Alerts/DefaultAlert.d.ts +6 -0
  9. package/lib/display/Alerts/DefaultAlert.js +125 -0
  10. package/lib/display/Alerts/LoaderAlert.d.ts +5 -0
  11. package/lib/display/Alerts/LoaderAlert.js +36 -0
  12. package/lib/display/Alerts/types.d.ts +49 -0
  13. package/lib/display/Alerts/types.js +24 -0
  14. package/lib/display/Alerts/utils.d.ts +15 -0
  15. package/lib/display/Alerts/utils.js +102 -0
  16. package/lib/display/Badge/Badge.d.ts +16 -0
  17. package/lib/display/Badge/Badge.js +77 -0
  18. package/lib/display/Badge/enums.d.ts +9 -0
  19. package/lib/display/Badge/enums.js +23 -0
  20. package/lib/display/Badge/utils.d.ts +9 -0
  21. package/lib/display/Badge/utils.js +49 -0
  22. package/lib/display/Block.d.ts +369 -0
  23. package/lib/display/Block.js +38 -0
  24. package/lib/display/CodeViewer/CodeViewer.d.ts +13 -0
  25. package/lib/display/CodeViewer/CodeViewer.js +96 -0
  26. package/lib/display/Drawer/Drawer.d.ts +25 -0
  27. package/lib/display/Drawer/Drawer.js +99 -0
  28. package/lib/display/DropdownCustomItem.d.ts +7 -0
  29. package/lib/display/DropdownCustomItem.js +23 -0
  30. package/lib/display/Filter/Buttons.d.ts +11 -0
  31. package/lib/display/Filter/Buttons.js +42 -0
  32. package/lib/display/Filter/Filter.d.ts +8 -0
  33. package/lib/display/Filter/Filter.js +38 -0
  34. package/lib/display/HelpPopover.d.ts +16 -0
  35. package/lib/display/HelpPopover.js +104 -0
  36. package/lib/display/Html.d.ts +8 -0
  37. package/lib/display/Html.js +29 -0
  38. package/lib/display/Icon/Icon.d.ts +11 -0
  39. package/lib/display/Icon/Icon.js +42 -0
  40. package/lib/display/Image/Image.d.ts +30 -0
  41. package/lib/display/Image/Image.js +93 -0
  42. package/lib/display/Image/ImageInfo.d.ts +7 -0
  43. package/lib/display/Image/ImageInfo.js +23 -0
  44. package/lib/display/InputIcon.d.ts +13 -0
  45. package/lib/display/InputIcon.js +33 -0
  46. package/lib/display/NavItemImage/NavItemImage.d.ts +9 -0
  47. package/lib/display/NavItemImage/NavItemImage.js +35 -0
  48. package/lib/display/OutputList.d.ts +12 -0
  49. package/lib/display/OutputList.js +46 -0
  50. package/lib/display/OutputListItem.d.ts +10 -0
  51. package/lib/display/OutputListItem.js +58 -0
  52. package/lib/display/OutputText.d.ts +15 -0
  53. package/lib/display/OutputText.js +170 -0
  54. package/lib/display/Pagination/Pagination.d.ts +2 -0
  55. package/lib/display/Pagination/Pagination.js +273 -0
  56. package/lib/display/Pagination/PaginationButton.d.ts +13 -0
  57. package/lib/display/Pagination/PaginationButton.js +53 -0
  58. package/lib/display/Pagination/types.d.ts +62 -0
  59. package/lib/display/Pagination/types.js +36 -0
  60. package/lib/display/PopoverConfirm/PopoverConfirm.d.ts +30 -0
  61. package/lib/display/PopoverConfirm/PopoverConfirm.js +87 -0
  62. package/lib/display/ProgressControl/ProgressControl.d.ts +17 -0
  63. package/lib/display/ProgressControl/ProgressControl.js +68 -0
  64. package/lib/display/Slider.d.ts +23 -0
  65. package/lib/display/Slider.js +107 -0
  66. package/lib/display/Status.d.ts +9 -0
  67. package/lib/display/Status.js +40 -0
  68. package/lib/display/StatusText/StatusText.d.ts +10 -0
  69. package/lib/display/StatusText/StatusText.js +35 -0
  70. package/lib/display/StatusText/types.d.ts +18 -0
  71. package/lib/display/StatusText/types.js +19 -0
  72. package/lib/display/StatusText/utils.d.ts +3 -0
  73. package/lib/display/StatusText/utils.js +29 -0
  74. package/lib/display/Text.d.ts +12 -0
  75. package/lib/display/Text.js +38 -0
  76. package/lib/display/Typography/Base.d.ts +32 -0
  77. package/lib/display/Typography/Base.js +259 -0
  78. package/lib/display/Typography/ContentEditable.d.ts +15 -0
  79. package/lib/display/Typography/ContentEditable.js +86 -0
  80. package/lib/display/Typography/Paragraph.d.ts +4 -0
  81. package/lib/display/Typography/Paragraph.js +23 -0
  82. package/lib/display/Typography/Text.d.ts +9 -0
  83. package/lib/display/Typography/Text.js +37 -0
  84. package/lib/display/Typography/Title.d.ts +7 -0
  85. package/lib/display/Typography/Title.js +28 -0
  86. package/lib/display/Typography/utils.d.ts +13 -0
  87. package/lib/display/Typography/utils.js +75 -0
  88. package/lib/helpers/HelpPopover.d.ts +9 -0
  89. package/lib/helpers/HelpPopover.js +46 -0
  90. package/lib/helpers/withRightPlaceholder.d.ts +9 -0
  91. package/lib/helpers/withRightPlaceholder.js +35 -0
  92. package/lib/inputs/Checkbox/Checkbox.d.ts +29 -0
  93. package/lib/inputs/Checkbox/Checkbox.js +117 -0
  94. package/lib/inputs/Checkbox/CheckboxControl.d.ts +7 -0
  95. package/lib/inputs/Checkbox/CheckboxControl.js +33 -0
  96. package/lib/inputs/CheckboxGroup/CheckboxGroup.d.ts +11 -0
  97. package/lib/inputs/CheckboxGroup/CheckboxGroup.js +84 -0
  98. package/lib/inputs/CodeEditor/CodeEditor.d.ts +21 -0
  99. package/lib/inputs/CodeEditor/CodeEditor.js +85 -0
  100. package/lib/inputs/DatePicker/Calendar.d.ts +65 -0
  101. package/lib/inputs/DatePicker/Calendar.js +556 -0
  102. package/lib/inputs/DatePicker/CalendarHeader.d.ts +26 -0
  103. package/lib/inputs/DatePicker/CalendarHeader.js +213 -0
  104. package/lib/inputs/DatePicker/Clock.d.ts +10 -0
  105. package/lib/inputs/DatePicker/Clock.js +45 -0
  106. package/lib/inputs/DatePicker/DateInput.d.ts +44 -0
  107. package/lib/inputs/DatePicker/DateInput.js +262 -0
  108. package/lib/inputs/DatePicker/DateInputGroup.d.ts +20 -0
  109. package/lib/inputs/DatePicker/DateInputGroup.js +77 -0
  110. package/lib/inputs/DatePicker/DateInterval.d.ts +24 -0
  111. package/lib/inputs/DatePicker/DateInterval.js +92 -0
  112. package/lib/inputs/DatePicker/DatePicker.d.ts +22 -0
  113. package/lib/inputs/DatePicker/DatePicker.js +36 -0
  114. package/lib/inputs/DatePicker/DateTimeControl.d.ts +98 -0
  115. package/lib/inputs/DatePicker/DateTimeControl.js +452 -0
  116. package/lib/inputs/DatePicker/Day.d.ts +14 -0
  117. package/lib/inputs/DatePicker/Day.js +50 -0
  118. package/lib/inputs/DatePicker/PopUp.d.ts +19 -0
  119. package/lib/inputs/DatePicker/PopUp.js +71 -0
  120. package/lib/inputs/DatePicker/types.d.ts +31 -0
  121. package/lib/inputs/DatePicker/types.js +25 -0
  122. package/lib/inputs/DatePicker/utils.d.ts +39 -0
  123. package/lib/inputs/DatePicker/utils.js +304 -0
  124. package/lib/inputs/Input.d.ts +51 -0
  125. package/lib/inputs/Input.js +200 -0
  126. package/lib/inputs/InputMask/InputMask.d.ts +23 -0
  127. package/lib/inputs/InputMask/InputMask.js +310 -0
  128. package/lib/inputs/InputMoney/InputMoney.d.ts +101 -0
  129. package/lib/inputs/InputMoney/InputMoney.js +258 -0
  130. package/lib/inputs/InputNumber/InputNumber.d.ts +29 -0
  131. package/lib/inputs/InputNumber/InputNumber.js +316 -0
  132. package/lib/inputs/InputNumber/index.d.ts +1 -0
  133. package/lib/inputs/InputNumber/index.js +14 -0
  134. package/lib/inputs/InputNumber/types.d.ts +18 -0
  135. package/lib/inputs/InputNumber/types.js +14 -0
  136. package/lib/inputs/InputNumber/utils.d.ts +6 -0
  137. package/lib/inputs/InputNumber/utils.js +86 -0
  138. package/lib/inputs/InputPassword/InputPassword.d.ts +10 -0
  139. package/lib/inputs/InputPassword/InputPassword.js +81 -0
  140. package/lib/inputs/InputSelect/InputAddon.d.ts +17 -0
  141. package/lib/inputs/InputSelect/InputAddon.js +31 -0
  142. package/lib/inputs/InputSelect/InputContent.d.ts +63 -0
  143. package/lib/inputs/InputSelect/InputContent.js +188 -0
  144. package/lib/inputs/InputSelect/InputSelect.d.ts +296 -0
  145. package/lib/inputs/InputSelect/InputSelect.js +795 -0
  146. package/lib/inputs/InputSelect/InputSelectGroup.d.ts +43 -0
  147. package/lib/inputs/InputSelect/InputSelectGroup.js +113 -0
  148. package/lib/inputs/InputSelect/PopupItems.d.ts +55 -0
  149. package/lib/inputs/InputSelect/PopupItems.js +357 -0
  150. package/lib/inputs/InputSelect/PopupList.d.ts +82 -0
  151. package/lib/inputs/InputSelect/PopupList.js +138 -0
  152. package/lib/inputs/InputSelect/SelectedItems.d.ts +17 -0
  153. package/lib/inputs/InputSelect/SelectedItems.js +125 -0
  154. package/lib/inputs/InputSelect/constants.d.ts +4 -0
  155. package/lib/inputs/InputSelect/constants.js +15 -0
  156. package/lib/inputs/InputSelect/types.d.ts +16 -0
  157. package/lib/inputs/InputSelect/types.js +16 -0
  158. package/lib/inputs/InputSelect/utils.d.ts +9 -0
  159. package/lib/inputs/InputSelect/utils.js +142 -0
  160. package/lib/inputs/InputSelectTree/InputSelectTree.d.ts +114 -0
  161. package/lib/inputs/InputSelectTree/InputSelectTree.js +466 -0
  162. package/lib/inputs/InputSelectTree/TreeSelectNode.d.ts +36 -0
  163. package/lib/inputs/InputSelectTree/TreeSelectNode.js +63 -0
  164. package/lib/inputs/InputSelectTree/allProps.d.ts +123 -0
  165. package/lib/inputs/InputSelectTree/allProps.js +48 -0
  166. package/lib/inputs/InputSelectTree/until.d.ts +4 -0
  167. package/lib/inputs/InputSelectTree/until.js +83 -0
  168. package/lib/inputs/InputText.d.ts +41 -0
  169. package/lib/inputs/InputText.js +170 -0
  170. package/lib/inputs/NumberPicker/NumberPicker.d.ts +15 -0
  171. package/lib/inputs/NumberPicker/NumberPicker.js +129 -0
  172. package/lib/inputs/NumberPicker/NumberPickerButton.d.ts +8 -0
  173. package/lib/inputs/NumberPicker/NumberPickerButton.js +64 -0
  174. package/lib/inputs/NumberPicker/index.d.ts +1 -0
  175. package/lib/inputs/NumberPicker/index.js +14 -0
  176. package/lib/inputs/NumberPicker/utils.d.ts +2 -0
  177. package/lib/inputs/NumberPicker/utils.js +31 -0
  178. package/lib/inputs/RadioGroup/default/Group.d.ts +15 -0
  179. package/lib/inputs/RadioGroup/default/Group.js +63 -0
  180. package/lib/inputs/RadioGroup/default/Input.d.ts +17 -0
  181. package/lib/inputs/RadioGroup/default/Input.js +77 -0
  182. package/lib/inputs/RadioGroup/tabs/Group.d.ts +3 -0
  183. package/lib/inputs/RadioGroup/tabs/Group.js +24 -0
  184. package/lib/inputs/RadioGroup/tabs/Input.d.ts +3 -0
  185. package/lib/inputs/RadioGroup/tabs/Input.js +21 -0
  186. package/lib/inputs/Rating/Rating.d.ts +30 -0
  187. package/lib/inputs/Rating/Rating.js +212 -0
  188. package/lib/inputs/Select/Popup.d.ts +31 -0
  189. package/lib/inputs/Select/Popup.js +131 -0
  190. package/lib/inputs/Select/Select.d.ts +225 -0
  191. package/lib/inputs/Select/Select.js +705 -0
  192. package/lib/inputs/Select/SelectInput.d.ts +19 -0
  193. package/lib/inputs/Select/SelectInput.js +85 -0
  194. package/lib/inputs/Select/utils.d.ts +1 -0
  195. package/lib/inputs/Select/utils.js +28 -0
  196. package/lib/inputs/Switch/Switch.d.ts +11 -0
  197. package/lib/inputs/Switch/Switch.js +41 -0
  198. package/lib/inputs/TextArea.d.ts +12 -0
  199. package/lib/inputs/TextArea.js +54 -0
  200. package/lib/inputs/TextEditor/TextEditor.d.ts +11 -0
  201. package/lib/inputs/TextEditor/TextEditor.js +89 -0
  202. package/lib/inputs/TimePicker/TimePicker.d.ts +50 -0
  203. package/lib/inputs/TimePicker/TimePicker.js +398 -0
  204. package/lib/inputs/utils.d.ts +5 -0
  205. package/lib/inputs/utils.js +39 -0
  206. package/lib/layouts/ScrollContainer.d.ts +218 -0
  207. package/lib/layouts/ScrollContainer.js +128 -0
  208. package/lib/layouts/Spinner/CoverSpinner.d.ts +29 -0
  209. package/lib/layouts/Spinner/CoverSpinner.js +153 -0
  210. package/lib/layouts/Spinner/InlineSpinner.d.ts +5 -0
  211. package/lib/layouts/Spinner/InlineSpinner.js +27 -0
  212. package/lib/layouts/Spinner/Spinner.d.ts +31 -0
  213. package/lib/layouts/Spinner/Spinner.js +178 -0
  214. package/lib/styles/components/Calendar.scss +125 -0
  215. package/lib/styles/components/CalendarHeader.scss +75 -0
  216. package/lib/styles/components/DateInputGroup.scss +39 -0
  217. package/lib/styles/components/DatePicker.scss +18 -0
  218. package/lib/styles/components/Day.scss +29 -0
  219. package/lib/styles/components/OutputList.scss +14 -0
  220. package/lib/styles/components/OutputText.scss +50 -0
  221. package/lib/styles/controls/CodeEditor.scss +4 -0
  222. package/lib/styles/controls/InputNumber.scss +36 -0
  223. package/lib/styles/controls/InputPassword.scss +17 -0
  224. package/lib/styles/controls/InputText.scss +59 -0
  225. package/lib/styles/controls/NumberPicker.scss +36 -0
  226. package/lib/styles/controls/ProgressControl.scss +3 -0
  227. package/lib/styles/controls/Slider.scss +32 -0
  228. package/lib/styles/controls/Switch.scss +105 -0
  229. package/lib/styles/controls/TextEditor.scss +23 -0
  230. package/lib/styles/controls/TimePicker.scss +32 -0
  231. package/lib/styles/n2o/variables.scss +328 -0
  232. package/lib/styles/theme/variables.scss +81 -0
  233. package/lib/styles/variables.scss +10 -0
  234. package/lib/types.d.ts +25 -0
  235. package/lib/types.js +6 -0
  236. package/lib/utils/id.d.ts +3 -0
  237. package/lib/utils/id.js +46 -0
  238. package/lib/utils/isEmptyModel.d.ts +1 -0
  239. package/lib/utils/isEmptyModel.js +21 -0
  240. package/lib/utils/parseFormatter.js +153 -0
  241. 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":"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","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 {};