From 20e343fc9e34570dcd8678ddb449d48c5b62a140 Mon Sep 17 00:00:00 2001 From: Mozafar Date: Thu, 26 Sep 2024 09:47:38 +0100 Subject: [PATCH] fix: update default props to JS default params (#1598) * refactor(react-18): replace defaultProps with JS default params * refactor(react-18): replace remaining defaultProps manually * refactor(react-18): fix wrong replacement for forwardRef and class components * refactor(react-18): use static defaultProps for class components * fix: avoid unnecessary rerenders using stable default prop references (partial) * fix: stable default prop references * fix: add missing defaultProps for file-input-field --------- Co-authored-by: Austin McGee <947888+amcgee@users.noreply.github.com> Co-authored-by: Kai Vandivier --- components/alert/src/alert-bar/alert-bar.js | 12 ++---- components/alert/src/alert-bar/icon.js | 6 +-- .../alert/src/alert-stack/alert-stack.js | 10 ++--- components/box/src/box.js | 6 +-- .../button/src/button-strip/button-strip.js | 12 +++--- components/button/src/button/button.js | 9 +---- .../src/dropdown-button/dropdown-button.js | 10 ++--- .../button/src/split-button/split-button.js | 10 ++--- .../src/calendar-input/calendar-input.js | 5 +-- components/calendar/src/calendar/calendar.js | 12 ++---- .../src/stories/calendar-story-wrapper.js | 12 ++---- components/card/src/card.js | 6 +-- components/center/src/center.js | 15 +++++--- .../src/checkbox-field/checkbox-field.js | 6 +-- components/checkbox/src/checkbox/checkbox.js | 18 ++++----- components/chip/src/chip.js | 12 ++---- components/cover/src/cover.js | 12 +++--- .../css/src/css-variables/css-variables.js | 16 ++++---- components/divider/src/divider.js | 12 +++--- .../field/src/field-group/field-group.js | 6 +-- components/field/src/field-set/field-set.js | 10 ++--- components/field/src/field/field.js | 6 +-- .../file-input-field-with-list.js | 28 +++++++------- ...file-input-field-with-list.prod.stories.js | 6 ++- .../src/file-input-field/file-input-field.js | 18 +++------ .../file-input-field.prod.stories.js | 4 +- .../file-input/src/file-input/file-input.js | 14 +++---- .../src/file-list/file-list-item.js | 6 +-- .../src/file-list/file-list-placeholder.js | 9 ++--- .../file-input/src/file-list/file-list.js | 10 ++--- .../header-bar/src/notification-icon.js | 6 +-- components/help/src/help.js | 13 ++++--- .../input/src/input-field/input-field.js | 10 ++--- components/input/src/input/input.js | 14 +++---- .../src/intersection-detector.js | 9 +---- components/label/src/label.js | 6 +-- components/layer/src/layer.js | 12 ++---- components/layer/src/layer.prod.stories.js | 6 ++- components/legend/src/legend.js | 11 +++--- .../src/circular-loader/circular-loader.js | 6 +-- .../loader/src/linear-loader/linear-loader.js | 12 ++---- components/logo/src/logo.js | 30 +++++---------- .../menu/src/flyout-menu/flyout-menu.js | 12 ++---- .../menu/src/menu-divider/menu-divider.js | 10 ++--- components/menu/src/menu-item/menu-item.js | 6 +-- .../menu-section-header.js | 6 +-- components/menu/src/menu/menu.js | 11 +++--- .../modal/src/modal-actions/modal-actions.js | 9 ++--- .../modal/src/modal-content/modal-content.js | 10 ++--- .../modal/src/modal-title/modal-title.js | 9 ++--- components/modal/src/modal/modal.js | 9 +---- components/node/src/node.js | 6 +-- .../notice-box/src/notice-box-content.js | 10 ++--- components/notice-box/src/notice-box.js | 6 +-- .../organisation-unit-tree-root-error.js | 9 ++--- .../organisation-unit-tree-root-loading.js | 8 ++-- .../organisation-unit-tree.js | 23 ++++-------- .../src/__tests__/page-summary.test.js | 4 +- components/pagination/src/pagination.js | 33 ++++++++--------- components/popover/src/popover.e2e.stories.js | 18 +++++---- components/popover/src/popover.js | 17 +++------ .../popover/src/popover.prod.stories.js | 8 +++- components/popper/src/popper.js | 14 +++---- components/radio/src/radio.js | 10 ++--- .../multi-select-field/multi-select-field.js | 36 +++++++++--------- .../multi-select-field.prod.stories.js | 8 +++- .../multi-select-option.js | 6 +-- components/select/src/multi-select/input.js | 6 +-- components/select/src/multi-select/menu.js | 6 +-- .../select/src/multi-select/multi-select.js | 11 ++---- components/select/src/select/input-wrapper.js | 6 +-- components/select/src/select/menu-wrapper.js | 6 +-- components/select/src/select/select.js | 8 ++-- .../single-select-field.js | 37 ++++++++++--------- .../single-select-field.prod.stories.js | 10 ++++- .../single-select-option.js | 6 +-- components/select/src/single-select/input.js | 6 +-- components/select/src/single-select/menu.js | 6 +-- .../select/src/single-select/single-select.js | 9 +---- .../selector-bar-item/selector-bar-item.js | 6 +-- .../src/selector-bar/selector-bar.js | 6 +-- .../src/autocomplete/autocomplete.js | 6 +-- .../src/autocomplete/menu-popup.js | 6 +-- components/sharing-dialog/src/modal/modal.js | 11 +++--- .../sharing-dialog/src/sharing-dialog.js | 32 +++++++--------- .../switch/src/switch-field/switch-field.js | 6 +-- components/switch/src/switch/switch.js | 18 ++++----- components/tab/src/tab-bar/tab-bar.js | 12 +++--- components/tab/src/tab/tab.js | 14 ++++--- .../table/src/data-table/data-table-cell.js | 16 +++----- .../data-table-column-header.js | 6 +-- .../data-table-row/data-table-row.js | 6 +-- components/table/src/data-table/data-table.js | 12 ++---- .../data-table/table-elements/table-body.js | 16 +++++--- .../table-data-cell/table-data-cell.js | 16 +++----- .../data-table/table-elements/table-foot.js | 15 +++++--- .../data-table/table-elements/table-head.js | 4 -- .../table-header-cell-action.js | 16 +++++--- .../table-header-cell/table-header-cell.js | 18 +++------ .../data-table/table-elements/table-row.js | 14 ++++--- .../table-elements/table-scroll-box.js | 18 +++++---- .../table-elements/table-toolbar.js | 16 +++++--- .../src/data-table/table-elements/table.js | 12 ++---- .../src/stacked-table/stacked-table-body.js | 10 ++--- .../stacked-table/stacked-table-cell-head.js | 9 +---- .../src/stacked-table/stacked-table-cell.js | 10 ++--- .../src/stacked-table/stacked-table-foot.js | 10 ++--- .../src/stacked-table/stacked-table-head.js | 10 ++--- .../stacked-table/stacked-table-row-head.js | 10 ++--- .../src/stacked-table/stacked-table-row.js | 10 ++--- .../table/src/stacked-table/stacked-table.js | 6 +-- components/table/src/table/table-body.js | 11 +++--- components/table/src/table/table-cell-head.js | 6 +-- components/table/src/table/table-cell.js | 6 +-- components/table/src/table/table-foot.js | 11 +++--- components/table/src/table/table-head.js | 11 +++--- components/table/src/table/table-row-head.js | 6 +-- components/table/src/table/table-row.js | 6 +-- components/table/src/table/table.js | 6 +-- components/tag/src/tag.js | 9 +---- .../src/text-area-field/text-area-field.js | 12 ++---- .../text-area/src/text-area/text-area.js | 21 +++++------ components/tooltip/src/tooltip.js | 18 +++------ components/transfer/src/options-container.js | 6 +-- components/transfer/src/transfer-option.js | 6 +-- components/transfer/src/transfer.js | 37 ++++++------------- .../transfer/src/transfer.prod.stories.js | 20 ++++++---- components/user-avatar/src/text-avatar.js | 6 +-- components/user-avatar/src/user-avatar.js | 6 +-- docs/src/components/DemoComponent.jsx | 7 +--- 130 files changed, 597 insertions(+), 859 deletions(-) diff --git a/components/alert/src/alert-bar/alert-bar.js b/components/alert/src/alert-bar/alert-bar.js index 8e84bd2c23..4440e1996f 100644 --- a/components/alert/src/alert-bar/alert-bar.js +++ b/components/alert/src/alert-bar/alert-bar.js @@ -13,10 +13,10 @@ const AlertBar = ({ children, className, critical, - dataTest, - duration, + dataTest = 'dhis2-uicore-alertbar', + duration = 8000, hidden, - icon, + icon = true, permanent, success, warning, @@ -142,12 +142,6 @@ const alertTypePropType = mutuallyExclusive( PropTypes.bool ) -AlertBar.defaultProps = { - duration: 8000, - dataTest: 'dhis2-uicore-alertbar', - icon: true, -} - AlertBar.propTypes = { /** An array of 0-2 action objects `[{label: "Save", onClick: clickHandler}]`*/ diff --git a/components/alert/src/alert-bar/icon.js b/components/alert/src/alert-bar/icon.js index cb78de8a30..dec45757b7 100644 --- a/components/alert/src/alert-bar/icon.js +++ b/components/alert/src/alert-bar/icon.js @@ -9,7 +9,7 @@ import { import PropTypes from 'prop-types' import React from 'react' -const StatusIcon = ({ error, warning, valid, info, defaultTo }) => { +const StatusIcon = ({ error, warning, valid, info, defaultTo = null }) => { if (error) { return } @@ -26,10 +26,6 @@ const StatusIcon = ({ error, warning, valid, info, defaultTo }) => { return defaultTo } -StatusIcon.defaultProps = { - defaultTo: null, -} - StatusIcon.propTypes = { defaultTo: PropTypes.element, error: PropTypes.bool, diff --git a/components/alert/src/alert-stack/alert-stack.js b/components/alert/src/alert-stack/alert-stack.js index c4b35ed022..31ce8f4838 100644 --- a/components/alert/src/alert-stack/alert-stack.js +++ b/components/alert/src/alert-stack/alert-stack.js @@ -4,7 +4,11 @@ import cx from 'classnames' import PropTypes from 'prop-types' import React from 'react' -export const AlertStack = ({ className, children, dataTest }) => ( +export const AlertStack = ({ + className, + children, + dataTest = 'dhis2-uicore-alertstack', +}) => (
{children} @@ -33,10 +37,6 @@ export const AlertStack = ({ className, children, dataTest }) => ( ) -AlertStack.defaultProps = { - dataTest: 'dhis2-uicore-alertstack', -} - AlertStack.propTypes = { children: PropTypes.node, className: PropTypes.string, diff --git a/components/box/src/box.js b/components/box/src/box.js index da9daa35b1..0221e1462e 100644 --- a/components/box/src/box.js +++ b/components/box/src/box.js @@ -11,7 +11,7 @@ export const Box = ({ maxWidth, marginTop, children, - dataTest, + dataTest = 'dhis2-uicore-box', className, }) => (
@@ -31,10 +31,6 @@ export const Box = ({
) -Box.defaultProps = { - dataTest: 'dhis2-uicore-box', -} - Box.propTypes = { children: PropTypes.node, className: PropTypes.string, diff --git a/components/button/src/button-strip/button-strip.js b/components/button/src/button-strip/button-strip.js index 38ccc7a8d5..3857a0b194 100644 --- a/components/button/src/button-strip/button-strip.js +++ b/components/button/src/button-strip/button-strip.js @@ -4,7 +4,13 @@ import cx from 'classnames' import PropTypes from 'prop-types' import React, { Children } from 'react' -const ButtonStrip = ({ className, children, middle, end, dataTest }) => ( +const ButtonStrip = ({ + className, + children, + middle, + end, + dataTest = 'dhis2-uicore-buttonstrip', +}) => (
( const alignmentPropType = mutuallyExclusive(['middle', 'end'], PropTypes.bool) -ButtonStrip.defaultProps = { - dataTest: 'dhis2-uicore-buttonstrip', -} - ButtonStrip.propTypes = { children: PropTypes.node, className: PropTypes.string, diff --git a/components/button/src/button/button.js b/components/button/src/button/button.js index a920e49b77..b25843f6e7 100644 --- a/components/button/src/button/button.js +++ b/components/button/src/button/button.js @@ -8,7 +8,7 @@ import styles from './button.styles.js' export const Button = ({ children, className, - dataTest, + dataTest = 'dhis2-uicore-button', destructive, disabled, icon, @@ -20,7 +20,7 @@ export const Button = ({ small, tabIndex, toggled, - type, + type = 'button', value, onBlur, onClick, @@ -94,11 +94,6 @@ export const Button = ({ ) } -Button.defaultProps = { - type: 'button', - dataTest: 'dhis2-uicore-button', -} - Button.propTypes = { /** Component to render inside the button */ children: PropTypes.node, diff --git a/components/button/src/dropdown-button/dropdown-button.js b/components/button/src/dropdown-button/dropdown-button.js index 82abc73249..418235f37c 100644 --- a/components/button/src/dropdown-button/dropdown-button.js +++ b/components/button/src/dropdown-button/dropdown-button.js @@ -67,6 +67,10 @@ class DropdownButton extends Component { open: false, } + static defaultProps = { + dataTest: 'dhis2-uicore-dropdownbutton', + } + anchorRef = React.createRef() componentDidMount() { @@ -124,7 +128,7 @@ class DropdownButton extends Component { tabIndex, type, initialFocus, - dataTest, + dataTest = 'dhis2-uicore-dropdownbutton', } = this.props const open = typeof this.props.open === 'boolean' @@ -181,10 +185,6 @@ class DropdownButton extends Component { } } -DropdownButton.defaultProps = { - dataTest: 'dhis2-uicore-dropdownbutton', -} - DropdownButton.propTypes = { /** Children to render inside the buton */ children: PropTypes.node, diff --git a/components/button/src/split-button/split-button.js b/components/button/src/split-button/split-button.js index 4aab19d6f5..21041d1c26 100644 --- a/components/button/src/split-button/split-button.js +++ b/components/button/src/split-button/split-button.js @@ -20,6 +20,10 @@ class SplitButton extends Component { open: false, } + static defaultProps = { + dataTest: 'dhis2-uicore-splitbutton', + } + anchorRef = React.createRef() componentDidMount() { @@ -72,7 +76,7 @@ class SplitButton extends Component { disabled, type, tabIndex, - dataTest, + dataTest = 'dhis2-uicore-splitbutton', initialFocus, } = this.props @@ -159,10 +163,6 @@ class SplitButton extends Component { } } -SplitButton.defaultProps = { - dataTest: 'dhis2-uicore-splitbutton', -} - SplitButton.propTypes = { children: PropTypes.string, className: PropTypes.string, diff --git a/components/calendar/src/calendar-input/calendar-input.js b/components/calendar/src/calendar-input/calendar-input.js index 2a8ae395fe..4be73a6555 100644 --- a/components/calendar/src/calendar-input/calendar-input.js +++ b/components/calendar/src/calendar-input/calendar-input.js @@ -27,6 +27,7 @@ export const CalendarInput = ({ width, cellSize, clearable, + dataTest = 'dhis2-uiwidgets-calendar-inputfield', ...rest } = {}) => { const ref = useRef() @@ -72,6 +73,7 @@ export const CalendarInput = ({ { const wrapperBorderColor = colors.grey300 const backgroundColor = 'none' @@ -85,12 +85,6 @@ export const Calendar = ({ ) } -Calendar.defaultProps = { - cellSize: '32px', - width: '240px', - weekDayFormat: 'narrow', -} - export const CalendarProps = { /** the calendar to use such gregory, ethiopic, nepali - full supported list here: https://github.com/dhis2/multi-calendar-dates/blob/main/src/constants/calendars.ts */ calendar: PropTypes.any.isRequired, diff --git a/components/calendar/src/stories/calendar-story-wrapper.js b/components/calendar/src/stories/calendar-story-wrapper.js index e43ed91688..24d6b70249 100644 --- a/components/calendar/src/stories/calendar-story-wrapper.js +++ b/components/calendar/src/stories/calendar-story-wrapper.js @@ -6,13 +6,13 @@ import { Calendar } from '../calendar/calendar.js' const { calendars, numberingSystems } = constants export const CalendarStoryWrapper = (props) => { const { - calendar, + calendar = 'gregory', locale, timeZone, dir, - component: Component, + component: Component = Calendar, date, - weekDayFormat, + weekDayFormat = 'narrow', } = props const [selectedCalendar, setSelectedCalendar] = useState(calendar) const [selectedNumberingSystem, setSelectedNumberingSystem] = useState() @@ -159,12 +159,6 @@ export const CalendarStoryWrapper = (props) => { ) } -CalendarStoryWrapper.defaultProps = { - calendar: 'gregorian', - component: Calendar, - weekDayFormat: 'narrow', -} - CalendarStoryWrapper.propTypes = { calendar: PropTypes.string.isRequired, component: PropTypes.elementType.isRequired, diff --git a/components/card/src/card.js b/components/card/src/card.js index 9319d2b974..8de324e841 100644 --- a/components/card/src/card.js +++ b/components/card/src/card.js @@ -3,7 +3,7 @@ import cx from 'classnames' import PropTypes from 'prop-types' import React from 'react' -const Card = ({ className, children, dataTest }) => ( +const Card = ({ className, children, dataTest = 'dhis2-uicore-card' }) => (
{children} @@ -23,10 +23,6 @@ const Card = ({ className, children, dataTest }) => (
) -Card.defaultProps = { - dataTest: 'dhis2-uicore-card', -} - Card.propTypes = { children: PropTypes.node, className: PropTypes.string, diff --git a/components/center/src/center.js b/components/center/src/center.js index 7222bbb4aa..12275421a6 100644 --- a/components/center/src/center.js +++ b/components/center/src/center.js @@ -3,7 +3,15 @@ import PropTypes from 'prop-types' import React, { forwardRef } from 'react' export const Center = forwardRef( - ({ className, dataTest, children, position }, ref) => ( + ( + { + className, + dataTest = 'dhis2-uicore-centeredcontent', + children, + position = 'middle', + }, + ref + ) => (
( ) -CheckboxField.defaultProps = { - dataTest: 'dhis2-uiwidgets-checkboxfield', -} - CheckboxField.propTypes = { checked: PropTypes.bool, className: PropTypes.string, diff --git a/components/checkbox/src/checkbox/checkbox.js b/components/checkbox/src/checkbox/checkbox.js index c4e95492df..735a1fa6c1 100644 --- a/components/checkbox/src/checkbox/checkbox.js +++ b/components/checkbox/src/checkbox/checkbox.js @@ -58,10 +58,16 @@ class Checkbox extends Component { } } + static defaultProps = { + checked: false, + indeterminate: false, + dataTest: 'dhis2-uicore-checkbox', + } + render() { const { - checked, - indeterminate, + checked = false, + indeterminate = false, className, disabled, error, @@ -72,7 +78,7 @@ class Checkbox extends Component { value, warning, dense, - dataTest, + dataTest = 'dhis2-uicore-checkbox', } = this.props const classes = cx({ @@ -178,12 +184,6 @@ class Checkbox extends Component { } } -Checkbox.defaultProps = { - checked: false, - indeterminate: false, - dataTest: 'dhis2-uicore-checkbox', -} - const uniqueOnStatePropType = mutuallyExclusive( ['checked', 'indeterminate'], PropTypes.bool diff --git a/components/chip/src/chip.js b/components/chip/src/chip.js index 221bf677cd..c06364b3b3 100644 --- a/components/chip/src/chip.js +++ b/components/chip/src/chip.js @@ -19,11 +19,11 @@ const Chip = ({ onRemove, onClick, icon, - dataTest, - marginBottom, + dataTest = 'dhis2-uicore-chip', + marginBottom = 4, marginLeft, marginRight, - marginTop, + marginTop = 4, marginInlineStart, marginInlineEnd, }) => ( @@ -114,12 +114,6 @@ const Chip = ({ ) -Chip.defaultProps = { - dataTest: 'dhis2-uicore-chip', - marginBottom: 4, - marginTop: 4, -} - Chip.propTypes = { children: PropTypes.any, className: PropTypes.string, diff --git a/components/cover/src/cover.js b/components/cover/src/cover.js index 01b2422fdc..2ddb89ff52 100644 --- a/components/cover/src/cover.js +++ b/components/cover/src/cover.js @@ -10,7 +10,13 @@ const createClickHandler = (onClick) => (event) => { } } -const Cover = ({ children, className, dataTest, onClick, translucent }) => ( +const Cover = ({ + children, + className, + dataTest = 'dhis2-uicore-componentcover', + onClick, + translucent, +}) => (
(
) -Cover.defaultProps = { - dataTest: 'dhis2-uicore-componentcover', -} - Cover.propTypes = { children: PropTypes.node, className: PropTypes.string, diff --git a/components/css/src/css-variables/css-variables.js b/components/css/src/css-variables/css-variables.js index d1136932fa..959956efc7 100644 --- a/components/css/src/css-variables/css-variables.js +++ b/components/css/src/css-variables/css-variables.js @@ -15,7 +15,13 @@ const toCustomPropertyString = (themeSection) => .map(([key, value]) => `--${key}: ${value};`) .join('\n') -const CssVariables = ({ colors, theme, layers, spacers, elevations }) => { +const CssVariables = ({ + colors = false, + theme = false, + layers = false, + spacers = false, + elevations = false, +}) => { const allowedProps = { colors, theme, layers, spacers, elevations } const variables = Object.keys(allowedProps) // Filter all props that are false @@ -36,14 +42,6 @@ const CssVariables = ({ colors, theme, layers, spacers, elevations }) => { ) } -CssVariables.defaultProps = { - colors: false, - theme: false, - layers: false, - spacers: false, - elevations: false, -} - CssVariables.propTypes = { colors: PropTypes.bool, elevations: PropTypes.bool, diff --git a/components/divider/src/divider.js b/components/divider/src/divider.js index 1db09c1b3e..10f75165db 100644 --- a/components/divider/src/divider.js +++ b/components/divider/src/divider.js @@ -15,7 +15,12 @@ const flipMargin = (margin) => { return margin } -const Divider = ({ className, dataTest, dense, margin }) => { +const Divider = ({ + className, + dataTest = 'dhis2-uicore-divider', + dense, + margin = `${spacers.dp8} 0`, +}) => { return (