react-native-a11y-order 0.9.1 → 0.11.0-rc
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +50 -336
- package/android/src/main/java/com/a11yorder/A11yOrderPackage.java +2 -6
- package/android/src/main/java/com/a11yorder/core/A11yAutoFocusView.java +61 -0
- package/android/src/main/java/com/a11yorder/{views/A11yView/A11yView.java → core/A11yScreenReaderView.java} +3 -45
- package/android/src/main/java/com/a11yorder/core/A11yViewOrder.java +37 -0
- package/android/src/main/java/com/a11yorder/views/A11yCardView/A11yCardViewManager.java +18 -0
- package/android/src/main/java/com/a11yorder/views/A11yIndexView/A11yIndexView.java +2 -65
- package/android/src/main/java/com/a11yorder/views/A11yIndexView/A11yIndexViewManager.java +27 -0
- package/android/src/newarch/A11yCardViewManagerSpec.java +9 -0
- package/android/src/oldarch/A11yCardViewManagerSpec.java +8 -0
- package/android/src/oldarch/A11yIndexViewManagerSpec.java +9 -0
- package/ios/helpers/RNAOFabricEventHelper/RNAOFabricEventHelper.mm +5 -5
- package/ios/views/RNAOA11yCardView/RNAOA11yCardView.h +29 -0
- package/ios/views/RNAOA11yCardView/RNAOA11yCardView.mm +83 -0
- package/ios/views/RNAOA11yCardView/RNAOA11yCardViewManager.h +14 -0
- package/ios/views/RNAOA11yCardView/RNAOA11yCardViewManager.mm +17 -0
- package/ios/views/RNAOA11yIndexView/RNAOA11yIndexView.h +2 -41
- package/ios/views/RNAOA11yIndexView/RNAOA11yIndexView.mm +27 -127
- package/ios/views/RNAOA11yIndexView/RNAOA11yIndexViewManager.mm +21 -0
- package/ios/views/base/RNAOA11yAutoFocusView.h +30 -0
- package/ios/views/{RNAOA11yView/RNAOA11yView.mm → base/RNAOA11yAutoFocusView.mm} +66 -168
- package/ios/views/base/RNAOA11yGroupChildrenView.h +21 -0
- package/ios/views/base/RNAOA11yGroupChildrenView.mm +19 -0
- package/ios/views/base/RNAOA11yScreenReaderView.h +24 -0
- package/ios/views/base/RNAOA11yScreenReaderView.mm +32 -0
- package/ios/views/base/RNAOA11yViewGroup.h +35 -0
- package/ios/views/base/RNAOA11yViewGroup.mm +46 -0
- package/ios/views/base/RNAOA11yViewOrder.h +40 -0
- package/ios/views/base/RNAOA11yViewOrder.mm +92 -0
- package/lib/commonjs/components/A11yCard/A11yCard.ios.js +49 -0
- package/lib/commonjs/components/A11yCard/A11yCard.ios.js.map +1 -0
- package/lib/commonjs/components/A11yCard/A11yCard.js +41 -0
- package/lib/commonjs/components/A11yCard/A11yCard.js.map +1 -0
- package/lib/commonjs/{types/A11yGroup.types.js → components/A11yCard/A11yCard.types.js} +1 -1
- package/lib/commonjs/components/A11yCard/A11yCard.types.js.map +1 -0
- package/lib/commonjs/components/A11yIndex/A11yIndex.js +88 -28
- package/lib/commonjs/components/A11yIndex/A11yIndex.js.map +1 -1
- package/lib/commonjs/components/A11yIndex/A11yIndex.types.js +39 -0
- package/lib/commonjs/components/A11yIndex/A11yIndex.types.js.map +1 -0
- package/lib/commonjs/components/A11yIndex/A11yIndex.web.js.map +1 -1
- package/lib/commonjs/components/A11yLock/A11yFocusFrame/A11yFocusFrame.js.map +1 -1
- package/lib/commonjs/components/A11yLock/A11yFocusTrap/A11yFocusTrap.js.map +1 -1
- package/lib/commonjs/components/A11yLock/A11yLock.types.js.map +1 -0
- package/lib/commonjs/components/{A11ySequence/A11ySequence.js → A11yOrder/A11yOrder.js} +3 -3
- package/lib/commonjs/components/A11yOrder/A11yOrder.js.map +1 -0
- package/lib/commonjs/{types/A11yModule.types.js → components/A11yOrder/A11yOrder.types.js} +1 -1
- package/lib/commonjs/components/A11yOrder/A11yOrder.types.js.map +1 -0
- package/lib/commonjs/components/A11yPaneTitle/A11yPaneTitle.js +6 -7
- package/lib/commonjs/components/A11yPaneTitle/A11yPaneTitle.js.map +1 -1
- package/lib/commonjs/components/A11yPaneTitle/A11yPaneTitle.types.js +6 -0
- package/lib/commonjs/components/A11yPaneTitle/A11yPaneTitle.types.js.map +1 -0
- package/lib/commonjs/components/A11yView/A11yView.js +7 -33
- package/lib/commonjs/components/A11yView/A11yView.js.map +1 -1
- package/lib/commonjs/components/A11yView/A11yView.types.js.map +1 -0
- package/lib/commonjs/index.js +17 -8
- package/lib/commonjs/index.js.map +1 -1
- package/lib/commonjs/index.web.js +10 -4
- package/lib/commonjs/index.web.js.map +1 -1
- package/lib/commonjs/nativeSpecs/{A11yGroupNativeComponent.ts → A11yCardNativeComponent.ts} +3 -3
- package/lib/commonjs/nativeSpecs/A11yIndexNativeComponent.ts +12 -3
- package/lib/module/components/A11yCard/A11yCard.ios.js +43 -0
- package/lib/module/components/A11yCard/A11yCard.ios.js.map +1 -0
- package/lib/module/components/A11yCard/A11yCard.js +35 -0
- package/lib/module/components/A11yCard/A11yCard.js.map +1 -0
- package/lib/module/components/A11yCard/A11yCard.types.js +4 -0
- package/lib/module/components/A11yCard/A11yCard.types.js.map +1 -0
- package/lib/module/components/A11yIndex/A11yIndex.js +88 -28
- package/lib/module/components/A11yIndex/A11yIndex.js.map +1 -1
- package/lib/module/components/A11yIndex/A11yIndex.types.js +35 -0
- package/lib/module/components/A11yIndex/A11yIndex.types.js.map +1 -0
- package/lib/module/components/A11yIndex/A11yIndex.web.js.map +1 -1
- package/lib/module/components/A11yLock/A11yFocusFrame/A11yFocusFrame.js.map +1 -1
- package/lib/module/components/A11yLock/A11yFocusTrap/A11yFocusTrap.js.map +1 -1
- package/lib/module/components/A11yLock/A11yLock.types.js.map +1 -0
- package/lib/module/components/{A11ySequence/A11ySequence.js → A11yOrder/A11yOrder.js} +2 -2
- package/lib/module/components/A11yOrder/A11yOrder.js.map +1 -0
- package/lib/module/components/A11yOrder/A11yOrder.types.js +4 -0
- package/lib/module/components/A11yOrder/A11yOrder.types.js.map +1 -0
- package/lib/module/components/A11yPaneTitle/A11yPaneTitle.js +6 -7
- package/lib/module/components/A11yPaneTitle/A11yPaneTitle.js.map +1 -1
- package/lib/module/components/A11yPaneTitle/A11yPaneTitle.types.js +4 -0
- package/lib/module/components/A11yPaneTitle/A11yPaneTitle.types.js.map +1 -0
- package/lib/module/components/A11yView/A11yView.js +7 -31
- package/lib/module/components/A11yView/A11yView.js.map +1 -1
- package/lib/module/components/A11yView/A11yView.types.js.map +1 -0
- package/lib/module/index.js +12 -8
- package/lib/module/index.js.map +1 -1
- package/lib/module/index.web.js +4 -4
- package/lib/module/index.web.js.map +1 -1
- package/{src/nativeSpecs/A11yGroupNativeComponent.ts → lib/module/nativeSpecs/A11yCardNativeComponent.ts} +3 -3
- package/lib/module/nativeSpecs/A11yIndexNativeComponent.ts +12 -3
- package/lib/typescript/src/components/A11yCard/A11yCard.d.ts +5 -0
- package/lib/typescript/src/components/A11yCard/A11yCard.d.ts.map +1 -0
- package/lib/typescript/src/components/A11yCard/A11yCard.ios.d.ts +5 -0
- package/lib/typescript/src/components/A11yCard/A11yCard.ios.d.ts.map +1 -0
- package/lib/typescript/src/components/A11yCard/A11yCard.types.d.ts +38 -0
- package/lib/typescript/src/components/A11yCard/A11yCard.types.d.ts.map +1 -0
- package/lib/typescript/src/components/A11yIndex/A11yIndex.d.ts +15 -10
- package/lib/typescript/src/components/A11yIndex/A11yIndex.d.ts.map +1 -1
- package/lib/typescript/src/components/A11yIndex/A11yIndex.types.d.ts +105 -0
- package/lib/typescript/src/components/A11yIndex/A11yIndex.types.d.ts.map +1 -0
- package/lib/typescript/src/components/A11yIndex/A11yIndex.web.d.ts +14 -10
- package/lib/typescript/src/components/A11yIndex/A11yIndex.web.d.ts.map +1 -1
- package/lib/typescript/src/components/A11yLock/A11yBaseLock/A11yBaseLock.d.ts +1 -1
- package/lib/typescript/src/components/A11yLock/A11yBaseLock/A11yBaseLock.d.ts.map +1 -1
- package/lib/typescript/src/components/A11yLock/A11yFocusFrame/A11yFocusFrame.android.d.ts +1 -1
- package/lib/typescript/src/components/A11yLock/A11yFocusFrame/A11yFocusFrame.android.d.ts.map +1 -1
- package/lib/typescript/src/components/A11yLock/A11yFocusFrame/A11yFocusFrame.d.ts +2 -2
- package/lib/typescript/src/components/A11yLock/A11yFocusFrame/A11yFocusFrame.d.ts.map +1 -1
- package/lib/typescript/src/components/A11yLock/A11yFocusTrap/A11yFocusTrap.android.d.ts +1 -1
- package/lib/typescript/src/components/A11yLock/A11yFocusTrap/A11yFocusTrap.android.d.ts.map +1 -1
- package/lib/typescript/src/components/A11yLock/A11yFocusTrap/A11yFocusTrap.d.ts +2 -2
- package/lib/typescript/src/components/A11yLock/A11yFocusTrap/A11yFocusTrap.d.ts.map +1 -1
- package/lib/typescript/src/components/A11yLock/A11yLock.types.d.ts +35 -0
- package/lib/typescript/src/components/A11yLock/A11yLock.types.d.ts.map +1 -0
- package/lib/typescript/src/components/{A11ySequence/A11ySequence.d.ts → A11yOrder/A11yOrder.d.ts} +4 -2
- package/lib/typescript/src/components/A11yOrder/A11yOrder.d.ts.map +1 -0
- package/lib/typescript/src/components/A11yOrder/A11yOrder.types.d.ts +11 -0
- package/lib/typescript/src/components/A11yOrder/A11yOrder.types.d.ts.map +1 -0
- package/lib/typescript/src/components/A11yPaneTitle/A11yPaneTitle.d.ts +3 -17
- package/lib/typescript/src/components/A11yPaneTitle/A11yPaneTitle.d.ts.map +1 -1
- package/lib/typescript/src/components/A11yPaneTitle/A11yPaneTitle.types.d.ts +52 -0
- package/lib/typescript/src/components/A11yPaneTitle/A11yPaneTitle.types.d.ts.map +1 -0
- package/lib/typescript/src/components/A11yView/A11yView.d.ts +13 -6
- package/lib/typescript/src/components/A11yView/A11yView.d.ts.map +1 -1
- package/lib/typescript/src/components/A11yView/A11yView.types.d.ts +10 -0
- package/lib/typescript/src/components/A11yView/A11yView.types.d.ts.map +1 -0
- package/lib/typescript/src/index.d.ts +32 -36
- package/lib/typescript/src/index.d.ts.map +1 -1
- package/lib/typescript/src/index.web.d.ts +22 -22
- package/lib/typescript/src/index.web.d.ts.map +1 -1
- package/lib/typescript/src/nativeSpecs/A11yCardNativeComponent.d.ts +8 -0
- package/lib/typescript/src/nativeSpecs/A11yCardNativeComponent.d.ts.map +1 -0
- package/lib/typescript/src/nativeSpecs/A11yIndexNativeComponent.d.ts +10 -3
- package/lib/typescript/src/nativeSpecs/A11yIndexNativeComponent.d.ts.map +1 -1
- package/package.json +12 -11
- package/src/components/A11yCard/A11yCard.ios.tsx +44 -0
- package/src/components/A11yCard/A11yCard.tsx +35 -0
- package/src/components/A11yCard/A11yCard.types.ts +50 -0
- package/src/components/A11yIndex/A11yIndex.tsx +144 -52
- package/src/components/A11yIndex/A11yIndex.types.ts +124 -0
- package/src/components/A11yIndex/A11yIndex.web.tsx +12 -17
- package/src/components/A11yLock/A11yBaseLock/A11yBaseLock.tsx +1 -1
- package/src/components/A11yLock/A11yFocusFrame/A11yFocusFrame.android.tsx +1 -1
- package/src/components/A11yLock/A11yFocusFrame/A11yFocusFrame.tsx +3 -2
- package/src/components/A11yLock/A11yFocusTrap/A11yFocusTrap.android.tsx +1 -1
- package/src/components/A11yLock/A11yFocusTrap/A11yFocusTrap.tsx +2 -2
- package/src/components/A11yLock/A11yLock.types.ts +38 -0
- package/src/components/{A11ySequence/A11ySequence.tsx → A11yOrder/A11yOrder.tsx} +4 -2
- package/src/components/A11yOrder/A11yOrder.types.ts +11 -0
- package/src/components/A11yPaneTitle/A11yPaneTitle.tsx +13 -19
- package/src/components/A11yPaneTitle/A11yPaneTitle.types.ts +58 -0
- package/src/components/A11yView/A11yView.tsx +8 -63
- package/src/components/A11yView/A11yView.types.ts +11 -0
- package/src/index.ts +26 -19
- package/src/index.web.ts +6 -13
- package/{lib/module/nativeSpecs/A11yGroupNativeComponent.ts → src/nativeSpecs/A11yCardNativeComponent.ts} +3 -3
- package/src/nativeSpecs/A11yIndexNativeComponent.ts +12 -3
- package/android/src/main/java/com/a11yorder/views/A11yGroupView/A11yGroupViewManager.java +0 -25
- package/android/src/main/java/com/a11yorder/views/A11yUIContainerView/A11yUIContainerViewManager.java +0 -30
- package/android/src/main/java/com/a11yorder/views/A11yView/A11yViewManager.java +0 -67
- package/android/src/newarch/A11yGroupViewManagerSpec.java +0 -9
- package/android/src/newarch/A11yUIContainerViewManagerSpec.java +0 -8
- package/android/src/newarch/A11yViewSpec.java +0 -13
- package/android/src/oldarch/A11yGroupViewManagerSpec.java +0 -8
- package/android/src/oldarch/A11yUIContainerViewManagerSpec.java +0 -9
- package/android/src/oldarch/A11yViewSpec.java +0 -18
- package/ios/views/RNAOA11yGroupView/RNAOA11yGroupView.h +0 -37
- package/ios/views/RNAOA11yGroupView/RNAOA11yGroupView.mm +0 -67
- package/ios/views/RNAOA11yGroupView/RNAOA11yGroupViewManager.h +0 -18
- package/ios/views/RNAOA11yGroupView/RNAOA11yGroupViewManager.mm +0 -25
- package/ios/views/RNAOA11yUIContainerView/RNAOA11yUIContainerView.h +0 -35
- package/ios/views/RNAOA11yUIContainerView/RNAOA11yUIContainerView.mm +0 -79
- package/ios/views/RNAOA11yUIContainerView/RNAOA11yUIContainerViewManager.h +0 -18
- package/ios/views/RNAOA11yUIContainerView/RNAOA11yUIContainerViewManager.mm +0 -27
- package/ios/views/RNAOA11yView/RNAOA11yView.h +0 -45
- package/ios/views/RNAOA11yView/RNAOA11yViewManager.h +0 -14
- package/ios/views/RNAOA11yView/RNAOA11yViewManager.mm +0 -53
- package/lib/commonjs/components/A11yGroup/A11yGroup.android.js +0 -18
- package/lib/commonjs/components/A11yGroup/A11yGroup.android.js.map +0 -1
- package/lib/commonjs/components/A11yGroup/A11yGroup.ios.js +0 -24
- package/lib/commonjs/components/A11yGroup/A11yGroup.ios.js.map +0 -1
- package/lib/commonjs/components/A11yGroup/A11yGroup.js +0 -9
- package/lib/commonjs/components/A11yGroup/A11yGroup.js.map +0 -1
- package/lib/commonjs/components/A11ySequence/A11ySequence.js.map +0 -1
- package/lib/commonjs/components/A11yUIContainer/A11yUIContainer.ios.js +0 -22
- package/lib/commonjs/components/A11yUIContainer/A11yUIContainer.ios.js.map +0 -1
- package/lib/commonjs/components/A11yUIContainer/A11yUIContainer.js +0 -9
- package/lib/commonjs/components/A11yUIContainer/A11yUIContainer.js.map +0 -1
- package/lib/commonjs/nativeSpecs/A11yUIContainerNativeComponent.ts +0 -12
- package/lib/commonjs/nativeSpecs/A11yViewNativeComponent.ts +0 -36
- package/lib/commonjs/types/A11yGroup.types.js.map +0 -1
- package/lib/commonjs/types/A11yIndex.types.js +0 -13
- package/lib/commonjs/types/A11yIndex.types.js.map +0 -1
- package/lib/commonjs/types/A11yLock.types.js.map +0 -1
- package/lib/commonjs/types/A11yModule.types.js.map +0 -1
- package/lib/commonjs/types/A11yUIContainerView.types.js +0 -15
- package/lib/commonjs/types/A11yUIContainerView.types.js.map +0 -1
- package/lib/commonjs/types/A11yView.types.js.map +0 -1
- package/lib/module/components/A11yGroup/A11yGroup.android.js +0 -12
- package/lib/module/components/A11yGroup/A11yGroup.android.js.map +0 -1
- package/lib/module/components/A11yGroup/A11yGroup.ios.js +0 -18
- package/lib/module/components/A11yGroup/A11yGroup.ios.js.map +0 -1
- package/lib/module/components/A11yGroup/A11yGroup.js +0 -5
- package/lib/module/components/A11yGroup/A11yGroup.js.map +0 -1
- package/lib/module/components/A11ySequence/A11ySequence.js.map +0 -1
- package/lib/module/components/A11yUIContainer/A11yUIContainer.ios.js +0 -17
- package/lib/module/components/A11yUIContainer/A11yUIContainer.ios.js.map +0 -1
- package/lib/module/components/A11yUIContainer/A11yUIContainer.js +0 -5
- package/lib/module/components/A11yUIContainer/A11yUIContainer.js.map +0 -1
- package/lib/module/nativeSpecs/A11yUIContainerNativeComponent.ts +0 -12
- package/lib/module/nativeSpecs/A11yViewNativeComponent.ts +0 -36
- package/lib/module/types/A11yGroup.types.js +0 -4
- package/lib/module/types/A11yGroup.types.js.map +0 -1
- package/lib/module/types/A11yIndex.types.js +0 -9
- package/lib/module/types/A11yIndex.types.js.map +0 -1
- package/lib/module/types/A11yLock.types.js.map +0 -1
- package/lib/module/types/A11yModule.types.js +0 -4
- package/lib/module/types/A11yModule.types.js.map +0 -1
- package/lib/module/types/A11yUIContainerView.types.js +0 -11
- package/lib/module/types/A11yUIContainerView.types.js.map +0 -1
- package/lib/module/types/A11yView.types.js.map +0 -1
- package/lib/typescript/src/components/A11yGroup/A11yGroup.android.d.ts +0 -4
- package/lib/typescript/src/components/A11yGroup/A11yGroup.android.d.ts.map +0 -1
- package/lib/typescript/src/components/A11yGroup/A11yGroup.d.ts +0 -3
- package/lib/typescript/src/components/A11yGroup/A11yGroup.d.ts.map +0 -1
- package/lib/typescript/src/components/A11yGroup/A11yGroup.ios.d.ts +0 -4
- package/lib/typescript/src/components/A11yGroup/A11yGroup.ios.d.ts.map +0 -1
- package/lib/typescript/src/components/A11ySequence/A11ySequence.d.ts.map +0 -1
- package/lib/typescript/src/components/A11yUIContainer/A11yUIContainer.d.ts +0 -3
- package/lib/typescript/src/components/A11yUIContainer/A11yUIContainer.d.ts.map +0 -1
- package/lib/typescript/src/components/A11yUIContainer/A11yUIContainer.ios.d.ts +0 -4
- package/lib/typescript/src/components/A11yUIContainer/A11yUIContainer.ios.d.ts.map +0 -1
- package/lib/typescript/src/nativeSpecs/A11yGroupNativeComponent.d.ts +0 -8
- package/lib/typescript/src/nativeSpecs/A11yGroupNativeComponent.d.ts.map +0 -1
- package/lib/typescript/src/nativeSpecs/A11yUIContainerNativeComponent.d.ts +0 -10
- package/lib/typescript/src/nativeSpecs/A11yUIContainerNativeComponent.d.ts.map +0 -1
- package/lib/typescript/src/nativeSpecs/A11yViewNativeComponent.d.ts +0 -26
- package/lib/typescript/src/nativeSpecs/A11yViewNativeComponent.d.ts.map +0 -1
- package/lib/typescript/src/types/A11yGroup.types.d.ts +0 -7
- package/lib/typescript/src/types/A11yGroup.types.d.ts.map +0 -1
- package/lib/typescript/src/types/A11yIndex.types.d.ts +0 -19
- package/lib/typescript/src/types/A11yIndex.types.d.ts.map +0 -1
- package/lib/typescript/src/types/A11yLock.types.d.ts +0 -8
- package/lib/typescript/src/types/A11yLock.types.d.ts.map +0 -1
- package/lib/typescript/src/types/A11yModule.types.d.ts +0 -7
- package/lib/typescript/src/types/A11yModule.types.d.ts.map +0 -1
- package/lib/typescript/src/types/A11yUIContainerView.types.d.ts +0 -13
- package/lib/typescript/src/types/A11yUIContainerView.types.d.ts.map +0 -1
- package/lib/typescript/src/types/A11yView.types.d.ts +0 -12
- package/lib/typescript/src/types/A11yView.types.d.ts.map +0 -1
- package/src/components/A11yGroup/A11yGroup.android.tsx +0 -8
- package/src/components/A11yGroup/A11yGroup.ios.tsx +0 -11
- package/src/components/A11yGroup/A11yGroup.tsx +0 -5
- package/src/components/A11yUIContainer/A11yUIContainer.ios.tsx +0 -20
- package/src/components/A11yUIContainer/A11yUIContainer.tsx +0 -5
- package/src/nativeSpecs/A11yUIContainerNativeComponent.ts +0 -12
- package/src/nativeSpecs/A11yViewNativeComponent.ts +0 -36
- package/src/types/A11yGroup.types.ts +0 -9
- package/src/types/A11yIndex.types.ts +0 -21
- package/src/types/A11yLock.types.ts +0 -8
- package/src/types/A11yModule.types.ts +0 -7
- package/src/types/A11yUIContainerView.types.ts +0 -15
- package/src/types/A11yView.types.ts +0 -19
- /package/lib/commonjs/{types → components/A11yLock}/A11yLock.types.js +0 -0
- /package/lib/commonjs/{types → components/A11yView}/A11yView.types.js +0 -0
- /package/lib/module/{types → components/A11yLock}/A11yLock.types.js +0 -0
- /package/lib/module/{types → components/A11yView}/A11yView.types.js +0 -0
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import React, { useImperativeHandle, useRef } from 'react';
|
|
2
|
+
import type { ViewProps } from 'react-native';
|
|
2
3
|
import { A11ySequenceOrderContext } from '../../context/A11ySequenceOrderContext';
|
|
3
4
|
import A11yIndexView, {
|
|
4
5
|
Commands,
|
|
@@ -6,8 +7,113 @@ import A11yIndexView, {
|
|
|
6
7
|
import {
|
|
7
8
|
type A11yIndexProps,
|
|
8
9
|
A11yOrderTypeEnum,
|
|
10
|
+
type A11yOrderType,
|
|
9
11
|
type IndexCommands,
|
|
10
|
-
|
|
12
|
+
A11yContainerTypeEnum,
|
|
13
|
+
} from './A11yIndex.types';
|
|
14
|
+
|
|
15
|
+
type ScreenReaderCallbacks = Pick<
|
|
16
|
+
A11yIndexProps,
|
|
17
|
+
| 'onScreenReaderFocused'
|
|
18
|
+
| 'onScreenReaderSubViewFocusChange'
|
|
19
|
+
| 'onScreenReaderSubViewFocused'
|
|
20
|
+
| 'onScreenReaderSubViewBlurred'
|
|
21
|
+
| 'onScreenReaderDescendantFocusChanged'
|
|
22
|
+
>;
|
|
23
|
+
|
|
24
|
+
function useScreenReaderProps({
|
|
25
|
+
onScreenReaderFocused,
|
|
26
|
+
onScreenReaderSubViewFocusChange,
|
|
27
|
+
onScreenReaderSubViewFocused,
|
|
28
|
+
onScreenReaderSubViewBlurred,
|
|
29
|
+
onScreenReaderDescendantFocusChanged,
|
|
30
|
+
}: ScreenReaderCallbacks) {
|
|
31
|
+
const hasHandler = Boolean(
|
|
32
|
+
onScreenReaderSubViewBlurred ||
|
|
33
|
+
onScreenReaderSubViewFocused ||
|
|
34
|
+
onScreenReaderSubViewFocusChange
|
|
35
|
+
);
|
|
36
|
+
|
|
37
|
+
const onScreenReaderFocusChange = React.useCallback(
|
|
38
|
+
(event: { nativeEvent: { isFocused: boolean } }) => {
|
|
39
|
+
const { isFocused } = event.nativeEvent;
|
|
40
|
+
onScreenReaderSubViewFocusChange?.(isFocused);
|
|
41
|
+
if (isFocused) {
|
|
42
|
+
onScreenReaderSubViewFocused?.();
|
|
43
|
+
} else {
|
|
44
|
+
onScreenReaderSubViewBlurred?.();
|
|
45
|
+
}
|
|
46
|
+
},
|
|
47
|
+
[
|
|
48
|
+
onScreenReaderSubViewFocusChange,
|
|
49
|
+
onScreenReaderSubViewBlurred,
|
|
50
|
+
onScreenReaderSubViewFocused,
|
|
51
|
+
]
|
|
52
|
+
);
|
|
53
|
+
|
|
54
|
+
return {
|
|
55
|
+
onScreenReaderFocused,
|
|
56
|
+
onScreenReaderFocusChange: hasHandler
|
|
57
|
+
? onScreenReaderFocusChange
|
|
58
|
+
: undefined,
|
|
59
|
+
descendantFocusChangedEnabled: Boolean(
|
|
60
|
+
onScreenReaderDescendantFocusChanged
|
|
61
|
+
),
|
|
62
|
+
onScreenReaderDescendantFocusChanged,
|
|
63
|
+
};
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
function useFocusRef(ref: React.ForwardedRef<IndexCommands>) {
|
|
67
|
+
const localRef = useRef<React.ComponentRef<typeof A11yIndexView>>(null);
|
|
68
|
+
|
|
69
|
+
useImperativeHandle(ref, () => {
|
|
70
|
+
const native = localRef.current as unknown as Record<string, unknown>;
|
|
71
|
+
|
|
72
|
+
return new Proxy({} as IndexCommands, {
|
|
73
|
+
get(_target, prop: string) {
|
|
74
|
+
if (prop === 'focus') {
|
|
75
|
+
return () => {
|
|
76
|
+
if (localRef.current) {
|
|
77
|
+
// @ts-expect-error Commands.focus type is too generic in codegen
|
|
78
|
+
Commands.focus(localRef.current);
|
|
79
|
+
}
|
|
80
|
+
};
|
|
81
|
+
}
|
|
82
|
+
return native?.[prop];
|
|
83
|
+
},
|
|
84
|
+
});
|
|
85
|
+
});
|
|
86
|
+
|
|
87
|
+
return localRef;
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
function useOrderProps(
|
|
91
|
+
index: number | undefined,
|
|
92
|
+
orderType: A11yOrderType | undefined,
|
|
93
|
+
importantForAccessibilityProp: ViewProps['importantForAccessibility']
|
|
94
|
+
) {
|
|
95
|
+
const orderKey = React.useContext(A11ySequenceOrderContext);
|
|
96
|
+
const hasOrderInfo = typeof index === 'number' || !!orderKey;
|
|
97
|
+
|
|
98
|
+
if (hasOrderInfo && !orderKey) {
|
|
99
|
+
throw new Error(
|
|
100
|
+
'<A11y.Index> element should be used inside of <A11y.Order> container'
|
|
101
|
+
);
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
const resolvedOrderType = orderType ?? 'default';
|
|
105
|
+
const importantForAccessibilityFallback =
|
|
106
|
+
resolvedOrderType === 'default' ? ('yes' as const) : undefined;
|
|
107
|
+
|
|
108
|
+
return {
|
|
109
|
+
orderKey,
|
|
110
|
+
orderFocusType: hasOrderInfo
|
|
111
|
+
? A11yOrderTypeEnum[resolvedOrderType]
|
|
112
|
+
: undefined,
|
|
113
|
+
importantForAccessibility:
|
|
114
|
+
importantForAccessibilityProp ?? importantForAccessibilityFallback,
|
|
115
|
+
};
|
|
116
|
+
}
|
|
11
117
|
|
|
12
118
|
export const A11yIndex = React.memo(
|
|
13
119
|
React.forwardRef<IndexCommands, A11yIndexProps>(
|
|
@@ -15,72 +121,58 @@ export const A11yIndex = React.memo(
|
|
|
15
121
|
{
|
|
16
122
|
children,
|
|
17
123
|
index,
|
|
18
|
-
orderType
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
onScreenReaderSubViewBlurred,
|
|
124
|
+
orderType,
|
|
125
|
+
a11yUIContainer,
|
|
126
|
+
shouldGroupAccessibilityChildren,
|
|
22
127
|
...props
|
|
23
128
|
},
|
|
24
129
|
ref
|
|
25
130
|
) => {
|
|
26
|
-
const
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
if (event.nativeEvent.isFocused) {
|
|
36
|
-
onScreenReaderSubViewFocused?.();
|
|
37
|
-
} else {
|
|
38
|
-
onScreenReaderSubViewBlurred?.();
|
|
39
|
-
}
|
|
40
|
-
},
|
|
41
|
-
[
|
|
42
|
-
onScreenReaderSubViewFocusChange,
|
|
43
|
-
onScreenReaderSubViewBlurred,
|
|
44
|
-
onScreenReaderSubViewFocused,
|
|
45
|
-
]
|
|
46
|
-
);
|
|
131
|
+
const {
|
|
132
|
+
onScreenReaderFocused,
|
|
133
|
+
onScreenReaderSubViewFocusChange,
|
|
134
|
+
onScreenReaderSubViewFocused,
|
|
135
|
+
onScreenReaderSubViewBlurred,
|
|
136
|
+
onScreenReaderDescendantFocusChanged,
|
|
137
|
+
importantForAccessibility: importantForAccessibilityProp,
|
|
138
|
+
...viewProps
|
|
139
|
+
} = props;
|
|
47
140
|
|
|
48
|
-
const
|
|
49
|
-
?
|
|
141
|
+
const containerTypeValue = a11yUIContainer
|
|
142
|
+
? A11yContainerTypeEnum[a11yUIContainer]
|
|
50
143
|
: undefined;
|
|
51
144
|
|
|
52
|
-
const
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
145
|
+
const shouldGroupChildrenValue =
|
|
146
|
+
shouldGroupAccessibilityChildren === undefined
|
|
147
|
+
? -1
|
|
148
|
+
: shouldGroupAccessibilityChildren
|
|
149
|
+
? 1
|
|
150
|
+
: 0;
|
|
58
151
|
|
|
59
|
-
|
|
60
|
-
|
|
152
|
+
const screenReaderNativeProps = useScreenReaderProps({
|
|
153
|
+
onScreenReaderFocused,
|
|
154
|
+
onScreenReaderSubViewFocusChange,
|
|
155
|
+
onScreenReaderSubViewFocused,
|
|
156
|
+
onScreenReaderSubViewBlurred,
|
|
157
|
+
onScreenReaderDescendantFocusChanged,
|
|
158
|
+
});
|
|
61
159
|
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
if (indexRef.current) {
|
|
65
|
-
Commands.focus(indexRef.current);
|
|
66
|
-
}
|
|
67
|
-
},
|
|
68
|
-
}));
|
|
160
|
+
const { orderKey, orderFocusType, importantForAccessibility } =
|
|
161
|
+
useOrderProps(index, orderType, importantForAccessibilityProp);
|
|
69
162
|
|
|
70
|
-
const
|
|
71
|
-
orderType === 'default' ? 'yes' : undefined;
|
|
163
|
+
const localRef = useFocusRef(ref);
|
|
72
164
|
|
|
73
165
|
return (
|
|
74
166
|
<A11yIndexView
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
|
|
167
|
+
ref={localRef as React.Ref<any>}
|
|
168
|
+
{...viewProps}
|
|
169
|
+
containerType={containerTypeValue}
|
|
170
|
+
shouldGroupAccessibilityChildren={shouldGroupChildrenValue}
|
|
171
|
+
importantForAccessibility={importantForAccessibility}
|
|
172
|
+
orderFocusType={orderFocusType}
|
|
80
173
|
orderIndex={index}
|
|
81
174
|
orderKey={orderKey}
|
|
82
|
-
{...
|
|
83
|
-
onScreenReaderFocusChange={onScreenReaderHandlerProp}
|
|
175
|
+
{...screenReaderNativeProps}
|
|
84
176
|
>
|
|
85
177
|
{children}
|
|
86
178
|
</A11yIndexView>
|
|
@@ -0,0 +1,124 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import type { NativeSyntheticEvent, View, ViewProps } from 'react-native';
|
|
3
|
+
import type { ScreenReaderDescendantFocusChanged } from '../../nativeSpecs/A11yIndexNativeComponent';
|
|
4
|
+
|
|
5
|
+
/** Ref handle for {@link A11y.Index} — exposes `focus()` to move screen reader focus programmatically. */
|
|
6
|
+
export type IndexCommands = Omit<React.ComponentRef<typeof View>, 'focus'> & {
|
|
7
|
+
/** Moves screen reader focus to this element. */
|
|
8
|
+
focus: () => void;
|
|
9
|
+
};
|
|
10
|
+
|
|
11
|
+
/** Numeric backing values for {@link A11yOrderType}. Kept for consumers who need the raw number. */
|
|
12
|
+
export const A11yOrderTypeEnum = {
|
|
13
|
+
default: 0,
|
|
14
|
+
child: 1,
|
|
15
|
+
subview: 2,
|
|
16
|
+
} as const;
|
|
17
|
+
|
|
18
|
+
/** @internal Numeric backing values for {@link A11yUIContainerType}. */
|
|
19
|
+
export const A11yContainerTypeEnum = {
|
|
20
|
+
none: 0,
|
|
21
|
+
table: 1,
|
|
22
|
+
list: 2,
|
|
23
|
+
landmark: 3,
|
|
24
|
+
group: 4,
|
|
25
|
+
} as const;
|
|
26
|
+
|
|
27
|
+
/**
|
|
28
|
+
* iOS only — sets `UIAccessibilityContainerType` on the wrapping view.
|
|
29
|
+
* Tells VoiceOver what kind of container this is: `'list'`, `'table'`, `'landmark'`, etc.
|
|
30
|
+
*/
|
|
31
|
+
export type A11yUIContainerType = keyof typeof A11yContainerTypeEnum;
|
|
32
|
+
|
|
33
|
+
/**
|
|
34
|
+
* Controls which element receives screen reader focus for this index slot.
|
|
35
|
+
*
|
|
36
|
+
* - `'default'` — the `A11y.Index` view itself
|
|
37
|
+
* - `'child'` — the first accessible child (useful when the index wrapper has no visual presence)
|
|
38
|
+
* - `'subview'` — first accessible child via an older traversal path
|
|
39
|
+
*/
|
|
40
|
+
export type A11yOrderType = keyof typeof A11yOrderTypeEnum;
|
|
41
|
+
|
|
42
|
+
/** The native event payload emitted by `onScreenReaderDescendantFocusChanged`. */
|
|
43
|
+
export type ScreenReaderDescendantFocusChangedEvent =
|
|
44
|
+
NativeSyntheticEvent<ScreenReaderDescendantFocusChanged>;
|
|
45
|
+
|
|
46
|
+
export type A11yIndexProps = ViewProps & {
|
|
47
|
+
children: React.ReactNode;
|
|
48
|
+
|
|
49
|
+
/**
|
|
50
|
+
* Numeric position of this element in the parent `A11y.Order` sequence.
|
|
51
|
+
* Lower numbers are focused first; ties are resolved by render order.
|
|
52
|
+
*/
|
|
53
|
+
index?: number;
|
|
54
|
+
|
|
55
|
+
/**
|
|
56
|
+
* Controls which element VoiceOver / TalkBack actually focuses for this slot.
|
|
57
|
+
*
|
|
58
|
+
* - `'default'` — the `A11y.Index` view itself receives focus
|
|
59
|
+
* - `'child'` — the first accessible descendant receives focus (useful when
|
|
60
|
+
* the index wrapper has no visual presence of its own)
|
|
61
|
+
* - `'subview'` — focuses the first direct child view rather than the first accessible descendant
|
|
62
|
+
*
|
|
63
|
+
* Defaults to `'default'`.
|
|
64
|
+
*/
|
|
65
|
+
orderType?: A11yOrderType;
|
|
66
|
+
|
|
67
|
+
/**
|
|
68
|
+
* iOS only — sets `UIAccessibilityContainerType` on the wrapping view.
|
|
69
|
+
* Helps VoiceOver understand the semantic role of the container:
|
|
70
|
+
* `'list'`, `'table'`, `'landmark'`, etc.
|
|
71
|
+
*
|
|
72
|
+
* @platform ios
|
|
73
|
+
*/
|
|
74
|
+
a11yUIContainer?: A11yUIContainerType;
|
|
75
|
+
|
|
76
|
+
/**
|
|
77
|
+
* iOS only — maps to `shouldGroupAccessibilityChildren` on the native view.
|
|
78
|
+
* Determines whether VoiceOver treats descendants as one grouped unit
|
|
79
|
+
* or navigates them individually.
|
|
80
|
+
*
|
|
81
|
+
* - `true` — VoiceOver focuses the wrapper as a single element and builds
|
|
82
|
+
* a combined label from its children.
|
|
83
|
+
* - `false` — descendants stay individually focusable even when iOS would
|
|
84
|
+
* otherwise collapse them.
|
|
85
|
+
* - omitted — defers to the platform default.
|
|
86
|
+
*
|
|
87
|
+
* @platform ios
|
|
88
|
+
*/
|
|
89
|
+
shouldGroupAccessibilityChildren?: boolean;
|
|
90
|
+
|
|
91
|
+
/**
|
|
92
|
+
* When `true`, requests screen reader focus on this element immediately after mount.
|
|
93
|
+
*/
|
|
94
|
+
autoFocus?: boolean;
|
|
95
|
+
|
|
96
|
+
/**
|
|
97
|
+
* Called when the screen reader focuses this element directly (not a descendant).
|
|
98
|
+
*/
|
|
99
|
+
onScreenReaderFocused?: () => void;
|
|
100
|
+
|
|
101
|
+
/**
|
|
102
|
+
* Called when screen reader focus enters or leaves any descendant.
|
|
103
|
+
* Receives `true` on enter and `false` on leave.
|
|
104
|
+
*/
|
|
105
|
+
onScreenReaderSubViewFocusChange?: (isFocused: boolean) => void;
|
|
106
|
+
|
|
107
|
+
/**
|
|
108
|
+
* Called when screen reader focus enters any descendant.
|
|
109
|
+
*/
|
|
110
|
+
onScreenReaderSubViewFocused?: () => void;
|
|
111
|
+
|
|
112
|
+
/**
|
|
113
|
+
* Called when screen reader focus leaves any descendant.
|
|
114
|
+
*/
|
|
115
|
+
onScreenReaderSubViewBlurred?: () => void;
|
|
116
|
+
|
|
117
|
+
/**
|
|
118
|
+
* Called with the full native event when screen reader focus changes on any descendant.
|
|
119
|
+
* Use this when you need the `nativeId` of the focused element.
|
|
120
|
+
*/
|
|
121
|
+
onScreenReaderDescendantFocusChanged?: (
|
|
122
|
+
e: ScreenReaderDescendantFocusChangedEvent
|
|
123
|
+
) => void;
|
|
124
|
+
};
|
|
@@ -1,9 +1,6 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
2
|
import { forwardRef, useImperativeHandle, useRef } from 'react';
|
|
3
|
-
import type {
|
|
4
|
-
IndexCommands,
|
|
5
|
-
A11yIndexProps,
|
|
6
|
-
} from '../../types/A11yIndex.types';
|
|
3
|
+
import type { A11yIndexProps } from './A11yIndex.types';
|
|
7
4
|
import { UIManager } from 'react-native';
|
|
8
5
|
import { View } from 'react-native';
|
|
9
6
|
|
|
@@ -11,17 +8,15 @@ const WebUiManager = UIManager as unknown as {
|
|
|
11
8
|
focus: (v: View) => void;
|
|
12
9
|
};
|
|
13
10
|
|
|
14
|
-
export const A11yIndex = forwardRef<
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
}));
|
|
11
|
+
export const A11yIndex = forwardRef<{}, A11yIndexProps>((props, ref) => {
|
|
12
|
+
const viewRef = useRef<View>(null);
|
|
13
|
+
useImperativeHandle(ref, () => ({
|
|
14
|
+
focus: () => {
|
|
15
|
+
if (viewRef.current) {
|
|
16
|
+
WebUiManager.focus(viewRef.current);
|
|
17
|
+
}
|
|
18
|
+
},
|
|
19
|
+
}));
|
|
24
20
|
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
);
|
|
21
|
+
return <View {...props} ref={viewRef as any} />;
|
|
22
|
+
});
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
2
|
import A11yLockNativeComponent from '../../../nativeSpecs/A11yLockNativeComponent';
|
|
3
|
-
import type { A11yLockProps } from '
|
|
3
|
+
import type { A11yLockProps } from '../A11yLock.types';
|
|
4
4
|
|
|
5
5
|
export const A11yBaseLock = React.memo<A11yLockProps>(
|
|
6
6
|
({
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
|
-
import type { A11yLockProps } from '
|
|
2
|
+
import type { A11yLockProps } from '../A11yLock.types';
|
|
3
3
|
import { A11yBaseLock } from '../A11yBaseLock/A11yBaseLock';
|
|
4
4
|
import { A11yFrameProvider } from '../../../context/A11yFocusFrameProviderContext';
|
|
5
5
|
|
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
|
-
import { View
|
|
2
|
+
import { View } from 'react-native';
|
|
3
3
|
import { A11yFrameProvider } from '../../../context/A11yFocusFrameProviderContext';
|
|
4
|
+
import type { A11yFocusFrameProps } from '../A11yLock.types';
|
|
4
5
|
|
|
5
|
-
export const A11yFocusFrame = (props:
|
|
6
|
+
export const A11yFocusFrame = (props: A11yFocusFrameProps) => (
|
|
6
7
|
<A11yFrameProvider>
|
|
7
8
|
<View {...props} />
|
|
8
9
|
</A11yFrameProvider>
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
|
-
import type { A11yLockProps } from '
|
|
2
|
+
import type { A11yLockProps } from '../A11yLock.types';
|
|
3
3
|
import { A11yBaseLock } from '../A11yBaseLock/A11yBaseLock';
|
|
4
4
|
import { A11yFocusTrapMountWrapper } from './A11yFocusTrapMountWrapper';
|
|
5
5
|
|
|
@@ -1,13 +1,13 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
2
|
import { View } from 'react-native';
|
|
3
|
-
import type {
|
|
3
|
+
import type { A11yFocusTrapProps } from '../A11yLock.types';
|
|
4
4
|
import { A11yFocusTrapMountWrapper } from './A11yFocusTrapMountWrapper';
|
|
5
5
|
import { A11yBaseLock } from '../A11yBaseLock/A11yBaseLock';
|
|
6
6
|
|
|
7
7
|
export const A11yFocusTrap = ({
|
|
8
8
|
forceLock = false,
|
|
9
9
|
...props
|
|
10
|
-
}:
|
|
10
|
+
}: A11yFocusTrapProps) => {
|
|
11
11
|
if (forceLock) {
|
|
12
12
|
return (
|
|
13
13
|
<A11yFocusTrapMountWrapper>
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import type { ViewProps } from 'react-native';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Props for {@link A11y.FocusTrap} — confines VoiceOver / TalkBack focus to this subtree.
|
|
5
|
+
* Useful for modals, bottom sheets, and overlays where focus must not leak out.
|
|
6
|
+
*/
|
|
7
|
+
export type A11yFocusTrapProps = ViewProps & {
|
|
8
|
+
/**
|
|
9
|
+
* When `true`, the focus trap is inactive and the screen reader can navigate
|
|
10
|
+
* freely outside this container.
|
|
11
|
+
*
|
|
12
|
+
* Defaults to `false`.
|
|
13
|
+
*/
|
|
14
|
+
lockDisabled?: boolean;
|
|
15
|
+
|
|
16
|
+
/**
|
|
17
|
+
* When `true`, focus is moved inside the trap immediately on mount rather than
|
|
18
|
+
* waiting for the next accessibility navigation gesture.
|
|
19
|
+
* Use this for programmatically-opened modals and sheets.
|
|
20
|
+
*
|
|
21
|
+
* Defaults to `false`.
|
|
22
|
+
*/
|
|
23
|
+
forceLock?: boolean;
|
|
24
|
+
};
|
|
25
|
+
|
|
26
|
+
/**
|
|
27
|
+
* Props for {@link A11y.FocusFrame} — detects when screen reader focus escapes
|
|
28
|
+
* this subtree, enabling focus-leak detection in complex UIs.
|
|
29
|
+
*/
|
|
30
|
+
export type A11yFocusFrameProps = ViewProps;
|
|
31
|
+
|
|
32
|
+
/** @internal Full props accepted by the native lock component. Not part of the public API. */
|
|
33
|
+
export type A11yLockProps = ViewProps & {
|
|
34
|
+
componentType?: number;
|
|
35
|
+
containerKey?: string;
|
|
36
|
+
lockDisabled?: boolean;
|
|
37
|
+
forceLock?: boolean;
|
|
38
|
+
};
|
|
@@ -1,9 +1,11 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
|
-
import type { ViewProps } from 'react-native';
|
|
3
2
|
import { A11ySequenceOrderContext } from '../../context/A11ySequenceOrderContext';
|
|
4
3
|
import A11yOrderNativeComponent from '../../nativeSpecs/A11yOrderNativeComponent';
|
|
4
|
+
import type { A11yOrderProps } from './A11yOrder.types';
|
|
5
5
|
|
|
6
|
-
export
|
|
6
|
+
export type { A11yOrderProps };
|
|
7
|
+
|
|
8
|
+
export const A11yOrder = React.memo<A11yOrderProps>((props) => {
|
|
7
9
|
const orderKey = React.useId();
|
|
8
10
|
return (
|
|
9
11
|
<A11ySequenceOrderContext.Provider value={orderKey}>
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { ViewProps } from 'react-native';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Props for {@link A11y.Order} — a container that defines an explicit screen reader
|
|
5
|
+
* focus sequence for its `A11y.Index` children.
|
|
6
|
+
*
|
|
7
|
+
* All standard `View` props are accepted and forwarded to the underlying native view.
|
|
8
|
+
* The `orderKey` that links child `A11y.Index` elements to this container is generated
|
|
9
|
+
* internally via `React.useId` and requires no prop.
|
|
10
|
+
*/
|
|
11
|
+
export type A11yOrderProps = ViewProps;
|
|
@@ -1,22 +1,16 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
|
-
import { type ViewProps } from 'react-native';
|
|
3
2
|
import A11yPaneTitleNative from '../../nativeSpecs/A11yPaneTitleNativeComponent';
|
|
3
|
+
import type {
|
|
4
|
+
A11yPaneTitleProps,
|
|
5
|
+
A11yPaneType,
|
|
6
|
+
A11yScreenChangeProps,
|
|
7
|
+
} from './A11yPaneTitle.types';
|
|
4
8
|
|
|
5
|
-
|
|
6
|
-
activity
|
|
7
|
-
pane
|
|
8
|
-
announce
|
|
9
|
-
}
|
|
10
|
-
|
|
11
|
-
type PaneType = keyof typeof PaneEnum;
|
|
12
|
-
|
|
13
|
-
type A11yPaneTitleType = React.PropsWithChildren<{
|
|
14
|
-
title?: string;
|
|
15
|
-
detachMessage?: string;
|
|
16
|
-
type?: PaneType;
|
|
17
|
-
withFocusRestore?: boolean;
|
|
18
|
-
displayed?: boolean;
|
|
19
|
-
}>;
|
|
9
|
+
const PaneTypeValue: Record<A11yPaneType, number> = {
|
|
10
|
+
activity: 0,
|
|
11
|
+
pane: 1,
|
|
12
|
+
announce: 2,
|
|
13
|
+
};
|
|
20
14
|
|
|
21
15
|
export const A11yPaneTitle = ({
|
|
22
16
|
title,
|
|
@@ -25,21 +19,21 @@ export const A11yPaneTitle = ({
|
|
|
25
19
|
children,
|
|
26
20
|
displayed,
|
|
27
21
|
withFocusRestore = true,
|
|
28
|
-
}:
|
|
22
|
+
}: A11yPaneTitleProps) => {
|
|
29
23
|
if (displayed === false) return null;
|
|
30
24
|
|
|
31
25
|
return (
|
|
32
26
|
<A11yPaneTitleNative
|
|
33
27
|
title={title}
|
|
34
28
|
detachMessage={detachMessage}
|
|
35
|
-
type={
|
|
29
|
+
type={PaneTypeValue[type]}
|
|
36
30
|
children={children}
|
|
37
31
|
withFocusRestore={withFocusRestore}
|
|
38
32
|
/>
|
|
39
33
|
);
|
|
40
34
|
};
|
|
41
35
|
|
|
42
|
-
export const A11yScreenChange = (props:
|
|
36
|
+
export const A11yScreenChange = (props: A11yScreenChangeProps) => (
|
|
43
37
|
<A11yPaneTitle
|
|
44
38
|
title={props.title}
|
|
45
39
|
detachMessage={props.detachMessage}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Controls the native accessibility announcement mechanism.
|
|
5
|
+
*
|
|
6
|
+
* - `'pane'` — layout-changed notification with a title (default, use for panels/sheets)
|
|
7
|
+
* - `'activity'` — screen-change notification (use for full-screen transitions)
|
|
8
|
+
* - `'announce'` — plain announcement with no focus shift (use for status updates)
|
|
9
|
+
*/
|
|
10
|
+
export type A11yPaneType = 'activity' | 'pane' | 'announce';
|
|
11
|
+
|
|
12
|
+
/**
|
|
13
|
+
* Props for {@link A11y.PaneTitle} — announces a screen or panel transition to
|
|
14
|
+
* VoiceOver / TalkBack and optionally restores focus when the view unmounts.
|
|
15
|
+
*/
|
|
16
|
+
export type A11yPaneTitleProps = React.PropsWithChildren<{
|
|
17
|
+
/**
|
|
18
|
+
* The title announced to the screen reader when this component mounts.
|
|
19
|
+
*/
|
|
20
|
+
title?: string;
|
|
21
|
+
|
|
22
|
+
/**
|
|
23
|
+
* A message announced to the screen reader when this component unmounts.
|
|
24
|
+
* Use to signal the end of a flow, e.g. `"Modal closed"` or `"Drawer closed"`.
|
|
25
|
+
*/
|
|
26
|
+
detachMessage?: string;
|
|
27
|
+
|
|
28
|
+
/**
|
|
29
|
+
* Controls the native announcement mechanism. Defaults to `'pane'`.
|
|
30
|
+
*
|
|
31
|
+
* - `'pane'` — layout-changed notification with a title (panels, sheets)
|
|
32
|
+
* - `'activity'` — screen-change notification (full-screen navigation)
|
|
33
|
+
* - `'announce'` — plain announcement with no focus shift (status updates)
|
|
34
|
+
*/
|
|
35
|
+
type?: A11yPaneType;
|
|
36
|
+
|
|
37
|
+
/**
|
|
38
|
+
* When `true`, VoiceOver / TalkBack restores focus to the previously focused
|
|
39
|
+
* element when this component unmounts.
|
|
40
|
+
*
|
|
41
|
+
* Defaults to `true`.
|
|
42
|
+
*/
|
|
43
|
+
withFocusRestore?: boolean;
|
|
44
|
+
|
|
45
|
+
/**
|
|
46
|
+
* When `false`, the component renders nothing and posts no announcement.
|
|
47
|
+
* Use this to conditionally suppress the view without unmounting its subtree.
|
|
48
|
+
*
|
|
49
|
+
* Defaults to `true`.
|
|
50
|
+
*/
|
|
51
|
+
displayed?: boolean;
|
|
52
|
+
}>;
|
|
53
|
+
|
|
54
|
+
/**
|
|
55
|
+
* Props for {@link A11y.ScreenChange} — shorthand for `A11y.PaneTitle` with
|
|
56
|
+
* `type="activity"` pre-set for full-screen navigation transitions.
|
|
57
|
+
*/
|
|
58
|
+
export type A11yScreenChangeProps = Omit<A11yPaneTitleProps, 'type'>;
|