@hipay/hipay-material-ui 2.0.0-beta.55 → 2.0.0-beta.57

Sign up to get free protection for your applications and to get access to all the features.
Files changed (137) hide show
  1. package/CHANGELOG.md +116 -0
  2. package/HiBreadcrumb/HiBreadcrumb.js +14 -4
  3. package/HiBreadcrumb/HiStep.js +4 -1
  4. package/HiBreadcrumb/HiStepContent.js +0 -1
  5. package/HiBreadcrumb/HiStepLabel.js +12 -4
  6. package/HiBreadcrumb/HiStepper.js +1 -1
  7. package/HiButton/HiButton.js +7 -1
  8. package/HiCell/CellIcon.js +4 -4
  9. package/HiCell/CellImage.js +13 -1
  10. package/HiCell/CellRate.js +6 -3
  11. package/HiCell/CellSentinel.js +7 -10
  12. package/HiCell/CellTextStyled.js +29 -1
  13. package/HiColoredLabel/HiColoredLabel.js +1 -1
  14. package/HiDatePicker/Caption.js +16 -10
  15. package/HiDatePicker/HiDatePicker.js +9 -3
  16. package/HiDatePicker/HiDateRangePicker.js +36 -22
  17. package/HiDatePicker/HiDateRangeSelector.js +75 -21
  18. package/HiDatePicker/NavBar.js +8 -1
  19. package/HiDatePicker/Overlays/CustomOverlayLayout.js +26 -17
  20. package/HiDatePicker/Overlays/CustomOverlayLayoutWithoutFooter.js +123 -0
  21. package/HiDatePicker/Overlays/MonthPickerOverlay.js +4 -4
  22. package/HiDatePicker/Overlays/MonthPickerOverlay.spec.js +1 -0
  23. package/HiDatePicker/Overlays/Overlay.js +15 -8
  24. package/HiDatePicker/Overlays/Overlay.spec.js +1 -0
  25. package/HiDatePicker/Overlays/TimePickerOverlay.js +2 -2
  26. package/HiDatePicker/Overlays/TimePickerOverlay.spec.js +1 -0
  27. package/HiDatePicker/Overlays/YearPickerOverlay.js +4 -6
  28. package/HiDatePicker/Overlays/YearPickerOverlay.spec.js +1 -0
  29. package/HiDatePicker/hiLocaleUtils.js +144 -0
  30. package/HiDatePicker/stylesheet.js +33 -7
  31. package/HiDotsStepper/HiDot.js +108 -0
  32. package/HiDotsStepper/HiDotsStepper.js +121 -0
  33. package/HiExpansionPanel/HiExpansionPanel.js +1 -1
  34. package/HiForm/HiAddressField.js +176 -0
  35. package/HiForm/HiFormControl.js +2 -0
  36. package/HiForm/HiInput.js +3 -3
  37. package/HiForm/HiSlider.js +352 -0
  38. package/HiForm/HiUpload.js +204 -0
  39. package/HiForm/HiUploadField.js +182 -0
  40. package/HiForm/HiUploadInput.js +459 -0
  41. package/HiForm/index.js +16 -0
  42. package/HiMap/HiMap.js +345 -0
  43. package/HiMap/HiMapExpand.js +210 -0
  44. package/HiMap/index.js +23 -0
  45. package/HiNotice/HiKPI.js +238 -0
  46. package/HiNotice/HiKPINotice.js +96 -0
  47. package/HiNotice/index.js +23 -0
  48. package/HiPdfReader/HiPdfReader.js +269 -0
  49. package/HiPdfReader/index.js +15 -0
  50. package/HiPin/HiPin.js +1 -1
  51. package/HiRadio/HiRadio.js +74 -0
  52. package/HiRadio/index.js +15 -0
  53. package/HiSelect/HiSelect.js +73 -84
  54. package/HiSelect/HiSuggestSelect.js +35 -4
  55. package/HiSelect/SelectInput.js +9 -1
  56. package/HiSelectNew/HiNestedSelectContent.js +5 -1
  57. package/HiSelectNew/HiSelect.js +260 -179
  58. package/HiSelectNew/HiSelectContent.js +0 -8
  59. package/HiSelectNew/HiSelectInput.js +8 -9
  60. package/HiSelectableList/HiSelectableList.js +39 -4
  61. package/HiSelectableList/HiSelectableListItem.js +81 -38
  62. package/HiTable/HiCellBuilder.js +25 -12
  63. package/HiTable/HiTableHeader.js +16 -17
  64. package/HiTable/constants.js +3 -1
  65. package/README.md +248 -98
  66. package/es/HiBreadcrumb/HiBreadcrumb.js +14 -4
  67. package/es/HiBreadcrumb/HiStep.js +4 -1
  68. package/es/HiBreadcrumb/HiStepContent.js +0 -1
  69. package/es/HiBreadcrumb/HiStepLabel.js +13 -4
  70. package/es/HiBreadcrumb/HiStepper.js +1 -1
  71. package/es/HiButton/HiButton.js +7 -0
  72. package/es/HiCell/CellIcon.js +5 -5
  73. package/es/HiCell/CellImage.js +13 -1
  74. package/es/HiCell/CellRate.js +6 -3
  75. package/es/HiCell/CellSentinel.js +7 -10
  76. package/es/HiCell/CellTextStyled.js +28 -1
  77. package/es/HiColoredLabel/HiColoredLabel.js +1 -1
  78. package/es/HiDatePicker/Caption.js +14 -10
  79. package/es/HiDatePicker/HiDatePicker.js +8 -3
  80. package/es/HiDatePicker/HiDateRangePicker.js +40 -28
  81. package/es/HiDatePicker/HiDateRangeSelector.js +69 -21
  82. package/es/HiDatePicker/ListPicker.js +1 -1
  83. package/es/HiDatePicker/NavBar.js +7 -1
  84. package/es/HiDatePicker/Overlays/CustomOverlayLayout.js +30 -19
  85. package/es/HiDatePicker/Overlays/CustomOverlayLayoutWithoutFooter.js +106 -0
  86. package/es/HiDatePicker/Overlays/MonthPickerOverlay.js +5 -5
  87. package/es/HiDatePicker/Overlays/MonthPickerOverlay.spec.js +1 -0
  88. package/es/HiDatePicker/Overlays/Overlay.js +16 -9
  89. package/es/HiDatePicker/Overlays/Overlay.spec.js +1 -0
  90. package/es/HiDatePicker/Overlays/TimePickerOverlay.js +2 -2
  91. package/es/HiDatePicker/Overlays/TimePickerOverlay.spec.js +1 -0
  92. package/es/HiDatePicker/Overlays/YearPickerOverlay.js +4 -6
  93. package/es/HiDatePicker/Overlays/YearPickerOverlay.spec.js +1 -0
  94. package/es/HiDatePicker/hiLocaleUtils.js +131 -0
  95. package/es/HiDatePicker/stylesheet.js +32 -7
  96. package/es/HiDotsStepper/HiDot.js +66 -0
  97. package/es/HiDotsStepper/HiDotsStepper.js +73 -0
  98. package/es/HiExpansionPanel/HiExpansionPanel.js +1 -1
  99. package/es/HiForm/HiAddressField.js +134 -0
  100. package/es/HiForm/HiFormControl.js +2 -0
  101. package/es/HiForm/HiInput.js +3 -3
  102. package/es/HiForm/HiSlider.js +302 -0
  103. package/es/HiForm/HiUpload.js +158 -0
  104. package/es/HiForm/HiUploadField.js +140 -0
  105. package/es/HiForm/HiUploadInput.js +411 -0
  106. package/es/HiForm/index.js +2 -0
  107. package/es/HiMap/HiMap.js +290 -0
  108. package/es/HiMap/HiMapExpand.js +162 -0
  109. package/es/HiMap/index.js +2 -0
  110. package/es/HiNotice/HiKPI.js +196 -0
  111. package/es/HiNotice/HiKPINotice.js +78 -0
  112. package/es/HiNotice/index.js +2 -0
  113. package/es/HiPdfReader/HiPdfReader.js +214 -0
  114. package/es/HiPdfReader/index.js +1 -0
  115. package/es/HiPin/HiPin.js +1 -1
  116. package/es/HiRadio/HiRadio.js +55 -0
  117. package/es/HiRadio/index.js +1 -0
  118. package/es/HiSelect/HiSelect.js +68 -78
  119. package/es/HiSelect/HiSuggestSelect.js +30 -4
  120. package/es/HiSelect/SelectInput.js +9 -1
  121. package/es/HiSelectNew/HiNestedSelectContent.js +5 -1
  122. package/es/HiSelectNew/HiSelect.js +246 -162
  123. package/es/HiSelectNew/HiSelectContent.js +0 -7
  124. package/es/HiSelectNew/HiSelectInput.js +8 -9
  125. package/es/HiSelectableList/HiSelectableList.js +34 -6
  126. package/es/HiSelectableList/HiSelectableListItem.js +92 -40
  127. package/es/HiTable/HiCellBuilder.js +130 -123
  128. package/es/HiTable/HiTableHeader.js +14 -12
  129. package/es/HiTable/constants.js +1 -0
  130. package/es/index.js +9 -1
  131. package/es/utils/helpers.js +1 -1
  132. package/index.es.js +9 -1
  133. package/index.js +66 -2
  134. package/package.json +5 -2
  135. package/umd/hipay-material-ui.development.js +44450 -40930
  136. package/umd/hipay-material-ui.production.min.js +2 -2
  137. package/utils/helpers.js +1 -1
