From cf72a266144d4e096d90dffc1a2b737f5b8c7bef Mon Sep 17 00:00:00 2001 From: Afsal K Date: Mon, 18 Nov 2024 18:09:08 +0530 Subject: [PATCH 1/3] refactor(useFocus): refactor repeated useEffect code --- .../components/APIKeyModal/APIKeyModal.tsx | 24 +---------- .../src/components/AboutModal/AboutModal.tsx | 7 ++-- .../components/Tearsheet/TearsheetShell.tsx | 41 ++----------------- .../src/global/js/hooks/useFocus.js | 31 ++++++++++++++ 4 files changed, 39 insertions(+), 64 deletions(-) diff --git a/packages/ibm-products/src/components/APIKeyModal/APIKeyModal.tsx b/packages/ibm-products/src/components/APIKeyModal/APIKeyModal.tsx index 5e2b48217f..c7e0809c97 100644 --- a/packages/ibm-products/src/components/APIKeyModal/APIKeyModal.tsx +++ b/packages/ibm-products/src/components/APIKeyModal/APIKeyModal.tsx @@ -36,7 +36,7 @@ import { isRequiredIf } from '../../global/js/utils/props-helper'; import uuidv4 from '../../global/js/utils/uuidv4'; import { APIKeyModalProps } from './APIKeyModal.types'; import { useFocus, usePreviousValue } from '../../global/js/hooks'; -import { getSpecificElement } from '../../global/js/hooks/useFocus'; +import { claimFocus } from '../../global/js/hooks/useFocus'; const componentName = 'APIKeyModal'; @@ -137,27 +137,7 @@ export let APIKeyModal: React.FC = forwardRef( useEffect(() => { if (open) { // Focusing the first element or selectorPrimaryFocus element - if ( - selectorPrimaryFocus && - getSpecificElement(modalRef?.current, selectorPrimaryFocus) - ) { - const specifiedEl = getSpecificElement( - modalRef?.current, - selectorPrimaryFocus - ); - - if ( - specifiedEl && - window?.getComputedStyle(specifiedEl)?.display !== 'none' - ) { - setTimeout(() => specifiedEl.focus(), 0); - return; - } - } - - setTimeout(() => { - firstElement?.focus(); - }, 0); + claimFocus(firstElement, modalRef, selectorPrimaryFocus); } }, [firstElement, modalRef, open, selectorPrimaryFocus]); diff --git a/packages/ibm-products/src/components/AboutModal/AboutModal.tsx b/packages/ibm-products/src/components/AboutModal/AboutModal.tsx index ced6f6b517..afaea2a06b 100644 --- a/packages/ibm-products/src/components/AboutModal/AboutModal.tsx +++ b/packages/ibm-products/src/components/AboutModal/AboutModal.tsx @@ -21,7 +21,7 @@ import React, { MutableRefObject, ReactNode, useEffect, useRef } from 'react'; import PropTypes from 'prop-types'; import cx from 'classnames'; import { getDevtoolsProps } from '../../global/js/utils/devtools'; -import { useFocus } from '../../global/js/hooks/useFocus'; +import { claimFocus, useFocus } from '../../global/js/hooks/useFocus'; import { pkg } from '../../settings'; import { usePortalTarget } from '../../global/js/hooks/usePortalTarget'; import uuidv4 from '../../global/js/utils/uuidv4'; @@ -153,10 +153,9 @@ export let AboutModal = React.forwardRef( useEffect(() => { if (open) { - setTimeout(() => firstElement?.focus(), 0); + claimFocus(firstElement, modalRef); } - // eslint-disable-next-line react-hooks/exhaustive-deps - }, [open]); + }, [firstElement, modalRef, open]); return renderPortalUse( diff --git a/packages/ibm-products/src/components/Tearsheet/TearsheetShell.tsx b/packages/ibm-products/src/components/Tearsheet/TearsheetShell.tsx index bebe1617c8..74dd3e7376 100644 --- a/packages/ibm-products/src/components/Tearsheet/TearsheetShell.tsx +++ b/packages/ibm-products/src/components/Tearsheet/TearsheetShell.tsx @@ -39,7 +39,7 @@ import { import { ActionSet } from '../ActionSet'; import { Wrap } from '../../global/js/utils/Wrap'; import { usePortalTarget } from '../../global/js/hooks/usePortalTarget'; -import { getSpecificElement, useFocus } from '../../global/js/hooks/useFocus'; +import { claimFocus, useFocus } from '../../global/js/hooks/useFocus'; import { usePreviousValue } from '../../global/js/hooks'; import { TearsheetAction } from './Tearsheet'; @@ -323,48 +323,13 @@ export const TearsheetShell = React.forwardRef( // Callback to give the tearsheet the opportunity to claim focus handleStackChange.claimFocus = function () { - if ( - selectorPrimaryFocus && - getSpecificElement(modalRef?.current, selectorPrimaryFocus) - ) { - const specifiedEl = getSpecificElement( - modalRef?.current, - selectorPrimaryFocus - ); - - if ( - specifiedEl && - window?.getComputedStyle(specifiedEl)?.display !== 'none' - ) { - return specifiedEl.focus(); - } - } - - setTimeout(() => firstElement?.focus(), 0); + claimFocus(firstElement, modalRef, selectorPrimaryFocus); }; useEffect(() => { if (open) { // Focusing the first element or selectorPrimaryFocus element - if ( - selectorPrimaryFocus && - getSpecificElement(modalRef?.current, selectorPrimaryFocus) - ) { - const specifiedEl = getSpecificElement( - modalRef?.current, - selectorPrimaryFocus - ); - - if ( - specifiedEl && - window?.getComputedStyle(specifiedEl)?.display !== 'none' - ) { - setTimeout(() => specifiedEl.focus(), 0); - return; - } - } - - setTimeout(() => firstElement?.focus(), 0); + claimFocus(firstElement, modalRef, selectorPrimaryFocus); } }, [firstElement, modalRef, open, selectorPrimaryFocus]); diff --git a/packages/ibm-products/src/global/js/hooks/useFocus.js b/packages/ibm-products/src/global/js/hooks/useFocus.js index f82bb9b613..e6a7dd052a 100644 --- a/packages/ibm-products/src/global/js/hooks/useFocus.js +++ b/packages/ibm-products/src/global/js/hooks/useFocus.js @@ -97,3 +97,34 @@ export const useFocus = (modalRef, selectorPrimaryFocus) => { getFocusable: getFocusable, }; }; + +/** + * + * @param {*} firstElement + * @param {*} modalRef + * @param {string | undefined} selectorPrimaryFocus + */ +export const claimFocus = ( + firstElement, + modalRef, + selectorPrimaryFocus = undefined +) => { + if ( + selectorPrimaryFocus && + getSpecificElement(modalRef?.current, selectorPrimaryFocus) + ) { + const specifiedEl = getSpecificElement( + modalRef?.current, + selectorPrimaryFocus + ); + + if ( + specifiedEl && + window?.getComputedStyle(specifiedEl)?.display !== 'none' + ) { + return specifiedEl.focus(); + } + } + + setTimeout(() => firstElement?.focus(), 0); +}; From 3705647b772ee01594758ab85d79f259e4846ee1 Mon Sep 17 00:00:00 2001 From: Afsal K Date: Tue, 7 Jan 2025 20:21:49 +0530 Subject: [PATCH 2/3] fix(create-release-tag-and-pr): resolve conflict issue in workflow --- .github/workflows/create-release-tag-and-pr.yml | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/.github/workflows/create-release-tag-and-pr.yml b/.github/workflows/create-release-tag-and-pr.yml index 0f9f01dce0..1f659a385d 100644 --- a/.github/workflows/create-release-tag-and-pr.yml +++ b/.github/workflows/create-release-tag-and-pr.yml @@ -49,6 +49,18 @@ jobs: run: | git checkout -b chore/${{ github.event.inputs.tag }}-release git push origin chore/${{ github.event.inputs.tag }}-release + + # Check for conflicts and if exists resolve it + - name: Check for conflicts and resolve + run: | + git merge origin/main + if [ $? -ne 0 ]; then + echo "Merge conflicts detected" + # Resolve conflicts by choosing current version as latest than main + git checkout --ours . + git add . + git commit -m "chore: resolved merge conflicts" + # Create PR with the new branch - name: Create Pull Request run: | From b6467c7662647b3cacee8d160593ef679d74ce08 Mon Sep 17 00:00:00 2001 From: Afsal K Date: Wed, 8 Jan 2025 10:38:19 +0530 Subject: [PATCH 3/3] feat(create-release-tag-and-pr): implement step to resolve conflict --- .github/workflows/create-release-tag-and-pr.yml | 11 +++-------- 1 file changed, 3 insertions(+), 8 deletions(-) diff --git a/.github/workflows/create-release-tag-and-pr.yml b/.github/workflows/create-release-tag-and-pr.yml index 1f659a385d..976816b0d3 100644 --- a/.github/workflows/create-release-tag-and-pr.yml +++ b/.github/workflows/create-release-tag-and-pr.yml @@ -51,15 +51,10 @@ jobs: git push origin chore/${{ github.event.inputs.tag }}-release # Check for conflicts and if exists resolve it - - name: Check for conflicts and resolve + - name: Attempt merge and resolve conflict (if any) run: | - git merge origin/main - if [ $? -ne 0 ]; then - echo "Merge conflicts detected" - # Resolve conflicts by choosing current version as latest than main - git checkout --ours . - git add . - git commit -m "chore: resolved merge conflicts" + git merge origin/main -Xours || true + git push origin chore/${{ github.event.inputs.tag }}-release # Create PR with the new branch - name: Create Pull Request