Skip to content
This repository has been archived by the owner on May 24, 2024. It is now read-only.

Commit

Permalink
Merge branch 'main' into UXPLATFORM-10398_default_false
Browse files Browse the repository at this point in the history
  • Loading branch information
adavijit authored May 22, 2024
2 parents 20a4fed + 1ca9c2e commit 0bda98d
Show file tree
Hide file tree
Showing 44 changed files with 142 additions and 72 deletions.
4 changes: 4 additions & 0 deletions packages/terra-date-picker/CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,10 @@

## Unreleased

* Fixed
* Focus is now not moving to the calendar button when navigating using `tab` key.
* Focus is now retained on the calendar button when the calendar is closed in mobile view.

## 4.110.1 - (May 20, 2024)

* Fixed
Expand Down
56 changes: 36 additions & 20 deletions packages/terra-date-picker/src/DatePicker.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -17,11 +17,6 @@ const propTypes = {
* String that labels the current element. 'aria-label' must be present for accessibility.
*/
ariaLabel: PropTypes.string,
/**
* @private
* Whether or not to disable focus on the calendar button when the calendar picker dismisses.
*/
disableButtonFocusOnClose: PropTypes.bool,
/**
* Whether the date input should be disabled.
*/
Expand Down Expand Up @@ -150,7 +145,6 @@ const propTypes = {
};

const defaultProps = {
disableButtonFocusOnClose: false,
disabled: false,
excludeDates: undefined,
filterDate: undefined,
Expand Down Expand Up @@ -188,6 +182,7 @@ class DatePicker extends React.Component {
this.datePickerContainer = React.createRef();
this.isDefaultDateAcceptable = props.isDefaultDateAcceptable;
this.containerHasFocus = false;
this.inputChanged = false;
this.handleBlur = this.handleBlur.bind(this);
this.handleBreakpointChange = this.handleBreakpointChange.bind(this);
this.handleChange = this.handleChange.bind(this);
Expand Down Expand Up @@ -226,6 +221,12 @@ class DatePicker extends React.Component {
this.isDefaultDateAcceptable = (this.props.isDefaultDateAcceptable) ? this.props.isDefaultDateAcceptable : this.validateDefaultDate();
}

componentWillUnmount() {
if (this.timeoutId) {
clearTimeout(this.timeoutId);
}
}

handleBreakpointChange(activeBreakpoint) {
const showPortalPicker = !this.props.isInline && (activeBreakpoint === 'tiny' || activeBreakpoint === 'small');

Expand All @@ -248,7 +249,7 @@ class DatePicker extends React.Component {
// as well as manually entering a valid date or clearing the date,
// Until a fix is made, we need to return if the event type is 'change' or 'keydown' indicating that onSelect was
// invoked from a manual change. See https://github.com/Hacker0x01/react-datepicker/issues/990
if (event.type === 'change' || event.type === 'keydown' || !selectedDate || !selectedDate.isValid()) {
if (event.type === 'change' || event.type === 'keydown' || !selectedDate || !selectedDate.isValid() || event.type === 'blur') {
return;
}

Expand All @@ -259,25 +260,17 @@ class DatePicker extends React.Component {
this.props.onSelect(event, selectedDate.format(DateUtil.ISO_EXTENDED_DATE_FORMAT));
}

if (!this.props.disableButtonFocusOnClose) {
// Allows time for focus-trap to release focus on the picker before returning focus to the calendar button.
setTimeout(() => {
/*
* Make sure the reference to calendarButton still exists before calling focus because it is possible that it is now
* nullified after the 100 ms timeout due to a force remount of this component with a new `key` prop value.
* Reference https://github.com/cerner/terra-framework/issues/1086
*/
if (this.calendarButton) {
this.calendarButton.focus();
}
}, 100);
// If the portal picker is displayed, focus on the calendar button on selecting a date
if (this.state.showPortalPicker) {
this.focusCalendarButton();
}
}

handleOnClickOutside(event) {
if (this.props.onClickOutside) {
this.props.onClickOutside(event);
}
this.focusCalendarButton();
}

handleBlur(event) {
Expand All @@ -287,6 +280,9 @@ class DatePicker extends React.Component {

// Handle blur only if focus has moved out of the entire date picker component.
if (!this.datePickerContainer.current.contains(activeTarget)) {
this.focusCalendarButton();
this.inputChanged = false;

if (this.props.onBlur) {
const metadata = this.getMetadata();
this.props.onBlur(event, metadata);
Expand All @@ -297,6 +293,8 @@ class DatePicker extends React.Component {
}

handleChange(date, event, value) {
this.inputChanged = true;

if (event.type === 'change') {
this.dateValue = value;
}
Expand Down Expand Up @@ -407,10 +405,28 @@ class DatePicker extends React.Component {
return isAcceptable;
}

focusCalendarButton() {
// Clear any existing timeout before setting a new one
if (this.timeoutId) {
clearTimeout(this.timeoutId);
}
// Allows time for focus-trap to release focus on the picker before returning focus to the calendar button.
this.timeoutId = setTimeout(() => {
/*
* Make sure the reference to calendarButton still exists before calling focus because it is possible that it is now
* nullified after the 100 ms timeout due to a force remount of this component with a new `key` prop value.
* Reference https://github.com/cerner/terra-framework/issues/1086
*/

if (this.calendarButton && this.inputChanged) {
this.calendarButton.focus();
}
}, 100);
}

render() {
const {
ariaLabel,
disableButtonFocusOnClose,
excludeDates,
filterDate,
includeDates,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,6 @@
exports[`should render a calendar filter with default date 1`] = `
<DatePicker
calendarClassName="calendar-filter"
disableButtonFocusOnClose={false}
disabled={false}
errorId=""
intl={
Expand Down Expand Up @@ -49,7 +48,6 @@ exports[`should render a calendar filter with default date 1`] = `
exports[`should render a calendar filter with excluded dates 1`] = `
<DatePicker
calendarClassName="calendar-filter"
disableButtonFocusOnClose={false}
disabled={false}
errorId=""
excludeDates={
Expand Down Expand Up @@ -99,7 +97,6 @@ exports[`should render a calendar filter with excluded dates 1`] = `
exports[`should render a calendar filter with filtered dates 1`] = `
<DatePicker
calendarClassName="calendar-filter"
disableButtonFocusOnClose={false}
disabled={false}
errorId=""
filterDate={[Function]}
Expand Down Expand Up @@ -145,7 +142,6 @@ exports[`should render a calendar filter with filtered dates 1`] = `
exports[`should render a calendar filter with included dates 1`] = `
<DatePicker
calendarClassName="calendar-filter"
disableButtonFocusOnClose={false}
disabled={false}
errorId=""
includeDates={
Expand Down Expand Up @@ -195,7 +191,6 @@ exports[`should render a calendar filter with included dates 1`] = `
exports[`should render a calendar filter with min and max dates 1`] = `
<DatePicker
calendarClassName="calendar-filter"
disableButtonFocusOnClose={false}
disabled={false}
errorId=""
intl={
Expand Down Expand Up @@ -240,7 +235,6 @@ exports[`should render a calendar filter with min and max dates 1`] = `
exports[`should render a calendar filter with onChange 1`] = `
<DatePicker
calendarClassName="calendar-filter"
disableButtonFocusOnClose={false}
disabled={false}
errorId=""
intl={
Expand Down Expand Up @@ -286,7 +280,6 @@ exports[`should render a calendar filter with onChange 1`] = `
exports[`should render a controlled calendar filter 1`] = `
<DatePicker
calendarClassName="calendar-filter"
disableButtonFocusOnClose={false}
disabled={false}
errorId=""
intl={
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,6 @@ exports[`correctly applies the theme context className 1`] = `
name="date-input"
>
<DatePicker
disableButtonFocusOnClose={false}
disabled={false}
errorId=""
intl={
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -282,7 +282,6 @@ exports[`should render a DatePickerField with props 1`] = `
>
<DatePicker
ariaLabel="Label Test"
disableButtonFocusOnClose={false}
disabled={true}
errorId=""
excludeDates={
Expand Down Expand Up @@ -1195,7 +1194,6 @@ exports[`should render a default DatePickerField component 1`] = `
>
<DatePicker
ariaLabel="Label"
disableButtonFocusOnClose={false}
disabled={false}
errorId=""
id="test-date-picker"
Expand Down Expand Up @@ -2174,7 +2172,6 @@ exports[`should render a valid DatePickerField with props 1`] = `
>
<DatePicker
ariaLabel="Label Test"
disableButtonFocusOnClose={false}
disabled={true}
errorId=""
excludeDates={
Expand Down
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
3 changes: 3 additions & 0 deletions packages/terra-date-time-picker/CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,9 @@

## Unreleased

* Removed
* Removed passing `disableButtonFocusOnClose` prop to the `DatePicker` Component.

## 4.118.1 - (May 20, 2024)

* Changed
Expand Down
1 change: 0 additions & 1 deletion packages/terra-date-time-picker/src/DateTimePicker.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -811,7 +811,6 @@ class DateTimePicker extends React.Component {
value={dateValue}
name="input"
disabled={disabled}
disableButtonFocusOnClose
isIncomplete={isIncomplete}
isInvalid={isInvalid}
required={required}
Expand Down
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
2 changes: 1 addition & 1 deletion packages/terra-framework-docs/CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@
* Changed
* Enabled `close` button in examples.

* Changed
* Updated
* Updated example for drill-in view under `terra-navigation-side-menu`.

## 1.89.1 - (May 20, 2024)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,12 @@ class DrillInDefault extends React.Component {
key: 'submenu3', text: 'Hospital Accommodations', isDisabled: true,
},
{ key: 'submenu4', text: 'Hospital Careers' },
{ key: 'submenu5', text: 'Hospital Info', childKeys: [] },
{
key: 'submenu5',
text: 'Hospital Info',
childKeys: [],
customStatusDisplay: <span>No results for Hospital Info</span>,
},
{
key: 'subsubmenu1', text: 'Imaging', id: 'test-item-2',
},
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,40 @@ import styles from './NavigationSideMenuDocCommon.module.scss';

const cx = classNames.bind(styles);

const data = [
{
key: 'menu', text: 'Hospital Details', childKeys: ['submenu1', 'submenu2', 'submenu3', 'submenu4', 'submenu5'],
},
{
key: 'submenu1',
text: 'Hospital services',
childKeys: ['subsubmenu1', 'subsubmenu2', 'subsubmenu3'],
id: 'test-item-1',
},
{ key: 'submenu2', text: 'Hospital events' },
{
key: 'submenu3', text: 'Hospital Accommodations',
},
{ key: 'submenu4', text: 'Hospital Careers' },
{
key: 'submenu5',
text: 'Hospital Info',
childKeys: [],
customStatusDisplay: <span>No results for Hospital Info</span>,
},
{
key: 'subsubmenu1', text: 'Imaging', id: 'test-item-2',
},
{ key: 'subsubmenu2', text: 'Laboratory' },
{
key: 'subsubmenu3', text: 'Rehabilitation services', childKeys: ['rehab1', 'rehab2', 'rehab3'], icon: <IconHospital />,
},
{ key: 'rehab1', text: 'Rehabilitation services 1' },
{
key: 'rehab2', text: 'Rehabilitation services 2', childKeys: [], isLoading: true, customStatusDisplay: <span>Loading...</span>,
},
{ key: 'rehab3', text: 'Rehabilitation services 3', childKeys: [] },
];
class DrillInExample extends React.Component {
constructor(props) {
super(props);
Expand All @@ -14,19 +48,31 @@ class DrillInExample extends React.Component {
this.resetMenuState = this.resetMenuState.bind(this);
this.fakeRoutingBack = this.fakeRoutingBack.bind(this);

this.state = { selectedMenuKey: 'menu', selectedChildKey: undefined };
this.state = { selectedMenuKey: 'menu', selectedChildKey: undefined, data };
}

handleOnChange(event, changeData) {
if (changeData.selectedMenuKey === 'rehab2') {
this.setState({ selectedMenuKey: changeData.selectedMenuKey });
setTimeout(() => {
const modifiedData = [
{
key: 'rehab2', text: 'Rehabilitation services 2', childKeys: ['rehab1sub'], isLoading: false,
},
{ key: 'rehab1sub', text: 'Rehabilitation services submenu', childKeys: [] },
];
this.setState({ data: modifiedData, selectedMenuKey: 'rehab2' });
}, 1000);
}
this.setState({ selectedMenuKey: changeData.selectedMenuKey, selectedChildKey: changeData.selectedChildKey });
}

resetMenuState() {
this.setState({ selectedMenuKey: 'menu', selectedChildKey: undefined });
this.setState({ selectedMenuKey: 'menu', selectedChildKey: undefined, data });
}

fakeRoutingBack() {
this.setState({ selectedMenuKey: 'fake-parent', selectedChildKey: undefined });
this.setState({ selectedMenuKey: 'fake-parent', selectedChildKey: undefined, data });
}

render() {
Expand All @@ -44,33 +90,7 @@ class DrillInExample extends React.Component {
content = (
<NavigationSideMenu
id="test-menu"
menuItems={[
{
key: 'menu', text: 'Hospital Details', childKeys: ['submenu1', 'submenu2', 'submenu3', 'submenu4', 'submenu5'],
},
{
key: 'submenu1',
text: 'Hospital services',
childKeys: ['subsubmenu1', 'subsubmenu2', 'subsubmenu3'],
id: 'test-item-1',
},
{ key: 'submenu2', text: 'Hospital events' },
{
key: 'submenu3', text: 'Hospital Accommodations',
},
{ key: 'submenu4', text: 'Hospital Careers' },
{ key: 'submenu5', text: 'Hospital Info', childKeys: [] },
{
key: 'subsubmenu1', text: 'Imaging', id: 'test-item-2',
},
{ key: 'subsubmenu2', text: 'Laboratory' },
{
key: 'subsubmenu3', text: 'Rehabilitation services', childKeys: ['rehab1', 'rehab2', 'rehab3'], icon: <IconHospital />,
},
{ key: 'rehab1', text: 'Rehabilitation services 1' },
{ key: 'rehab2', text: 'Rehabilitation services 2' },
{ key: 'rehab3', text: 'Rehabilitation services 3', childKeys: [] },
]}
menuItems={this.state.data}
onChange={this.handleOnChange}
routingStackBack={this.fakeRoutingBack}
selectedMenuKey={this.state.selectedMenuKey}
Expand Down
2 changes: 2 additions & 0 deletions packages/terra-navigation-side-menu/CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,8 @@
## Unreleased

* Added
* Added custom status display for Drill-in content.
* Added isLoading prop for Drill-in item.
* Added headerLevel prop for the title of the menu.
* Added missing A11y attributes.

Expand Down
Loading

0 comments on commit 0bda98d

Please sign in to comment.