Skip to content

Commit

Permalink
fix: fixed the startDate to endDate on start input (carbon-design-sys…
Browse files Browse the repository at this point in the history
  • Loading branch information
guidari authored Jul 11, 2024
1 parent e8c6ae5 commit c1822dc
Show file tree
Hide file tree
Showing 2 changed files with 37 additions and 6 deletions.
33 changes: 32 additions & 1 deletion packages/react/src/components/DatePicker/DatePicker.stories.js
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@
* LICENSE file in the root directory of this source tree.
*/

import React from 'react';
import React, { useState } from 'react';

import { WithLayer } from '../../../.storybook/templates/WithLayer';

Expand Down Expand Up @@ -45,6 +45,37 @@ export const Simple = () => (
</DatePicker>
);

export const Test = () => {
const [start, setStart] = useState();
const [end, setEnd] = useState();

const onPeriodChanged = (range) => {
setStart(range[0]);
setEnd(range[1]);
console.log({ range });
};

return (
<DatePicker
datePickerType="range"
value={[start, end]}
onChange={onPeriodChanged}>
<DatePickerInput
id="date-picker-input-id-start"
placeholder="mm/dd/yyyy"
labelText="Start date"
size="md"
/>
<DatePickerInput
id="date-picker-input-id-finish"
placeholder="mm/dd/yyyy"
labelText="End date"
size="md"
/>
</DatePicker>
);
};

export const SingleWithCalendar = () => (
<DatePicker datePickerType="single">
<DatePickerInput
Expand Down
10 changes: 5 additions & 5 deletions packages/react/src/components/DatePicker/plugins/rangePlugin.js
Original file line number Diff line number Diff line change
Expand Up @@ -17,12 +17,12 @@ export default (config) => {
origSetDate.call(this, dates, triggerChange, format);
// If `triggerChange` is `true`, `onValueUpdate` Flatpickr event is fired
// where Flatpickr's range plugin takes care of fixing the first `<input>`
if (!triggerChange) {
const { _input: inputDates } = fp;
const inputDatesArray = inputDates.value.split(' ');
[inputDatesArray[0], inputDatesArray[2]].forEach((input, i) => {
if (!triggerChange && dates.length === 2) {
const { _input: inputFrom } = fp;
const { input: inputTo } = config;
[inputFrom, inputTo].forEach((input, i) => {
if (input) {
input = !dates[i]
input.value = !dates[i]
? ''
: fp.formatDate(new Date(dates[i]), fp.config.dateFormat);
}
Expand Down

0 comments on commit c1822dc

Please sign in to comment.