From 0b3de92a1b5571f8f071a9df2100192d6a68bf81 Mon Sep 17 00:00:00 2001 From: HugoChollet Date: Fri, 9 Dec 2022 10:45:29 +0100 Subject: [PATCH] fix: editable check only for TextInput and wording --- README.md | 4 ++-- src/__tests__/to-be-disabled.tsx | 8 ++++---- src/to-be-disabled.ts | 6 ++++-- 3 files changed, 10 insertions(+), 8 deletions(-) diff --git a/README.md b/README.md index 7015f30..714d42b 100644 --- a/README.md +++ b/README.md @@ -119,11 +119,11 @@ toBeDisabled(); Check whether or not an element is disabled from a user perspective. -This matcher will check if the element or its parent has any of thoses props value: +This matcher will check if the element or its parent has any of those props : - `disabled={true}` - `accessibilityState={{disabled: true}}` -- `editable={false}` +- `editable={false}` for `TextInput` only It also works with `accessibilityStates={['disabled']}` for now. However, this prop is deprecated in React Native [0.62](https://reactnative.dev/blog/2020/03/26/version-0.62#breaking-changes) diff --git a/src/__tests__/to-be-disabled.tsx b/src/__tests__/to-be-disabled.tsx index eadbfa9..4a017f6 100644 --- a/src/__tests__/to-be-disabled.tsx +++ b/src/__tests__/to-be-disabled.tsx @@ -50,9 +50,9 @@ describe('.toBeDisabled', () => { }); }); - test('handle editable prop for TextInput when false', () => { + test('handle editable prop for TextInput', () => { const { queryByTestId } = render( - + , @@ -92,9 +92,9 @@ describe('.toBeEnabled', () => { }); }); - test('handle editable prop for TextInput when true', () => { + test('handle editable prop for TextInput', () => { const { queryByTestId } = render( - + diff --git a/src/to-be-disabled.ts b/src/to-be-disabled.ts index 995e583..c6f37dd 100644 --- a/src/to-be-disabled.ts +++ b/src/to-be-disabled.ts @@ -19,12 +19,14 @@ const DISABLE_TYPES = [ function isElementDisabled(element: ReactTestInstance) { if (!DISABLE_TYPES.includes(getType(element))) return false; + if (getType(element) === 'TextInput' && element?.props?.editable === false) { + return true; + } return ( !!element?.props?.disabled || !!element?.props?.accessibilityState?.disabled || - !!element?.props?.accessibilityStates?.includes('disabled') || - element?.props?.editable === false + !!element?.props?.accessibilityStates?.includes('disabled') ); }