@@ -29,6 +29,8 @@ var _propTypes = _interopRequireDefault(require("prop-types"));
29
29
 
30
30
  var _moment = _interopRequireDefault(require("react-day-picker/moment"));
31
31
 
32
+ var _hiLocaleUtils = _interopRequireDefault(require("./hiLocaleUtils"));
33
+
32
34
  var _DayPickerInput = _interopRequireDefault(require("react-day-picker/DayPickerInput"));
33
35
 
34
36
  var _classnames = _interopRequireDefault(require("classnames"));
@@ -66,7 +68,7 @@ function (_React$Component) {
66
68
  var _this;
67
69
 
68
70
  (0, _classCallCheck2.default)(this, HiDateRangePicker);
69
- _this = (0, _possibleConstructorReturn2.default)(this, (0, _getPrototypeOf2.default)(HiDateRangePicker).call(this));
71
+ _this = (0, _possibleConstructorReturn2.default)(this, (0, _getPrototypeOf2.default)(HiDateRangePicker).call(this, props));
70
72
 
71
73
  _this.handleDayChange = function (name, day) {
72
74
  if (day) {
@@ -105,13 +107,11 @@ function (_React$Component) {
105
107
  _this.onDayToClick = function (day) {
106
108
  var change = (0, _moment2.default)(day) >= (0, _moment2.default)(_this.props.from);
107
109
 
108
- if (change && _this.props.disableFutureDays && (0, _moment2.default)(day) > (0, _moment2.default)()) {
110
+ if (change && _this.props.disableFutureDays && (0, _moment2.default)(day).utc() > (0, _moment2.default)().utc().endOf('day')) {
109
111
  change = false;
110
112
  }
111
113
 
112
114
  if (change) {
113
- console.log((0, _extends2.default)({}, _this.props));
114
-
115
115
  _this.handleDayChange('to', day);
116
116
 
117
117
  document.activeElement.blur();
@@ -138,8 +138,8 @@ function (_React$Component) {
138
138
 
139
139
  _this.handleChange = function (name, day) {
140
140
  var translations = _this.props.translations;
141
- var date = undefined;
142
- var error = undefined;
141
+ var date;
142
+ var error;
143
143
  var now = new Date();
144
144
  var _this$props = _this.props,
145
145
  minimumDate = _this$props.minimumDate,
@@ -163,10 +163,10 @@ function (_React$Component) {
163
163
 
164
164
  if (name === 'to' && comparativeDate > (0, _moment2.default)(date) || name === 'from' && comparativeDate < (0, _moment2.default)(date)) {
165
165
  error = translations.to_superior_from;
166
- } else if (date < minimumDate) {
167
- error = translations.date_inferior_min_date.replace("%s", (0, _moment2.default)(minimumDate).format(format));
168
- } else if (disableFutureDays && date > now) {
169
- error = translations.date_superior_max_date.replace("%s", (0, _moment2.default)().format(format));
166
+ } else if ((0, _moment2.default)(date).utc() < (0, _moment2.default)(minimumDate).utc().startOf('day')) {
167
+ error = translations.date_inferior_min_date.replace('%s', (0, _moment2.default)(minimumDate).format(format));
168
+ } else if (disableFutureDays && (0, _moment2.default)(date).utc() > (0, _moment2.default)(now).utc().endOf('day')) {
169
+ error = translations.date_superior_max_date.replace('%s', (0, _moment2.default)().format(format));
170
170
  }
171
171
 
172
172
  if (!_this.props.enableTime) {
@@ -217,9 +217,11 @@ function (_React$Component) {
217
217
  _this.handleReset = function (name) {
218
218
  _this.handleChange(name, undefined);
219
219
 
220
- _this.setState({
221
- keyFrom: _this.state.keyFrom === 1 ? 2 : 1,
222
- keyTo: _this.state.keyTo === 1 ? 2 : 1
220
+ _this.setState(function (prevState) {
221
+ return {
222
+ keyFrom: prevState.keyFrom === 1 ? 2 : 1,
223
+ keyTo: prevState.keyTo === 1 ? 2 : 1
224
+ };
223
225
  });
224
226
  };
225
227
 
@@ -255,7 +257,7 @@ function (_React$Component) {
255
257
  staticPosition: staticPosition
256
258
  });
257
259
 
258
- switch (_this.state['openedPanel']) {
260
+ switch (_this.state.openedPanel) {
259
261
  case 'time':
260
262
  return _this.renderTimePickerOverlay(name, rangeOverlayProps);
261
263
 
@@ -266,6 +268,7 @@ function (_React$Component) {
266
268
  return _this.renderYearPickerOverlay(name, rangeOverlayProps);
267
269
 
268
270
  case 'calendar':
271
+ default:
269
272
  return _react.default.createElement(_Overlay.default, rangeOverlayProps);
270
273
  }
271
274
  };
@@ -280,7 +283,7 @@ function (_React$Component) {
280
283
 
281
284
  _this.renderMonthPickerOverlay = function (name, propsOverlay) {
282
285
  var monthPickerProps = {
283
- value: _this.state['currentMonth'],
286
+ value: _this.state.currentMonth,
284
287
  onChange: _this.handleCurrentMonthChange
285
288
  };
286
289
  return _react.default.createElement(_MonthPickerOverlay.default, (0, _extends2.default)({
@@ -305,7 +308,7 @@ function (_React$Component) {
305
308
 
306
309
  _this.renderYearPickerOverlay = function (name, propsOverlay) {
307
310
  var yearPickerProps = {
308
- value: _this.state['currentMonth'],
311
+ value: _this.state.currentMonth,
309
312
  onChange: _this.handleCurrentMonthChange,
310
313
  disabledFutureDays: _this.props.disableFutureDays
311
314
  };
@@ -408,13 +411,15 @@ function (_React$Component) {
408
411
  onTodayButtonClick: this.handleCurrentMonthChange,
409
412
  navbarElement: this.renderNavBar,
410
413
  captionElement: this.renderCaption,
411
- disabledDays: (0, _extends2.default)({
414
+ disabledDays: (0, _extends2.default)({}, dayPickerProps.disabledDays, {
412
415
  before: minimumDate
413
416
  }, disableFutureDays && {
414
417
  after: now
415
418
  }, to && {
416
419
  after: to
417
420
  }),
421
+ locale: locale,
422
+ localeUtils: _hiLocaleUtils.default,
418
423
  month: this.state.currentMonth,
419
424
  modifiers: (0, _extends2.default)({}, modifiers)
420
425
  });
@@ -423,13 +428,15 @@ function (_React$Component) {
423
428
  navbarElement: this.renderNavBar,
424
429
  onDayClick: this.onDayToClick,
425
430
  captionElement: this.renderCaption,
426
- disabledDays: (0, _extends2.default)({
431
+ disabledDays: (0, _extends2.default)({}, dayPickerProps.disabledDays, {
427
432
  before: minimumDate
428
433
  }, disableFutureDays && {
429
434
  after: now
430
435
  }, from && {
431
436
  before: from
432
437
  }),
438
+ locale: locale,
439
+ localeUtils: _hiLocaleUtils.default,
433
440
  month: this.state.currentMonth,
434
441
  modifiers: (0, _extends2.default)({}, modifiers)
435
442
  }); // From & To InputProps
@@ -509,7 +516,7 @@ function (_React$Component) {
509
516
  inputProps: toInputProps,
510
517
  format: enableTime ? "".concat(format, " HH:mm") : format,
511
518
  formatDate: _moment.default.formatDate,
512
- parseDate: _moment.default.parseDate //onDayChange={(day) => this.handleDayChange('to', day)}
519
+ parseDate: _moment.default.parseDate // onDayChange={(day) => this.handleDayChange('to', day)}
513
520
  ,
514
521
  placeholder: ''
515
522
  })));
@@ -532,7 +539,7 @@ function (_React$Component) {
532
539
  }(_react.default.Component);
533
540
 
534
541
  HiDateRangePicker.defaultProps = {
535
- disabledDays: [],
542
+ disabledDays: {},
536
543
  disableFutureDays: true,
537
544
  staticPosition: false,
538
545
  enableTime: false,
@@ -541,6 +548,8 @@ HiDateRangePicker.defaultProps = {
541
548
  labelFrom: 'Start',
542
549
  labelTo: 'End',
543
550
  locale: 'fr-FR',
551
+ minimumDate: new Date(2013, 4, 1),
552
+ // by default 1 May 2013
544
553
  translations: {
545
554
  today: 'today',
546
555
  hour: 'Hour',
@@ -566,6 +575,11 @@ HiDateRangePicker.propTypes = process.env.NODE_ENV !== "production" ? {
566
575
  */
567
576
  disabled: _propTypes.default.bool,
568
577
 
578
+ /**
579
+ * http://react-day-picker.js.org/api/DayPicker#disabledDays
580
+ */
581
+ disabledDays: _propTypes.default.object,
582
+
569
583
  /**
570
584
  * Uniquement la sélection de date antérieures à aujourd'hui (inclu)
571
585
  */
@@ -590,7 +604,7 @@ HiDateRangePicker.propTypes = process.env.NODE_ENV !== "production" ? {
590
604
  * Date de début sélectionnée
591
605
  */
592
606
  from: _propTypes.default.instanceOf(Date),
593
- //from: PropTypes.oneOfType([PropTypes.instanceOf(Date), PropTypes.string]),
607
+ // from: PropTypes.oneOfType([PropTypes.instanceOf(Date), PropTypes.string]),
594
608
 
595
609
  /**
596
610
  * Erreur sur date from
@@ -636,7 +650,7 @@ HiDateRangePicker.propTypes = process.env.NODE_ENV !== "production" ? {
636
650
  /**
637
651
  * Date minimale sélectionnable
638
652
  */
639
- minimumDate: _propTypes.default.instanceOf(Date).isRequired,
653
+ minimumDate: _propTypes.default.instanceOf(Date),
640
654
 
641
655
  /**
642
656
  * Callback à la sélection d'une date
@@ -5,6 +5,9 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
5
5
  Object.defineProperty(exports, "__esModule", {
6
6
  value: true
7
7
  });
8
+ exports.findSeparator = findSeparator;
9
+ exports.yearAndMonth = yearAndMonth;
10
+ exports.yearAndQuarter = yearAndQuarter;
8
11
  exports.buildDateRangeOptionByKey = buildDateRangeOptionByKey;
9
12
  exports.default = exports.styles = void 0;
10
13
 
@@ -44,6 +47,52 @@ var _HiDateRangePicker = _interopRequireDefault(require("./HiDateRangePicker"));
44
47
 
45
48
  var _HiFormControl = _interopRequireDefault(require("../HiForm/HiFormControl"));
46
49
 
50
+ function findSeparator(format) {
51
+ var str = '';
52
+
53
+ if (format.search('[/]') >= 0) {
54
+ str = '/';
55
+ } else if (format.search('[-]') >= 0) {
56
+ str = '-';
57
+ } else if (format.search('[.]') >= 0) {
58
+ str = '.';
59
+ }
60
+
61
+ return str;
62
+ }
63
+
64
+ function yearAndMonth(format, date) {
65
+ var findY = function findY(el) {
66
+ return el.toUpperCase().search('Y') >= 0;
67
+ };
68
+
69
+ var findM = function findM(el) {
70
+ return el.toUpperCase().search('M') >= 0;
71
+ };
72
+
73
+ var s = findSeparator(format);
74
+ var split = format.split(s);
75
+ var indexY = split.findIndex(findY);
76
+ var indexM = split.findIndex(findM);
77
+ return indexY < indexM ? date.format(split[indexY] + s + split[indexM]) : date.format(split[indexM] + s + split[indexY]);
78
+ }
79
+
80
+ function yearAndQuarter(format, date, t) {
81
+ var findY = function findY(el) {
82
+ return el.toUpperCase().search('Y') >= 0;
83
+ };
84
+
85
+ var findM = function findM(el) {
86
+ return el.toUpperCase().search('M') >= 0;
87
+ };
88
+
89
+ var s = findSeparator(format);
90
+ var split = format.split(s);
91
+ var indexY = split.findIndex(findY);
92
+ var indexM = split.findIndex(findM);
93
+ return indexY < indexM ? date.format("".concat(split[indexY]).concat(s, "[").concat(t.short_quarter, "]Q")) : date.format("[".concat(t.short_quarter, "]Q").concat(s).concat(split[indexY]));
94
+ }
95
+
47
96
  function buildDateRangeOptionByKey(key, t, format) {
48
97
  var from;
49
98
  var label;
@@ -104,21 +153,21 @@ function buildDateRangeOptionByKey(key, t, format) {
104
153
  label = t.previous_month;
105
154
  from = (0, _moment.default)().subtract(1, 'month').startOf('month');
106
155
  to = (0, _moment.default)().subtract(1, 'month').endOf('month');
107
- info = "".concat(from.format(t.yearAndMonth), ", ").concat(from.daysInMonth(), " ").concat(t.days);
156
+ info = "".concat(yearAndMonth(format, from), ", ").concat(from.daysInMonth(), " ").concat(t.days);
108
157
  break;
109
158
 
110
159
  case 'cq':
111
160
  label = t.current_quarter;
112
161
  from = (0, _moment.default)().startOf('quarter');
113
162
  to = (0, _moment.default)();
114
- info = "".concat(from.format(t.yearAndQuarter), ", ").concat(from.format(format), " ").concat(t.to_now, ", ").concat(to.diff(from, 'days') + 1, " ").concat(t.days);
163
+ info = "".concat(yearAndQuarter(format, from, t), ", ").concat(from.format(format), " ").concat(t.to_now, ", ").concat(to.diff(from, 'days') + 1, " ").concat(t.days);
115
164
  break;
116
165
 
117
166
  case 'pq':
118
167
  label = t.previous_quarter;
119
168
  from = (0, _moment.default)().subtract(1, 'quarter').startOf('quarter');
120
169
  to = (0, _moment.default)().subtract(1, 'quarter').endOf('quarter');
121
- info = "".concat(from.format(t.yearAndQuarter), ", ").concat(to.diff(from, 'days') + 1, " ").concat(t.days);
170
+ info = "".concat(yearAndQuarter(format, from, t), ", ").concat(to.diff(from, 'days') + 1, " ").concat(t.days);
122
171
  break;
123
172
 
124
173
  case 'cy':
@@ -142,7 +191,7 @@ function buildDateRangeOptionByKey(key, t, format) {
142
191
  };
143
192
  }
144
193
 
145
- var styles = function styles(theme) {
194
+ var styles = function styles() {
146
195
  return {
147
196
  root: {
148
197
  maxWidth: 500,
@@ -154,7 +203,8 @@ var styles = function styles(theme) {
154
203
  marginTop: 1
155
204
  },
156
205
  dateRangePicker: {
157
- width: 'calc(100% + 8px)'
206
+ width: 'calc(100% + 8px)',
207
+ marginTop: 0
158
208
  },
159
209
  smSelect: {},
160
210
  smRangePicker: {}
@@ -175,17 +225,25 @@ function (_React$Component) {
175
225
  _this = (0, _possibleConstructorReturn2.default)(this, (0, _getPrototypeOf2.default)(HiDateRangeSelector).call(this));
176
226
  _this.options = [];
177
227
 
178
- _this.onBlur = function (event) {
228
+ _this.handleBlur = function (event) {
179
229
  if (event instanceof Object && _this.props.onblur) {
180
230
  _this.props.onBlur(event);
181
231
  }
182
232
  };
183
233
 
234
+ _this.handleReset = function (name) {
235
+ _this.props.onChange(name, undefined);
236
+
237
+ _this.props.onChange("".concat(name, "Error"), undefined);
238
+ };
239
+
184
240
  _this.handleSelectChange = function (name) {
185
241
  return function (event, value) {
186
- var _this$setState;
242
+ _this.setState(function (prevState) {
243
+ var _ref;
187
244
 
188
- _this.setState((_this$setState = {}, (0, _defineProperty2.default)(_this$setState, name, value), (0, _defineProperty2.default)(_this$setState, "key", _this.state.key === 1 ? 2 : 1), _this$setState));
245
+ return _ref = {}, (0, _defineProperty2.default)(_ref, name, value), (0, _defineProperty2.default)(_ref, "key", prevState.key === 1 ? 2 : 1), _ref;
246
+ });
189
247
 
190
248
  var selectedOption = _this.options.find(function (option) {
191
249
  return option.id === value;
@@ -207,7 +265,6 @@ function (_React$Component) {
207
265
  };
208
266
  };
209
267
 
210
- _this.handleReset = _this.handleReset.bind((0, _assertThisInitialized2.default)((0, _assertThisInitialized2.default)(_this)));
211
268
  _this.handleSelectChange = _this.handleSelectChange.bind((0, _assertThisInitialized2.default)((0, _assertThisInitialized2.default)(_this)));
212
269
  _this.options = props.availableOptionKeys.map(function (key) {
213
270
  return buildDateRangeOptionByKey(key, props.translations, props.format);
@@ -233,12 +290,6 @@ function (_React$Component) {
233
290
  value: function componentWillUnmount() {
234
291
  clearTimeout(this.timeout); // TODO : supprimer ?
235
292
  }
236
- }, {
237
- key: "handleReset",
238
- value: function handleReset(name) {
239
- this.props.onChange(name, undefined);
240
- this.props.onChange("".concat(name, "Error"), undefined);
241
- }
242
293
  }, {
243
294
  key: "render",
244
295
  value: function render() {
@@ -281,7 +332,7 @@ function (_React$Component) {
281
332
  spacing: 8,
282
333
  className: classes.root,
283
334
  ref: function ref(container) {
284
- return _this2.container = container;
335
+ _this2.container = container;
285
336
  }
286
337
  }, _react.default.createElement(_Grid.default, {
287
338
  item: true,
@@ -332,14 +383,14 @@ function (_React$Component) {
332
383
  disabled: disabled || selectedPreset !== 'custom',
333
384
  translations: translations,
334
385
  staticPosition: staticPosition,
335
- onBlur: this.onBlur,
386
+ onBlur: this.handleBlur,
336
387
  hasSelector: true
337
388
  }, props)))));
338
389
  }
339
390
  }], [{
340
391
  key: "getDerivedStateFromProps",
341
- value: function getDerivedStateFromProps(props, state) {
342
- if (props.defaultPreset && props.returnSelectValue) {
392
+ value: function getDerivedStateFromProps(props) {
393
+ if (props.returnSelectValue) {
343
394
  return {
344
395
  selectedPreset: props.defaultPreset
345
396
  };
@@ -358,6 +409,8 @@ HiDateRangeSelector.defaultProps = {
358
409
  staticPosition: false,
359
410
  locale: 'fr-FR',
360
411
  format: 'YYYY-DD-MM',
412
+ minimumDate: new Date(2013, 4, 1),
413
+ // by default 1 May 2013
361
414
  translations: {
362
415
  today: 'Today',
363
416
  hour: 'Hour',
@@ -366,6 +419,7 @@ HiDateRangeSelector.defaultProps = {
366
419
  quarter: 'Quarter',
367
420
  week: 'Week',
368
421
  short_week: 'W',
422
+ short_quarter: 'Q',
369
423
  yearAndMonth: 'YYYY[-]MM',
370
424
  yearAndQuarter: 'YYYY[-Q]Q',
371
425
  year: 'Year',
@@ -468,7 +522,7 @@ HiDateRangeSelector.propTypes = process.env.NODE_ENV !== "production" ? {
468
522
  /**
469
523
  * Date minimale sélectionnable
470
524
  */
471
- minimumDate: _propTypes.default.instanceOf(Date).isRequired,
525
+ minimumDate: _propTypes.default.instanceOf(Date),
472
526
 
473
527
  /**
474
528
  * Callback à la sélection d'une date
@@ -483,7 +537,7 @@ HiDateRangeSelector.propTypes = process.env.NODE_ENV !== "production" ? {
483
537
  /**
484
538
  * Retourne la valeur du select de la période au change du select
485
539
  */
486
- returnSelectValue: _propTypes.default.bool.isRequired,
540
+ returnSelectValue: _propTypes.default.bool,
487
541
 
488
542
  /**
489
543
  * Props passées au HiSelectField
@@ -62,6 +62,8 @@ var _ref4 = _react.default.createElement(_AccessTime.default, null);
62
62
 
63
63
  var NavBar = function NavBar(_ref) {
64
64
  var classes = _ref.classes,
65
+ _ref$locale = _ref.locale,
66
+ locale = _ref$locale === void 0 ? 'en_US' : _ref$locale,
65
67
  localeUtils = _ref.localeUtils,
66
68
  nextMonth = _ref.nextMonth,
67
69
  onClockClick = _ref.onClockClick,
@@ -69,7 +71,7 @@ var NavBar = function NavBar(_ref) {
69
71
  onNextClick = _ref.onNextClick,
70
72
  previousMonth = _ref.previousMonth,
71
73
  showClockButton = _ref.showClockButton;
72
- var months = localeUtils.getMonths();
74
+ var months = localeUtils.getMonths(locale);
73
75
  var prev = "".concat(months[previousMonth.getMonth()], " ").concat(previousMonth.getFullYear());
74
76
  var next = "".concat(months[nextMonth.getMonth()], " ").concat(nextMonth.getFullYear());
75
77
  return _react.default.createElement("div", {
@@ -100,6 +102,11 @@ NavBar.propTypes = process.env.NODE_ENV !== "production" ? {
100
102
  */
101
103
  classes: _propTypes.default.object,
102
104
 
105
+ /**
106
+ * ReactDayPicker prop
107
+ */
108
+ locale: _propTypes.default.string,
109
+
103
110
  /**
104
111
  * ReactDayPicker prop
105
112
  */
@@ -26,10 +26,15 @@ var _withStyles = _interopRequireDefault(require("../../styles/withStyles"));
26
26
  var styles = function styles(theme) {
27
27
  return {
28
28
  paper: {
29
- position: 'absolute',
30
29
  width: '100%',
31
30
  zIndex: 10
32
31
  },
32
+ absolute: {
33
+ position: 'absolute'
34
+ },
35
+ relative: {
36
+ position: 'relative'
37
+ },
33
38
  left: {
34
39
  width: '200%',
35
40
  left: 0
@@ -80,22 +85,25 @@ var CustomOverlayLayout = function CustomOverlayLayout(_ref) {
80
85
  footerElement = _ref.footerElement,
81
86
  absoluteElement = _ref.absoluteElement,
82
87
  side = _ref.side,
83
- props = (0, _objectWithoutProperties2.default)(_ref, ["classes", "children", "headerElement", "footerElement", "absoluteElement", "side"]);
84
- var paperClass = (0, _classnames.default)(classes.paper, (_classNames = {}, (0, _defineProperty2.default)(_classNames, classes.left, side === 'from'), (0, _defineProperty2.default)(_classNames, classes.right, side === 'to'), _classNames));
88
+ staticPosition = _ref.staticPosition,
89
+ props = (0, _objectWithoutProperties2.default)(_ref, ["classes", "children", "headerElement", "footerElement", "absoluteElement", "side", "staticPosition"]);
90
+ var paperClass = (0, _classnames.default)(classes.paper, (_classNames = {}, (0, _defineProperty2.default)(_classNames, classes.left, side === 'from'), (0, _defineProperty2.default)(_classNames, classes.right, side === 'to'), (0, _defineProperty2.default)(_classNames, classes.absolute, staticPosition !== true), (0, _defineProperty2.default)(_classNames, classes.relative, staticPosition === true), _classNames));
85
91
  var paperProps = (0, _extends2.default)({}, props);
86
- return _react.default.createElement(_Paper.default, {
87
- className: paperClass,
88
- onBlur: paperProps.onBlur,
89
- onFocus: paperProps.onFocus
90
- }, _react.default.createElement("div", {
91
- className: classes.overlay
92
- }, _react.default.createElement("div", {
93
- className: classes.header
94
- }, headerElement), _react.default.createElement("div", {
95
- className: classes.body
96
- }, children), _react.default.createElement("div", {
97
- className: classes.footer
98
- }, footerElement), absoluteElement));
92
+ return (// eslint-disable-next-line react/jsx-handler-names
93
+ _react.default.createElement(_Paper.default, {
94
+ className: paperClass,
95
+ onBlur: paperProps.onBlur,
96
+ onFocus: paperProps.onFocus
97
+ }, _react.default.createElement("div", {
98
+ className: classes.overlay
99
+ }, _react.default.createElement("div", {
100
+ className: classes.header
101
+ }, headerElement), _react.default.createElement("div", {
102
+ className: classes.body
103
+ }, children), _react.default.createElement("div", {
104
+ className: classes.footer
105
+ }, footerElement), absoluteElement))
106
+ );
99
107
  };
100
108
 
101
109
  CustomOverlayLayout.propTypes = process.env.NODE_ENV !== "production" ? {
@@ -112,7 +120,8 @@ CustomOverlayLayout.propTypes = process.env.NODE_ENV !== "production" ? {
112
120
  /**
113
121
  * Définit comment construire le Paper dans le cas d'un double input
114
122
  */
115
- side: _propTypes.default.string
123
+ side: _propTypes.default.string,
124
+ staticPosition: _propTypes.default.bool
116
125
  } : {};
117
126
 
118
127
  var _default = (0, _withStyles.default)(styles, {
@@ -0,0 +1,123 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports.default = exports.styles = void 0;
9
+
10
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
11
+
12
+ var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
13
+
14
+ var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
15
+
16
+ var _react = _interopRequireDefault(require("react"));
17
+
18
+ var _propTypes = _interopRequireDefault(require("prop-types"));
19
+
20
+ var _classnames = _interopRequireDefault(require("classnames"));
21
+
22
+ var _Paper = _interopRequireDefault(require("@material-ui/core/Paper"));
23
+
24
+ var _withStyles = _interopRequireDefault(require("../../styles/withStyles"));
25
+
26
+ var styles = function styles(theme) {
27
+ return {
28
+ paper: {
29
+ width: '100%',
30
+ zIndex: 10
31
+ },
32
+ absolute: {
33
+ position: 'absolute'
34
+ },
35
+ relative: {
36
+ position: 'relative'
37
+ },
38
+ left: {
39
+ width: '200%',
40
+ left: 0
41
+ },
42
+ right: {
43
+ width: '200%',
44
+ left: '-100%'
45
+ },
46
+ overlay: (0, _extends2.default)({
47
+ padding: 0,
48
+ height: 325,
49
+ textAlign: 'center'
50
+ }, theme.typography.body2, {
51
+ fontWeight: theme.typography.fontWeightRegular
52
+ }),
53
+ header: (0, _extends2.default)({
54
+ display: 'block',
55
+ height: 40,
56
+ textAlign: 'center',
57
+ padding: '10px 0'
58
+ }, theme.typography.body1, {
59
+ color: theme.palette.neutral.main,
60
+ borderBottom: '1px solid',
61
+ borderBottomColor: theme.palette.divider
62
+ }),
63
+ body: {
64
+ height: 285,
65
+ width: 224,
66
+ margin: 'auto'
67
+ }
68
+ };
69
+ };
70
+
71
+ exports.styles = styles;
72
+
73
+ var CustomOverlayLayoutWithoutFooter = function CustomOverlayLayoutWithoutFooter(_ref) {
74
+ var _classNames;
75
+
76
+ var classes = _ref.classes,
77
+ children = _ref.children,
78
+ headerElement = _ref.headerElement,
79
+ footerElement = _ref.footerElement,
80
+ absoluteElement = _ref.absoluteElement,
81
+ side = _ref.side,
82
+ staticPosition = _ref.staticPosition,
83
+ props = (0, _objectWithoutProperties2.default)(_ref, ["classes", "children", "headerElement", "footerElement", "absoluteElement", "side", "staticPosition"]);
84
+ var paperClass = (0, _classnames.default)(classes.paper, (_classNames = {}, (0, _defineProperty2.default)(_classNames, classes.left, side === 'from'), (0, _defineProperty2.default)(_classNames, classes.right, side === 'to'), (0, _defineProperty2.default)(_classNames, classes.absolute, staticPosition !== true), (0, _defineProperty2.default)(_classNames, classes.relative, staticPosition === true), _classNames));
85
+ var paperProps = (0, _extends2.default)({}, props);
86
+ return (// eslint-disable-next-line react/jsx-handler-names
87
+ _react.default.createElement(_Paper.default, {
88
+ className: paperClass,
89
+ onBlur: paperProps.onBlur,
90
+ onFocus: paperProps.onFocus
91
+ }, _react.default.createElement("div", {
92
+ className: classes.overlay
93
+ }, _react.default.createElement("div", {
94
+ className: classes.header
95
+ }, headerElement), _react.default.createElement("div", {
96
+ className: classes.body
97
+ }, children), absoluteElement))
98
+ );
99
+ };
100
+
101
+ CustomOverlayLayoutWithoutFooter.propTypes = process.env.NODE_ENV !== "production" ? {
102
+ absoluteElement: _propTypes.default.any,
103
+ children: _propTypes.default.any,
104
+
105
+ /**
106
+ * Useful to extend the style applied to components.
107
+ */
108
+ classes: _propTypes.default.object,
109
+ footerElement: _propTypes.default.any,
110
+ headerElement: _propTypes.default.any,
111
+
112
+ /**
113
+ * Définit comment construire le Paper dans le cas d'un double input
114
+ */
115
+ side: _propTypes.default.string,
116
+ staticPosition: _propTypes.default.bool
117
+ } : {};
118
+
119
+ var _default = (0, _withStyles.default)(styles, {
120
+ name: 'HmuiCustomOverlayLayoutWithoutFooter'
121
+ })(CustomOverlayLayoutWithoutFooter);
122
+
123
+ exports.default = _default;
@@ -27,7 +27,7 @@ var _react = _interopRequireDefault(require("react"));
27
27
 
28
28
  var _propTypes = _interopRequireDefault(require("prop-types"));
29
29
 
30
- var _CustomOverlayLayout = _interopRequireDefault(require("./CustomOverlayLayout"));
30
+ var _CustomOverlayLayoutWithoutFooter = _interopRequireDefault(require("./CustomOverlayLayoutWithoutFooter"));
31
31
 
32
32
  var _ListPicker = _interopRequireDefault(require("../ListPicker"));
33
33
 
@@ -43,7 +43,7 @@ function (_React$Component) {
43
43
  _this = (0, _possibleConstructorReturn2.default)(this, (0, _getPrototypeOf2.default)(MonthPickerOverlay).call(this));
44
44
  _this.months = [];
45
45
  _this.handleMonthClick = _this.handleMonthClick.bind((0, _assertThisInitialized2.default)((0, _assertThisInitialized2.default)(_this)));
46
- _this.months = props.localeUtils ? props.localeUtils.getMonths() : props.children.props.localeUtils.getMonths();
46
+ _this.months = props.localeUtils ? props.localeUtils.getMonths(props.children.props.locale) : props.children.props.localeUtils.getMonths(props.children.props.locale);
47
47
  return _this;
48
48
  }
49
49
 
@@ -66,8 +66,8 @@ function (_React$Component) {
66
66
  translations = _this$props.translations,
67
67
  props = (0, _objectWithoutProperties2.default)(_this$props, ["value", "translations"]);
68
68
  var now = new Date();
69
- var currentMonth = props.localeUtils ? props.localeUtils.getMonths()[now.getMonth()] : props.children.props.localeUtils.getMonths()[now.getMonth()];
70
- return _react.default.createElement(_CustomOverlayLayout.default, (0, _extends2.default)({
69
+ var currentMonth = props.localeUtils ? props.localeUtils.getMonths(props.children.props.locale)[now.getMonth()] : props.children.props.localeUtils.getMonths(props.children.props.locale)[now.getMonth()];
70
+ return _react.default.createElement(_CustomOverlayLayoutWithoutFooter.default, (0, _extends2.default)({
71
71
  headerElement: translations.month
72
72
  }, props), _react.default.createElement(_ListPicker.default, {
73
73
  itemList: this.months,
@@ -16,6 +16,7 @@ var _MonthPickerOverlay = _interopRequireDefault(require("./MonthPickerOverlay")
16
16
 
17
17
  var _ListPicker = _interopRequireDefault(require("../ListPicker"));
18
18
 
19
+ /* eslint-disable */
19
20
  var _ref = _react.default.createElement("span", null, "children");
20
21
 
21
22
  var _ref2 = _react.default.createElement("span", null, "children");