intelicoreact 0.0.6 → 0.0.9

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 (117) hide show
  1. package/dist/Atomic/FormElements/CheckboxInput/CheckboxInput.js +6 -2
  2. package/dist/Atomic/FormElements/CheckboxInput/CheckboxInput.scss +91 -60
  3. package/dist/Atomic/FormElements/CheckboxInput/CheckboxInput.stories.js +2 -1
  4. package/dist/Atomic/FormElements/Dropdown/Dropdown.js +84 -28
  5. package/dist/Atomic/FormElements/Dropdown/Dropdown.scss +27 -3
  6. package/dist/Atomic/FormElements/Dropdown/Dropdown.stories.js +50 -7
  7. package/dist/Atomic/FormElements/Dropdown/components/DropdownLoader.js +20 -0
  8. package/dist/Atomic/FormElements/Dropdown/components/Loader.scss +57 -0
  9. package/dist/Atomic/FormElements/Input/Input.js +124 -50
  10. package/dist/Atomic/FormElements/Input/Input.stories.js +19 -15
  11. package/dist/Atomic/FormElements/InputCalendar/InputCalendar.js +33 -31
  12. package/dist/Atomic/FormElements/InputCalendar/InputCalendar.stories.js +29 -19
  13. package/dist/Atomic/FormElements/InputDateRange/{components/InputDateRange.js → InputDateRange.js} +54 -62
  14. package/dist/Atomic/FormElements/InputDateRange/{components/InputDateRange.scss → InputDateRange.scss} +254 -228
  15. package/dist/Atomic/FormElements/InputDateRange/InputDateRange.stories.js +15 -160
  16. package/dist/Atomic/FormElements/InputDateRange/components/Datepicker.js +72 -34
  17. package/dist/Atomic/FormElements/InputDateRange/components/OpenedPart.js +26 -11
  18. package/dist/Atomic/FormElements/InputDateRange/components/SelectItem.js +14 -6
  19. package/dist/Atomic/FormElements/InputDateRange/{index.js → dependencies.js} +19 -18
  20. package/dist/Atomic/FormElements/NumericInput/NumericInput.js +292 -0
  21. package/dist/Atomic/FormElements/NumericInput/NumericInput.scss +135 -0
  22. package/dist/Atomic/FormElements/NumericInput/NumericInput.stories.js +117 -0
  23. package/dist/Atomic/FormElements/RangeCalendar/RangeCalendar.js +10 -3
  24. package/dist/Atomic/FormElements/RangeCalendar/RangeCalendar.scss +4 -4
  25. package/dist/Atomic/FormElements/Table/Table.scss +1 -1
  26. package/dist/Atomic/FormElements/Textarea/Textarea.scss +1 -1
  27. package/dist/Atomic/MainMenu/MainMenu.scss +2 -2
  28. package/dist/Atomic/UI/Accordion/Accordion.scss +2 -2
  29. package/dist/Atomic/UI/Arrow/Arrow.js +6 -6
  30. package/dist/Atomic/UI/Arrow/Arrow.scss +0 -3
  31. package/dist/Atomic/UI/Calendar/Calendar.js +8 -5
  32. package/dist/Atomic/UI/Calendar/Calendar.scss +19 -3
  33. package/dist/Atomic/UI/Calendar/Calendar.stories.js +3 -2
  34. package/dist/Atomic/UI/Status/Status.scss +1 -1
  35. package/dist/Constants/index.constants.js +8 -0
  36. package/dist/Functions/inputExecutor.js +58 -0
  37. package/dist/Molecular/Datepicker/Datepicker.js +451 -0
  38. package/dist/Molecular/Datepicker/Datepicker.scss +8 -0
  39. package/dist/Molecular/Datepicker/Datepicker.stories.js +44 -0
  40. package/dist/{Atomic/FormElements/Calendar → Molecular/Datepicker/components}/Calendar.js +50 -39
  41. package/dist/scss/_vars.scss +3 -1
  42. package/dist/scss/main.scss +1 -1
  43. package/package.json +5 -4
  44. package/src/Atomic/FormElements/CheckboxInput/CheckboxInput.js +12 -2
  45. package/src/Atomic/FormElements/CheckboxInput/CheckboxInput.scss +91 -60
  46. package/src/Atomic/FormElements/CheckboxInput/CheckboxInput.stories.js +4 -3
  47. package/src/Atomic/FormElements/Dropdown/Dropdown.js +104 -39
  48. package/src/Atomic/FormElements/Dropdown/Dropdown.scss +27 -3
  49. package/src/Atomic/FormElements/Dropdown/Dropdown.stories.js +42 -15
  50. package/src/Atomic/FormElements/Dropdown/components/DropdownLoader.js +16 -0
  51. package/src/Atomic/FormElements/Dropdown/components/Loader.scss +57 -0
  52. package/src/Atomic/FormElements/Input/Input.js +108 -37
  53. package/src/Atomic/FormElements/Input/Input.stories.js +43 -22
  54. package/src/Atomic/FormElements/InputCalendar/InputCalendar.js +18 -17
  55. package/src/Atomic/FormElements/InputCalendar/InputCalendar.stories.js +17 -14
  56. package/src/Atomic/FormElements/InputDateRange/InputDateRange.js +219 -0
  57. package/src/Atomic/FormElements/InputDateRange/{components/InputDateRange.scss → InputDateRange.scss} +254 -228
  58. package/src/Atomic/FormElements/InputDateRange/InputDateRange.stories.js +38 -117
  59. package/src/Atomic/FormElements/InputDateRange/components/Datepicker.js +92 -53
  60. package/src/Atomic/FormElements/InputDateRange/components/OpenedPart.js +14 -5
  61. package/src/Atomic/FormElements/InputDateRange/components/SelectItem.js +5 -3
  62. package/src/Atomic/FormElements/InputDateRange/{index.js → dependencies.js} +16 -12
  63. package/src/Atomic/FormElements/NumericInput/NumericInput.js +263 -0
  64. package/src/Atomic/FormElements/NumericInput/NumericInput.scss +135 -0
  65. package/src/Atomic/FormElements/NumericInput/NumericInput.stories.js +78 -0
  66. package/src/Atomic/FormElements/RangeCalendar/RangeCalendar.js +6 -3
  67. package/src/Atomic/FormElements/RangeCalendar/RangeCalendar.scss +4 -4
  68. package/src/Atomic/FormElements/Table/Table.scss +1 -1
  69. package/src/Atomic/FormElements/Textarea/Textarea.scss +1 -1
  70. package/src/Atomic/MainMenu/MainMenu.scss +2 -2
  71. package/src/Atomic/UI/Accordion/Accordion.scss +2 -2
  72. package/src/Atomic/UI/Arrow/Arrow.js +4 -4
  73. package/src/Atomic/UI/Arrow/Arrow.scss +0 -3
  74. package/src/Atomic/UI/Calendar/Calendar.js +4 -4
  75. package/src/Atomic/UI/Calendar/Calendar.scss +19 -3
  76. package/src/Atomic/UI/Calendar/Calendar.stories.js +2 -1
  77. package/src/Atomic/UI/Status/Status.scss +1 -1
  78. package/src/Constants/index.constants.js +41 -0
  79. package/src/Functions/inputExecutor.js +53 -0
  80. package/src/Functions/utils.js +4 -1
  81. package/src/Molecular/Datepicker/Datepicker.js +346 -0
  82. package/src/Molecular/Datepicker/Datepicker.scss +8 -0
  83. package/src/Molecular/Datepicker/Datepicker.stories.js +27 -0
  84. package/src/Molecular/Datepicker/components/Calendar.js +118 -0
  85. package/src/scss/_vars.scss +3 -1
  86. package/src/scss/main.scss +1 -1
  87. package/dist/Atomic/FormElements/Calendar/Calendar.scss +0 -543
  88. package/dist/Atomic/FormElements/Calendar/Calendar.stories.js +0 -33
  89. package/dist/scss/anme/_anme-bootstrap-grid.scss +0 -748
  90. package/dist/scss/anme/_anme-elements.scss +0 -269
  91. package/dist/scss/anme/_anme-grid.scss +0 -111
  92. package/dist/scss/anme/_anme-justify.scss +0 -111
  93. package/dist/scss/anme/_anme-mixins-media.scss +0 -116
  94. package/dist/scss/anme/_anme-mixins.scss +0 -166
  95. package/dist/scss/anme/_anme-normalize.scss +0 -8
  96. package/dist/scss/anme/_anme-overall.scss +0 -34
  97. package/dist/scss/anme/_anme-padding-margins.scss +0 -419
  98. package/dist/scss/anme/_anme-table.scss +0 -81
  99. package/dist/scss/anme/_anme-theme.scss +0 -275
  100. package/dist/scss/anme/_anme-vars.scss +0 -91
  101. package/dist/scss/anme/_code-styling.scss +0 -23
  102. package/dist/scss/anme/styles.scss +0 -12
  103. package/src/Atomic/FormElements/InputDateRange/components/InputDateRange.js +0 -230
  104. package/src/scss/anme/_anme-bootstrap-grid.scss +0 -748
  105. package/src/scss/anme/_anme-elements.scss +0 -269
  106. package/src/scss/anme/_anme-grid.scss +0 -111
  107. package/src/scss/anme/_anme-justify.scss +0 -111
  108. package/src/scss/anme/_anme-mixins-media.scss +0 -116
  109. package/src/scss/anme/_anme-mixins.scss +0 -166
  110. package/src/scss/anme/_anme-normalize.scss +0 -8
  111. package/src/scss/anme/_anme-overall.scss +0 -34
  112. package/src/scss/anme/_anme-padding-margins.scss +0 -419
  113. package/src/scss/anme/_anme-table.scss +0 -81
  114. package/src/scss/anme/_anme-theme.scss +0 -275
  115. package/src/scss/anme/_anme-vars.scss +0 -91
  116. package/src/scss/anme/_code-styling.scss +0 -23
  117. package/src/scss/anme/styles.scss +0 -12
