gecko-dev/accessible/mac/MOXAccessibleProtocol.h
2020-08-20 22:12:23 +00:00

386 lines
9.7 KiB
Objective-C

/* -*- Mode: Objective-C; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
@protocol MOXTextMarkerSupport;
// This protocol's primary use is for abstracting the NSAccessibility informal protocol
// into a formal internal API. Conforming classes get to choose a subset of the optional
// methods to implement. Those methods will be mapped to NSAccessibility attributes or actions.
// A conforming class can implement moxBlockSelector to control which of its implemented
// methods should be exposed to NSAccessibility.
@protocol MOXAccessible
// The deepest descendant of the accessible subtree that contains the specified point.
// Forwarded from accessibilityHitTest.
- (id _Nullable)moxHitTest:(NSPoint)point;
// The deepest descendant of the accessible subtree that has the focus.
// Forwarded from accessibilityFocusedUIElement.
- (id _Nullable)moxFocusedUIElement;
// Sends a notification to any observing assistive applications.
- (void)moxPostNotification:(NSString* _Nonnull)notification;
- (void)moxPostNotification:(NSString* _Nonnull)notification
withUserInfo:(NSDictionary* _Nullable)userInfo;
// Return YES if selector should be considered not supported.
// Used in implementations such as:
// - accessibilityAttributeNames
// - accessibilityActionNames
// - accessibilityIsAttributeSettable
- (BOOL)moxBlockSelector:(SEL _Nonnull)selector;
// Returns a list of all children, doesn't do ignore filtering.
- (NSArray* _Nullable)moxChildren;
// Returns our parent, doesn't do ignore filtering.
- (id<mozAccessible> _Nullable)moxParent;
// This is called by isAccessibilityElement. If a subclass wants
// to alter the isAccessibilityElement return value, it must
// override this and not isAccessibilityElement directly.
- (BOOL)moxIgnoreWithParent:(id<MOXAccessible> _Nullable)parent;
// Should the child be ignored. This allows subclasses to determine
// what kinds of accessibles are valid children. This causes the child
// to be skipped, but the unignored descendants will be added to the
// container in the default children getter.
- (BOOL)moxIgnoreChild:(id<MOXAccessible> _Nullable)child;
// Return text delegate if it exists.
- (id<MOXTextMarkerSupport> _Nullable)moxTextMarkerDelegate;
@optional
#pragma mark - AttributeGetters
// AXChildren
- (NSArray* _Nullable)moxUnignoredChildren;
// AXParent
- (id _Nullable)moxUnignoredParent;
// AXRole
- (NSString* _Nullable)moxRole;
// AXRoleDescription
- (NSString* _Nullable)moxRoleDescription;
// AXSubrole
- (NSString* _Nullable)moxSubrole;
// AXTitle
- (NSString* _Nullable)moxTitle;
// AXDescription
- (NSString* _Nullable)moxLabel;
// AXHelp
- (NSString* _Nullable)moxHelp;
// AXValue
- (id _Nullable)moxValue;
// AXSize
- (NSValue* _Nullable)moxSize;
// AXPosition
- (NSValue* _Nullable)moxPosition;
// AXEnabled
- (NSNumber* _Nullable)moxEnabled;
// AXFocused
- (NSNumber* _Nullable)moxFocused;
// AXWindow
- (id _Nullable)moxWindow;
// AXTitleUIElement
- (id _Nullable)moxTitleUIElement;
// AXTopLevelUIElement
- (id _Nullable)moxTopLevelUIElement;
// AXHasPopup
- (NSNumber* _Nullable)moxHasPopup;
// AXARIACurrent
- (NSString* _Nullable)moxARIACurrent;
// AXSelected
- (NSNumber* _Nullable)moxSelected;
// AXRequired
- (NSNumber* _Nullable)moxRequired;
// AXDOMIdentifier
- (NSString* _Nullable)moxDOMIdentifier;
// AXURL
- (NSURL* _Nullable)moxURL;
// AXPopupValue
- (NSString* _Nullable)moxPopupValue;
// AXVisited
- (NSNumber* _Nullable)moxVisited;
// AXExpanded
- (NSNumber* _Nullable)moxExpanded;
// AXMain
- (NSNumber* _Nullable)moxMain;
// AXMinimized
- (NSNumber* _Nullable)moxMinimized;
// AXSelectedChildren
- (NSArray* _Nullable)moxSelectedChildren;
// AXTabs
- (NSArray* _Nullable)moxTabs;
// AXContents
- (NSArray* _Nullable)moxContents;
// AXOrientation
- (NSString* _Nullable)moxOrientation;
// AXMenuItemMarkChar
- (NSString* _Nullable)moxMenuItemMarkChar;
// AXLoaded
- (NSNumber* _Nullable)moxLoaded;
// AXLoadingProgress
- (NSNumber* _Nullable)moxLoadingProgress;
// Webkit also implements the following:
// // AXCaretBrowsingEnabled
// - (NSString* _Nullable)moxCaretBrowsingEnabled;
// // AXLayoutCount
// - (NSString* _Nullable)moxLayoutCount;
// // AXWebSessionID
// - (NSString* _Nullable)moxWebSessionID;
// // AXPreventKeyboardDOMEventDispatch
// - (NSString* _Nullable)moxPreventKeyboardDOMEventDispatch;
// Table Attributes
// AXRowCount
- (NSNumber* _Nullable)moxRowCount;
// AXColumnCount
- (NSNumber* _Nullable)moxColumnCount;
// AXRows
- (NSArray* _Nullable)moxRows;
// AXColumns
- (NSArray* _Nullable)moxColumns;
// AXIndex
- (NSNumber* _Nullable)moxIndex;
// AXRowIndexRange
- (NSValue* _Nullable)moxRowIndexRange;
// AXColumnIndexRange
- (NSValue* _Nullable)moxColumnIndexRange;
// AXRowHeaderUIElements
- (NSArray* _Nullable)moxRowHeaderUIElements;
// AXColumnHeaderUIElements
- (NSArray* _Nullable)moxColumnHeaderUIElements;
// Math Attributes
// AXMathRootRadicand
- (id _Nullable)moxMathRootRadicand;
// AXMathRootIndex
- (id _Nullable)moxMathRootIndex;
// AXMathFractionNumerator
- (id _Nullable)moxMathFractionNumerator;
// AXMathFractionDenominator
- (id _Nullable)moxMathFractionDenominator;
// AXMathLineThickness
- (NSNumber* _Nullable)moxMathLineThickness;
// AXMathBase
- (id _Nullable)moxMathBase;
// AXMathSubscript
- (id _Nullable)moxMathSubscript;
// AXMathSuperscript
- (id _Nullable)moxMathSuperscript;
// AXMathUnder
- (id _Nullable)moxMathUnder;
// AXMathOver
- (id _Nullable)moxMathOver;
// AXInvalid
- (NSString* _Nullable)moxInvalid;
// AXSelectedText
- (NSString* _Nullable)moxSelectedText;
// AXSelectedTextRange
- (NSValue* _Nullable)moxSelectedTextRange;
// AXNumberOfCharacters
- (NSNumber* _Nullable)moxNumberOfCharacters;
// AXVisibleCharacterRange
- (NSValue* _Nullable)moxVisibleCharacterRange;
// AXInsertionPointLineNumber
- (NSNumber* _Nullable)moxInsertionPointLineNumber;
#pragma mark - AttributeSetters
// AXValue
- (void)moxSetValue:(id _Nullable)value;
// AXFocused
- (void)moxSetFocused:(NSNumber* _Nullable)focused;
// AXSelected
- (void)moxSetSelected:(NSNumber* _Nullable)selected;
// AXSelectedChildren
- (void)moxSetSelectedChildren:(NSArray* _Nullable)selectedChildren;
// AXSelectedText
- (void)moxSetSelectedText:(NSString* _Nullable)selectedText;
// AXSelectedTextRange
- (void)moxSetSelectedTextRange:(NSValue* _Nullable)selectedTextRange;
// AXVisibleCharacterRange
- (void)moxSetVisibleCharacterRange:(NSValue* _Nullable)visibleCharacterRange;
#pragma mark - Actions
// AXPress
- (void)moxPerformPress;
// AXShowMenu
- (void)moxPerformShowMenu;
// AXScrollToVisible
- (void)moxPerformScrollToVisible;
// AXIncrement
- (void)moxPerformIncrement;
// AXDecrement
- (void)moxPerformDecrement;
#pragma mark - ParameterizedAttributeGetters
// AXLineForIndex
- (NSNumber* _Nullable)moxLineForIndex:(NSNumber* _Nonnull)index;
// AXRangeForLine
- (NSValue* _Nullable)moxRangeForLine:(NSNumber* _Nonnull)line;
// AXStringForRange
- (NSString* _Nullable)moxStringForRange:(NSValue* _Nonnull)range;
// AXRangeForPosition
- (NSValue* _Nullable)moxRangeForPosition:(NSValue* _Nonnull)position;
// AXRangeForIndex
- (NSValue* _Nullable)moxRangeForIndex:(NSNumber* _Nonnull)index;
// AXBoundsForRange
- (NSValue* _Nullable)moxBoundsForRange:(NSValue* _Nonnull)range;
// AXRTFForRange
- (NSData* _Nullable)moxRTFForRange:(NSValue* _Nonnull)range;
// AXStyleRangeForIndex
- (NSValue* _Nullable)moxStyleRangeForIndex:(NSNumber* _Nonnull)index;
// AttributedStringForRange
- (NSAttributedString* _Nullable)moxAttributedStringForRange:(NSValue* _Nonnull)range;
// AXUIElementsForSearchPredicate
- (NSArray* _Nullable)moxUIElementsForSearchPredicate:(NSDictionary* _Nonnull)searchPredicate;
// AXUIElementCountForSearchPredicate
- (NSNumber* _Nullable)moxUIElementCountForSearchPredicate:(NSDictionary* _Nonnull)searchPredicate;
// AXCellForColumnAndRow
- (id _Nullable)moxCellForColumnAndRow:(NSArray* _Nonnull)columnAndRow;
@end
// This protocol maps text marker and text marker range parameters to
// methods. It is implemented by a delegate of a MOXAccessible.
@protocol MOXTextMarkerSupport
#pragma mark - TextAttributeGetters
// AXStartTextMarker
- (id _Nullable)moxStartTextMarker;
// AXEndTextMarker
- (id _Nullable)moxEndTextMarker;
// AXSelectedTextMarkerRange
- (id _Nullable)moxSelectedTextMarkerRange;
#pragma mark - ParameterizedTextAttributeGetters
// AXLengthForTextMarkerRange
- (NSNumber* _Nullable)moxLengthForTextMarkerRange:(id _Nonnull)textMarkerRange;
// AXStringForTextMarkerRange
- (NSString* _Nullable)moxStringForTextMarkerRange:(id _Nonnull)textMarkerRange;
// AXTextMarkerRangeForUnorderedTextMarkers
- (id _Nullable)moxTextMarkerRangeForUnorderedTextMarkers:(NSArray* _Nonnull)textMarkers;
// AXLeftWordTextMarkerRangeForTextMarker
- (id _Nullable)moxLeftWordTextMarkerRangeForTextMarker:(id _Nonnull)textMarker;
// AXRightWordTextMarkerRangeForTextMarker
- (id _Nullable)moxRightWordTextMarkerRangeForTextMarker:(id _Nonnull)textMarker;
// AXStartTextMarkerForTextMarkerRange
- (id _Nullable)moxStartTextMarkerForTextMarkerRange:(id _Nonnull)textMarkerRange;
// AXEndTextMarkerForTextMarkerRange
- (id _Nullable)moxEndTextMarkerForTextMarkerRange:(id _Nonnull)textMarkerRange;
// AXNextTextMarkerForTextMarker
- (id _Nullable)moxNextTextMarkerForTextMarker:(id _Nonnull)textMarker;
// AXPreviousTextMarkerForTextMarker
- (id _Nullable)moxPreviousTextMarkerForTextMarker:(id _Nonnull)textMarker;
// AXAttributedStringForTextMarkerRange
- (NSAttributedString* _Nullable)moxAttributedStringForTextMarkerRange:(id _Nonnull)textMarkerRange;
// AXBoundsForTextMarkerRange
- (NSValue* _Nullable)moxBoundsForTextMarkerRange:(id _Nonnull)textMarkerRange;
@end