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

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 (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");