@@ -1,4 +1,4 @@
1
- @import "../../../scss/anme/anme-vars";
1
+ @import "~anme/scss/anme-vars";
2
2
 
3
3
  .status {
4
4
  display: inline-flex;
@@ -0,0 +1,41 @@
1
+
2
+ export const KEYBOARD_SERVICE_KEYS = [
3
+ 'Escape',
4
+ 'F1',
5
+ 'F2',
6
+ 'F3',
7
+ 'F4',
8
+ 'F5',
9
+ 'F6',
10
+ 'F7',
11
+ 'F8',
12
+ 'F9',
13
+ 'F10',
14
+ 'F11',
15
+ 'F12',
16
+ 'Tab',
17
+ 'CapsLock',
18
+ 'Shift',
19
+ 'Control',
20
+ 'Meta',
21
+ 'Option',
22
+ 'Alt',
23
+ 'ContextMenu',
24
+ 'ArrowLeft',
25
+ 'ArrowRight',
26
+ 'ArrowUp',
27
+ 'ArrowDown',
28
+ 'NumLock',
29
+ 'Backspace',
30
+ 'Delete',
31
+ 'Enter',
32
+ 'Return',
33
+ 'Insert',
34
+ 'Home',
35
+ 'End',
36
+ 'PageUp',
37
+ 'PageDown',
38
+ 'PrintScreen',
39
+ 'ScrollLock',
40
+ 'Pause'
41
+ ];
@@ -0,0 +1,53 @@
1
+ export const formatInput = {
2
+ priceInput: {
3
+ addCommas: (value) => {
4
+ value = value.toString();
5
+ const isFraction = value.includes('.');
6
+
7
+ const valueBeforeDot = isFraction ? value.slice(0, value.indexOf('.')) : value;
8
+
9
+ const intPart = valueBeforeDot
10
+ .split('')
11
+ .reverse()
12
+ .reduce((acc, item, idx) => (idx % 3 === 0 && idx !== 0 ? [...acc, ',', item] : [...acc, item]), [])
13
+ .reverse()
14
+ .join('');
15
+
16
+ return isFraction ? intPart + value.slice(value.indexOf('.')) : intPart;
17
+ },
18
+ removeComma: (value) => {
19
+ return parseInt(value.toString().replace(/\,/g, ''));
20
+ },
21
+ },
22
+ onlyNumbers: (value, isDot = false) => {
23
+ const val = value.slice(0, 1) !== '0' && value.slice(0, 1) !== '.' ? value : value.slice(1);
24
+ if (isDot) return twoDigitAfterDot(val.replace(/[^0-9.]/g, ''));
25
+ else return +val.toString().replace(/\D/g, '');
26
+ },
27
+ onlyString: (value) => {
28
+ return value.toString().replace(/[^a-z]/gi, '');
29
+ },
30
+ };
31
+
32
+ //обрезает числа после точки до 2х
33
+ // 342.23423432 -> 342.23
34
+ const twoDigitAfterDot = (value) => {
35
+ if (value.includes('.')) {
36
+ const valueAfterDot = value.slice(0, value.indexOf('.') + 3);
37
+ let rest = value.slice(value.indexOf('.') + 1, value.indexOf('.') + 3);
38
+
39
+ return allButTheFirstDotCutter(valueAfterDot);
40
+ } else {
41
+ return value;
42
+ }
43
+ };
44
+
45
+ //обрезает все точки кроме первой.
46
+ //для фомата "2 цифры после точки"
47
+ // нельзя = 123...
48
+ // можно 123.99
49
+ function allButTheFirstDotCutter(str) {
50
+ return str.replace(/^([^.]*\.)(.*)$/, function (a, b, c) {
51
+ return b + c.replace(/\./g, '');
52
+ });
53
+ }
@@ -5,7 +5,10 @@ export const handleObjectChange =
5
5
  (data, prop = '', isNumber) => {
6
6
  let value;
7
7
  if (data?.target) {
8
- value = data.target.type === 'checkbox' ? data.target.checked : data.target.value;
8
+ value =
9
+ data.target.type === 'checkbox'
10
+ ? data.target.checked
11
+ : data.target.value;
9
12
  } else value = data;
10
13
 
11
14
  value = isNumber ? +value : value;
@@ -0,0 +1,346 @@
1
+ import React, { useEffect, useMemo, useRef, useState } from 'react';
2
+ import { useClickOutside } from '../../Functions/useClickOutside';
3
+ import InputMask from 'react-input-mask';
4
+ import moment from 'moment';
5
+ import cn from 'classnames';
6
+
7
+ import Langs from '../../../../Langs';
8
+ import Button from '../../Atomic/UI/Button/Button';
9
+ import Calendar from './components/Calendar';
10
+
11
+ const padTime = (time) => {
12
+ return `${time.toString().padStart(2, '0')}:00`;
13
+ };
14
+
15
+ import './Datepicker.scss';
16
+ import Switcher from '../../Atomic/FormElements/Switcher/Switcher';
17
+ import Dropdown from '../../Atomic/FormElements/Dropdown/Dropdown';
18
+ import Input from '../../Atomic/FormElements/Input/Input';
19
+
20
+ const Datepicker = (props) => {
21
+ const { values = {}, onChange, onChangeCompare, onCancel, getSelectedMode = () => {}, onChangeInterval, isCompareHidden, limitRange } = props;
22
+ const { start = null, end = null, compare = false } = values;
23
+ const txt = Langs[global.lng];
24
+ const startDateInputRef = useRef(null);
25
+ const endDateInputRef = useRef(null);
26
+
27
+ const [startDate, setStartDate] = useState(start);
28
+ const [endDate, setEndDate] = useState(end);
29
+ const dateInterval = getSelectedMode({ start: startDate, end: endDate });
30
+
31
+ const [startDateInput, setStartDateInput] = useState(start);
32
+ const [endDateInput, setEndDateInput] = useState(end);
33
+ const [startHour, setStartHour] = useState(start ? moment(start).hour() : 0);
34
+ const [endHour, setEndHour] = useState(end ? moment(end).hour() : 0);
35
+ // eslint-disable-next-line no-unused-vars
36
+ const [isCompare, setIsCompare] = useState(compare);
37
+ const [date1, setDate1] = useState(start ? moment(start).toDate() : moment().subtract(1, 'month').toDate());
38
+ const [date2, setDate2] = useState(end ? moment(end).toDate() : moment().toDate());
39
+ const [isStartFocused, setIsStartFocused] = useState(false);
40
+ const [isEndFocused, setIsEndFocused] = useState(false);
41
+ const [hoverStatus, setHoverStatus] = useState(null);
42
+
43
+ const isNearby = useMemo(() => moment(date2).subtract(1, 'month').isSame(moment(date1), 'month'), [date1, date2]);
44
+
45
+ const isPreviousPeriodShowed = useMemo(() => isCompare && !isCompareHidden && startDate && endDate, [startDate, endDate, isCompare]);
46
+
47
+ const prevEndHour = useRef(endHour);
48
+
49
+ const getStartHourItems = () =>
50
+ [...Array(24).keys()].map((hour) => ({
51
+ label: padTime(hour),
52
+ value: hour,
53
+ disabled: moment(startDate).isSame(endDate, 'day') && endHour <= hour,
54
+ }));
55
+ const getEndHourItems = () =>
56
+ [...Array(24).keys()].map((hour) => ({
57
+ label: padTime(hour + 1),
58
+ value: hour === 23 ? 0 : hour + 1,
59
+ disabled:
60
+ (moment(startDate).isSame(endDate, 'day') || (moment(startDate).isSame(moment(endDate).subtract(1, 'days'), 'day') && endHour === 0)) &&
61
+ hour < startHour,
62
+ }));
63
+
64
+ const startPrevDate = useMemo(() => {
65
+ if (isPreviousPeriodShowed) {
66
+ const intervalHoursCount = moment(endDate).diff(startDate, 'hours');
67
+ return moment(startDate).subtract(intervalHoursCount, 'hours').toDate();
68
+ } else return null;
69
+ }, [startDate, endDate, isCompare]);
70
+
71
+ const endPrevDate = useMemo(() => {
72
+ if (isPreviousPeriodShowed) {
73
+ return startDate;
74
+ } else return null;
75
+ }, [startDate, endDate, isCompare]);
76
+
77
+ const title = useMemo(() => {
78
+ if (isCompare && !isCompareHidden && startDate && endDate) {
79
+ return `${moment(startPrevDate).format('ll')} (${moment(startPrevDate).format('HH:mm')}) - ${moment(endPrevDate).format('ll')} (${moment(
80
+ endPrevDate
81
+ ).format('HH:mm')})`;
82
+ } else return '';
83
+ }, [startDate, endDate, isCompare]);
84
+
85
+ const subtractDay = (date) => (endHour === 0 ? moment(date).subtract(1, 'days') : date);
86
+ const addDay = (date) => (endHour === 0 ? moment(date).add(1, 'days') : date);
87
+
88
+ useEffect(() => {
89
+ if (moment(startDate).isSameOrAfter(endDate)) {
90
+ setStartDate(moment(endDate).subtract(1, 'd').toDate());
91
+ setDate1(moment(endDate).subtract(1, 'd'));
92
+ }
93
+ }, [startDate]);
94
+
95
+ useEffect(() => {
96
+ if (moment(endDate).isSameOrBefore(startDate)) {
97
+ setEndDate(moment(startDate).add(1, 'd').toDate());
98
+ setDate2(moment(startDate).add(1, 'd'));
99
+ }
100
+ }, [endDate]);
101
+
102
+ useEffect(() => {
103
+ setStartDateInput(startDate);
104
+ setEndDateInput(endDate);
105
+ if (moment(startDate).isBefore(moment(endDate), 'month')) {
106
+ setDate1(moment(startDate));
107
+ setDate2(moment(endDate));
108
+ }
109
+ }, [startDate, endDate]);
110
+
111
+ useEffect(() => {
112
+ if (moment(date1).isSameOrAfter(moment(date2), 'month')) {
113
+ setDate1(moment(date2).subtract(1, 'month'));
114
+ }
115
+ }, [date1, date2]);
116
+
117
+ useEffect(() => {
118
+ onChangeInterval(dateInterval);
119
+ }, [dateInterval]);
120
+
121
+ const handleClick = (date) => {
122
+ prevEndHour.current = 0;
123
+ if (!startDate || (startDate && endDate && !(moment(startDate).add(1, 'd').isSame(endDate, 'day') && endHour === 0))) {
124
+ setStartDate(moment(date).startOf('day').toDate());
125
+ setEndDate(moment(date).add(1, 'd').startOf('day').toDate());
126
+ setStartHour(0);
127
+ setEndHour(0);
128
+ } else if (moment(date).isBefore(moment(startDate), 'day')) {
129
+ setEndDate(moment(startDate).add(1, 'd').startOf('day').toDate());
130
+ setStartDate(moment(date).set('hour', parseInt(startHour, 10)).toDate());
131
+ } else if (moment(date).isAfter(moment(startDate), 'day')) {
132
+ setEndDate(moment(date).add(1, 'd').startOf('day').toDate());
133
+ }
134
+ setHoverStatus(null);
135
+ };
136
+
137
+ let timerId;
138
+
139
+ const handleHover = (date) => {
140
+ if (!date) {
141
+ timerId = setTimeout(() => {
142
+ setHoverStatus(null);
143
+ }, 400);
144
+ return;
145
+ }
146
+ if (timerId) clearTimeout(timerId);
147
+ if (moment(startDate).add(1, 'd').isSame(endDate, 'day') && endHour === 0) {
148
+ if (moment(date).isAfter(moment(startDate), 'day')) setHoverStatus('end');
149
+ else if (moment(date).isBefore(moment(startDate), 'day')) setHoverStatus('start');
150
+ else setHoverStatus(null);
151
+ } else {
152
+ setHoverStatus('start');
153
+ }
154
+ };
155
+
156
+ const handleChangeStartHour = ({ target: { value: val } }) => {
157
+ setStartHour(+val);
158
+ setStartDate(
159
+ moment(startDate)
160
+ .set('hour', +val)
161
+ .toDate()
162
+ );
163
+ };
164
+
165
+ const handleChangeEndHour = ({ target: { value: val } }) => {
166
+ const newHour = +val;
167
+ setEndHour(newHour);
168
+ let newEndDate;
169
+ if (prevEndHour.current === 0 && newHour !== 0) {
170
+ newEndDate = moment(endDate).subtract(1, 'days');
171
+ } else if (prevEndHour.current !== 0 && newHour === 0) {
172
+ newEndDate = moment(endDate).add(1, 'days');
173
+ } else {
174
+ newEndDate = endDate;
175
+ }
176
+ prevEndHour.current = newHour;
177
+ setEndDate(moment(newEndDate).set('hour', newHour).toDate());
178
+ };
179
+
180
+ const renderButtons = () => (
181
+ <>
182
+ <Button className="plr15 mr5" onClick={() => onCancel()}>
183
+ {txt.buttons.cancel}
184
+ </Button>
185
+ <Button
186
+ className="plr20"
187
+ type="filled"
188
+ disabled={!startDate || !endDate}
189
+ onClick={() =>
190
+ onChange({
191
+ start: startDate,
192
+ end: endDate,
193
+ startPrevDate,
194
+ endPrevDate,
195
+ compare: isCompare,
196
+ })
197
+ }
198
+ >
199
+ {txt.buttons.apply}
200
+ </Button>
201
+ </>
202
+ );
203
+
204
+ const renderPreviousPeriod = () => (
205
+ <>
206
+ {txt.labels.previousPeriod}: <span className="date-picker__previous-period-interval">{title}</span>
207
+ </>
208
+ );
209
+
210
+ const handleStartDateFocus = () => {
211
+ setIsStartFocused(true);
212
+ setStartDateInput(moment(startDate).format('L'));
213
+ };
214
+
215
+ const handleStartDateBlur = () => {
216
+ let newDate;
217
+ if (moment(startDateInput).isValid()) {
218
+ newDate = moment(startDateInput).set('hour', parseInt(startHour, 10)).toDate();
219
+ setStartDate(newDate);
220
+ } else {
221
+ newDate = startDate;
222
+ setStartDateInput(newDate);
223
+ }
224
+ setIsStartFocused(false);
225
+ startDateInputRef.current.blur();
226
+ setDate1(moment(newDate).isSameOrAfter(moment(date2), 'month') ? moment(date2).subtract(1, 'month') : moment(newDate));
227
+ };
228
+
229
+ const handleEndDateFocus = () => {
230
+ setIsEndFocused(true);
231
+ setEndDateInput(moment(subtractDay(endDateInput)).format('L'));
232
+ };
233
+
234
+ const handleEndDateBlur = () => {
235
+ let newDate;
236
+ if (moment(endDateInput).isValid()) {
237
+ newDate = moment(endDateInput).set('hour', parseInt(endHour, 10)).toDate();
238
+ setEndDate(addDay(newDate));
239
+ } else {
240
+ newDate = endDate;
241
+ setEndDateInput(newDate);
242
+ }
243
+ setIsEndFocused(false);
244
+ endDateInputRef.current.blur();
245
+ setDate2(newDate);
246
+ setEndDateInput();
247
+ };
248
+
249
+ const handleKeyPressed = (e, handleDateBlur) => {
250
+ if (e.key === 'Enter') handleDateBlur();
251
+ };
252
+
253
+ return (
254
+ <div className="date-picker">
255
+ <div className="date-picker__header">
256
+ <Input
257
+ dataTest="datepicker_start-date-input"
258
+ className={cn('mr5', { 'date-picker-text-input--active': hoverStatus === 'start' })}
259
+ value={isStartFocused ? startDateInput : moment(startDate).format('ll')}
260
+ disabled={!startDate}
261
+ onChange={(e) => setStartDateInput(e.target.value)}
262
+ onFocus={handleStartDateFocus}
263
+ onBlur={handleStartDateBlur}
264
+ onKeyPress={(e) => handleKeyPressed(e, handleStartDateBlur)}
265
+ ref={startDateInputRef}
266
+ />
267
+ <Dropdown
268
+ dataTest="datepicker_start-hour-select-input"
269
+ onChange={handleChangeStartHour}
270
+ value={startHour}
271
+ items={getStartHourItems()}
272
+ disabled={!startDate}
273
+ short
274
+ />
275
+ <div className="pl5 pr5 date-picker__header--gray">—</div>
276
+ <Input
277
+ dataTest="datepicker_end-date-input"
278
+ className={cn('mr5', { 'date-picker-text-input--active': hoverStatus === 'end' })}
279
+ value={isEndFocused ? endDateInput : moment(subtractDay(endDate)).format('ll')}
280
+ disabled={!endDate}
281
+ onChange={(e) => setEndDateInput(e.target.value)}
282
+ onFocus={handleEndDateFocus}
283
+ onBlur={handleEndDateBlur}
284
+ onKeyPress={(e) => handleKeyPressed(e, handleEndDateBlur)}
285
+ ref={endDateInputRef}
286
+ />
287
+ <Dropdown
288
+ dataTest="datepicker_end-hour-select-input"
289
+ onChange={handleChangeEndHour}
290
+ value={endHour}
291
+ items={getEndHourItems()}
292
+ disabled={!endDate}
293
+ short
294
+ />
295
+ </div>
296
+ <div className="date-picker__previous-period">{isCompare && !isCompareHidden && startDate && endDate && renderPreviousPeriod()}</div>
297
+ <div className="date-picker__calendars">
298
+ <Calendar
299
+ date={date1}
300
+ setDate={setDate1}
301
+ allowNext={!isNearby}
302
+ startDate={startDate}
303
+ endDate={endDate}
304
+ startPrevDate={startPrevDate}
305
+ endPrevDate={endPrevDate}
306
+ onClick={handleClick}
307
+ onHover={handleHover}
308
+ limitRange={limitRange}
309
+ />
310
+ <Calendar
311
+ date={date2}
312
+ setDate={setDate2}
313
+ allowPrev={!isNearby}
314
+ startDate={startDate}
315
+ endDate={endDate}
316
+ startPrevDate={startPrevDate}
317
+ endPrevDate={endPrevDate}
318
+ onClick={handleClick}
319
+ onHover={handleHover}
320
+ />
321
+ </div>
322
+ <div className="date-picker__footer j46">
323
+ {!isCompareHidden ? (
324
+ <div className="j4">
325
+ <div className="mr5">
326
+ <Switcher
327
+ dataTest="datepicker_compare"
328
+ label={txt.labels.compare}
329
+ isSwitchOn={isCompare}
330
+ onChange={() => {
331
+ onChangeCompare(!isCompare);
332
+ setIsCompare((state) => !state);
333
+ }}
334
+ />
335
+ </div>
336
+ </div>
337
+ ) : (
338
+ <div />
339
+ )}
340
+ <div>{renderButtons()}</div>
341
+ </div>
342
+ </div>
343
+ );
344
+ };
345
+
346
+ export default Datepicker;
@@ -0,0 +1,8 @@
1
+ .test {
2
+ width: 380px;
3
+ }
4
+
5
+ .testing {
6
+ border: none;
7
+ box-shadow: none;
8
+ }
@@ -0,0 +1,27 @@
1
+ import React, { useRef, useState } from 'react';
2
+ import { ref } from 'yup';
3
+ import Datepicker from './Datepicker';
4
+
5
+ global.lng = 'en';
6
+
7
+ // export default {
8
+ // title: 'Form Elements/Datepicker',
9
+ // component: Datepicker,
10
+ // };
11
+
12
+ const Template = (args) => {
13
+ const params = {
14
+ minDate: args?.minDate,
15
+ maxDate: args?.maxDate,
16
+ };
17
+
18
+ return <Datepicker data={args.date} params={params} />;
19
+ };
20
+
21
+ export const DatepickerTemplate = Template.bind({});
22
+
23
+ DatepickerTemplate.args = {
24
+ date: '10/14/2021',
25
+ minDate: '10/11/2021',
26
+ maxDate: '10/25/2021',
27
+ };
@@ -0,0 +1,118 @@
1
+ import cn from 'classnames';
2
+ import moment from 'moment';
3
+ import React, { useEffect, useMemo, useState } from 'react';
4
+ import * as Icon from 'react-feather';
5
+
6
+ const Calendar = (props) => {
7
+ const { date, setDate, startDate, endDate, allowPrev = true, allowNext = true, onClick, onHover, startPrevDate, endPrevDate, limitRange } = props;
8
+
9
+ const [days, setDays] = useState({});
10
+
11
+ const title = useMemo(() => `${moment(date).format('MMM')} ${moment(date).format('YYYY')}`, [date]);
12
+
13
+ useEffect(() => {
14
+ const result = {};
15
+ const day = moment(date).startOf('month');
16
+ const daysInMonth = day.daysInMonth();
17
+ for (let d = 0; d < daysInMonth; d += 1) {
18
+ let week = day.week();
19
+ if (day.month() === 11 && week === 1) week = 53;
20
+ if (day.month() === 0 && week === 53) week = 0;
21
+ if (!Object.prototype.hasOwnProperty.call(result, week)) {
22
+ result[week] = {};
23
+ }
24
+ result[week][day.weekday()] = { date: day.toDate() };
25
+ day.add(1, 'd');
26
+ }
27
+ setDays(result);
28
+ }, [date]);
29
+
30
+ const renderDay = (week, dayOfWeek) => {
31
+ const day = days[week][dayOfWeek];
32
+ const isFutureDay = day && moment(day.date).isAfter(moment(), 'day');
33
+ const isPastDay = limitRange ? day && moment(day.date).isBefore(moment().subtract(limitRange, 'days'), 'day') : null;
34
+ const isRangeEnd = day && (moment(day.date).isSame(startDate, 'day') || moment(day.date).isSame(moment(endDate).subtract(1, 'hour'), 'day'));
35
+ const isRangeInside =
36
+ day &&
37
+ startDate &&
38
+ endDate &&
39
+ moment(day.date).isAfter(startDate, 'day') &&
40
+ moment(day.date).isBefore(moment(endDate).subtract(1, 'hour'), 'day');
41
+ const isPrevRangeEnd =
42
+ day && (moment(day.date).isSame(startPrevDate, 'day') || moment(day.date).isSame(moment(endPrevDate).subtract(1, 'day'), 'day'));
43
+ const isPrevRangeInside =
44
+ day &&
45
+ startPrevDate &&
46
+ endPrevDate &&
47
+ moment(day.date).isAfter(startPrevDate, 'day') &&
48
+ moment(day.date).isBefore(moment(endPrevDate).subtract(1, 'day'), 'day');
49
+ const classNames = cn(
50
+ 'calendar__day',
51
+ { 'calendar__day--clickable': day },
52
+ { 'calendar__day--disabled': isFutureDay },
53
+ { 'calendar__day--disabled': isPastDay },
54
+ { 'calendar__day--range-end': isRangeEnd },
55
+ { 'calendar__day--range-inside': isRangeInside },
56
+ { 'calendar__day--prev-range-end': isPrevRangeEnd },
57
+ { 'calendar__day--prev-range-inside': isPrevRangeInside }
58
+ );
59
+
60
+ return (
61
+ <div
62
+ key={`${week}_${dayOfWeek}`}
63
+ className={classNames}
64
+ onClick={day && !isFutureDay ? () => onClick(day.date) : null}
65
+ onMouseOver={day && !isFutureDay ? () => onHover(day.date) : null}
66
+ onMouseLeave={() => onHover(null)}
67
+ >
68
+ {day && day.date.getDate()}
69
+ </div>
70
+ );
71
+ };
72
+
73
+ const handlePrev = () => {
74
+ setDate(moment(date).subtract(1, 'month').toDate());
75
+ };
76
+
77
+ const handleNext = () => {
78
+ setDate(moment(date).add(1, 'month').toDate());
79
+ };
80
+
81
+ return (
82
+ <div className="calendar">
83
+ <div className="calendar-header">
84
+ <div className="calendar-header__prev">
85
+ {allowPrev && (
86
+ <div onClick={handlePrev}>
87
+ <Icon.ChevronLeft size={16} />
88
+ </div>
89
+ )}
90
+ </div>
91
+ <div className="calendar-header__title">{title}</div>
92
+ <div className="calendar-header__next">
93
+ {allowNext && (
94
+ <div onClick={handleNext}>
95
+ <Icon.ChevronRight size={16} />
96
+ </div>
97
+ )}
98
+ </div>
99
+ </div>
100
+ <div className="calendar__week">
101
+ {[...Array(7).keys()].map((dayOfWeek) => {
102
+ return (
103
+ <div key={`day-of-week_${dayOfWeek}`} className="calendar__day calendar__day--title">
104
+ {moment().weekday(dayOfWeek).format('dd').charAt(0)}
105
+ </div>
106
+ );
107
+ })}
108
+ </div>
109
+ {Object.keys(days).map((week, index) => (
110
+ <div key={`week_${index}`} className="calendar__week">
111
+ {[...Array(7).keys()].map((dayOfWeek) => renderDay(week, dayOfWeek))}
112
+ </div>
113
+ ))}
114
+ </div>
115
+ );
116
+ };
117
+
118
+ export default Calendar;
@@ -1,4 +1,6 @@
1
1
  /* THEME COLORS*/
2
+ @use "sass:math";
3
+
2
4
  $color--secondary: #f06d8d;
3
5
  $color--primary: #6b81dd;
4
6
  $color--dark: #1e1e2d;
@@ -43,4 +45,4 @@ $h4-fs: 22px;
43
45
  $h4-lh: 1.18;
44
46
 
45
47
  $txt: 14px;
46
- $txt--lh: (20 / 14);
48
+ $txt--lh: math.div(20, 14);
@@ -1,5 +1,5 @@
1
1
  @import './fonts';
2
- @import './anme/styles.scss';
2
+ @import '~anme/scss/styles.scss';
3
3
 
4
4
  body {
5
5
  font-family: 'Roboto', sans-serif;