@office-iss/react-native-win32 0.64.6 → 0.64.10
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/.flowconfig +5 -0
- package/CHANGELOG.json +61 -1
- package/CHANGELOG.md +36 -4
- package/Libraries/Components/Pressable/Pressable.win32.js +333 -0
- package/Libraries/Components/View/ReactNativeViewViewConfig.win32.js +2 -0
- package/Libraries/Components/View/Tests/ViewWin32Test.js +49 -4
- package/Libraries/Components/View/View.win32.js +4 -4
- package/Libraries/Components/View/ViewPropTypes.win32.js +544 -0
- package/Libraries/Components/View/ViewWin32.Props.d.ts +6 -0
- package/Libraries/Components/View/ViewWin32.Props.js +1 -1
- package/Libraries/Pressability/HoverState.win32.js +60 -0
- package/Libraries/Pressability/Pressability.win32.js +944 -0
- package/Libraries/Types/CoreEventTypes.win32.js +193 -0
- package/overrides.json +42 -7
- package/package.json +1 -1
- package/src/Libraries/Components/View/Tests/ViewWin32Test.tsx +65 -1
- package/src/Libraries/Components/View/ViewWin32.Props.ts +8 -1
package/.flowconfig
CHANGED
|
@@ -12,6 +12,7 @@
|
|
|
12
12
|
<PROJECT_ROOT>/Libraries/Alert/Alert.js
|
|
13
13
|
<PROJECT_ROOT>/Libraries/Components/AccessibilityInfo/NativeAccessibilityInfo.js
|
|
14
14
|
<PROJECT_ROOT>/Libraries/Components/Picker/Picker.js
|
|
15
|
+
<PROJECT_ROOT>/Libraries/Components/Pressable/Pressable.js
|
|
15
16
|
<PROJECT_ROOT>/Libraries/Components/SafeAreaView/SafeAreaView.js
|
|
16
17
|
<PROJECT_ROOT>/Libraries/Components/TextInput/TextInput.js
|
|
17
18
|
<PROJECT_ROOT>/Libraries/Components/TextInput/TextInputState.js
|
|
@@ -19,11 +20,15 @@
|
|
|
19
20
|
<PROJECT_ROOT>/Libraries/Components/View/ReactNativeViewAttributes.js
|
|
20
21
|
<PROJECT_ROOT>/Libraries/Components/View/ReactNativeViewViewConfig.js
|
|
21
22
|
<PROJECT_ROOT>/Libraries/Components/View/View.js
|
|
23
|
+
<PROJECT_ROOT>/Libraries/Components/View/ViewPropTypes.js
|
|
22
24
|
<PROJECT_ROOT>/Libraries/Image/Image.js
|
|
23
25
|
<PROJECT_ROOT>/Libraries/Inspector/Inspector.js
|
|
24
26
|
<PROJECT_ROOT>/Libraries/Inspector/InspectorOverlay.js
|
|
25
27
|
<PROJECT_ROOT>/Libraries/Network/RCTNetworking.js
|
|
28
|
+
<PROJECT_ROOT>/Libraries/Pressability/Pressability.js
|
|
29
|
+
<PROJECT_ROOT>/Libraries/Pressability/HoverState.js
|
|
26
30
|
<PROJECT_ROOT>/Libraries/StyleSheet/StyleSheet.js
|
|
31
|
+
<PROJECT_ROOT>/Libraries/Types/CoreEventTypes.js
|
|
27
32
|
<PROJECT_ROOT>/Libraries/Utilities/DeviceInfo.js
|
|
28
33
|
<PROJECT_ROOT>/Libraries/Utilities/Dimensions.js
|
|
29
34
|
|
package/CHANGELOG.json
CHANGED
|
@@ -2,7 +2,67 @@
|
|
|
2
2
|
"name": "@office-iss/react-native-win32",
|
|
3
3
|
"entries": [
|
|
4
4
|
{
|
|
5
|
-
"date": "Mon,
|
|
5
|
+
"date": "Mon, 17 Jan 2022 16:09:50 GMT",
|
|
6
|
+
"tag": "@office-iss/react-native-win32_v0.64.10",
|
|
7
|
+
"version": "0.64.10",
|
|
8
|
+
"comments": {
|
|
9
|
+
"patch": [
|
|
10
|
+
{
|
|
11
|
+
"comment": "Port windows pressable with extra desktop support to win32",
|
|
12
|
+
"author": "saadnajmi2@gmail.com",
|
|
13
|
+
"commit": "acfb47a7924f4d4e34e020838423bbbab026d670",
|
|
14
|
+
"package": "@office-iss/react-native-win32"
|
|
15
|
+
}
|
|
16
|
+
]
|
|
17
|
+
}
|
|
18
|
+
},
|
|
19
|
+
{
|
|
20
|
+
"date": "Mon, 15 Nov 2021 16:09:20 GMT",
|
|
21
|
+
"tag": "@office-iss/react-native-win32_v0.64.9",
|
|
22
|
+
"version": "0.64.9",
|
|
23
|
+
"comments": {
|
|
24
|
+
"patch": [
|
|
25
|
+
{
|
|
26
|
+
"comment": "Add enableFocusRing prop for View and test",
|
|
27
|
+
"author": "ruaraki@microsoft.com",
|
|
28
|
+
"commit": "ecbd53d9cd10b88691fc79eeaaf3be1b035f162f",
|
|
29
|
+
"package": "@office-iss/react-native-win32"
|
|
30
|
+
}
|
|
31
|
+
]
|
|
32
|
+
}
|
|
33
|
+
},
|
|
34
|
+
{
|
|
35
|
+
"date": "Mon, 25 Oct 2021 15:07:12 GMT",
|
|
36
|
+
"tag": "@office-iss/react-native-win32_v0.64.8",
|
|
37
|
+
"version": "0.64.8",
|
|
38
|
+
"comments": {
|
|
39
|
+
"patch": [
|
|
40
|
+
{
|
|
41
|
+
"comment": "Revert back to a warning for acceptsKeyboardFocus deprecation",
|
|
42
|
+
"author": "30809111+acoates-ms@users.noreply.github.com",
|
|
43
|
+
"commit": "e615b1c46b7396fe617dc3019091cc367bd145a8",
|
|
44
|
+
"package": "@office-iss/react-native-win32"
|
|
45
|
+
}
|
|
46
|
+
]
|
|
47
|
+
}
|
|
48
|
+
},
|
|
49
|
+
{
|
|
50
|
+
"date": "Mon, 20 Sep 2021 15:06:37 GMT",
|
|
51
|
+
"tag": "@office-iss/react-native-win32_v0.64.7",
|
|
52
|
+
"version": "0.64.7",
|
|
53
|
+
"comments": {
|
|
54
|
+
"patch": [
|
|
55
|
+
{
|
|
56
|
+
"comment": "Adding accessibilityItemType to ViewWin32",
|
|
57
|
+
"author": "safreibe@microsoft.com",
|
|
58
|
+
"commit": "47ceaac64f88816796d67d08affb9beea67d6344",
|
|
59
|
+
"package": "@office-iss/react-native-win32"
|
|
60
|
+
}
|
|
61
|
+
]
|
|
62
|
+
}
|
|
63
|
+
},
|
|
64
|
+
{
|
|
65
|
+
"date": "Mon, 13 Sep 2021 15:06:21 GMT",
|
|
6
66
|
"tag": "@office-iss/react-native-win32_v0.64.6",
|
|
7
67
|
"version": "0.64.6",
|
|
8
68
|
"comments": {
|
package/CHANGELOG.md
CHANGED
|
@@ -1,17 +1,49 @@
|
|
|
1
1
|
# Change Log - @office-iss/react-native-win32
|
|
2
2
|
|
|
3
|
-
This log was last generated on Mon,
|
|
3
|
+
This log was last generated on Mon, 17 Jan 2022 16:09:50 GMT and should not be manually modified.
|
|
4
4
|
|
|
5
5
|
<!-- Start content -->
|
|
6
6
|
|
|
7
|
-
## 0.64.
|
|
7
|
+
## 0.64.10
|
|
8
8
|
|
|
9
|
-
Mon,
|
|
9
|
+
Mon, 17 Jan 2022 16:09:50 GMT
|
|
10
10
|
|
|
11
11
|
### Patches
|
|
12
12
|
|
|
13
|
-
-
|
|
13
|
+
- Port windows pressable with extra desktop support to win32 (saadnajmi2@gmail.com)
|
|
14
14
|
|
|
15
|
+
## 0.64.9
|
|
16
|
+
|
|
17
|
+
Mon, 15 Nov 2021 16:09:20 GMT
|
|
18
|
+
|
|
19
|
+
### Patches
|
|
20
|
+
|
|
21
|
+
- Add enableFocusRing prop for View and test (ruaraki@microsoft.com)
|
|
22
|
+
|
|
23
|
+
## 0.64.8
|
|
24
|
+
|
|
25
|
+
Mon, 25 Oct 2021 15:07:12 GMT
|
|
26
|
+
|
|
27
|
+
### Patches
|
|
28
|
+
|
|
29
|
+
- Revert back to a warning for acceptsKeyboardFocus deprecation (30809111+acoates-ms@users.noreply.github.com)
|
|
30
|
+
|
|
31
|
+
## 0.64.7
|
|
32
|
+
|
|
33
|
+
Mon, 20 Sep 2021 15:06:37 GMT
|
|
34
|
+
|
|
35
|
+
### Patches
|
|
36
|
+
|
|
37
|
+
- Adding accessibilityItemType to ViewWin32 (safreibe@microsoft.com)
|
|
38
|
+
|
|
39
|
+
## 0.64.6
|
|
40
|
+
|
|
41
|
+
Mon, 13 Sep 2021 15:06:21 GMT
|
|
42
|
+
|
|
43
|
+
### Patches
|
|
44
|
+
|
|
45
|
+
- Fix exception in View when props are undefined (30809111+acoates-ms@users.noreply.github.com)
|
|
46
|
+
|
|
15
47
|
## 0.64.5
|
|
16
48
|
|
|
17
49
|
Mon, 23 Aug 2021 15:10:07 GMT
|
|
@@ -0,0 +1,333 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Copyright (c) Facebook, Inc. and its affiliates.
|
|
3
|
+
*
|
|
4
|
+
* This source code is licensed under the MIT license found in the
|
|
5
|
+
* LICENSE file in the root directory of this source tree.
|
|
6
|
+
*
|
|
7
|
+
* @flow strict-local
|
|
8
|
+
* @format
|
|
9
|
+
*/
|
|
10
|
+
|
|
11
|
+
'use strict';
|
|
12
|
+
|
|
13
|
+
import * as React from 'react';
|
|
14
|
+
import {useMemo, useState, useRef, useImperativeHandle} from 'react';
|
|
15
|
+
import useAndroidRippleForView, {
|
|
16
|
+
type RippleConfig,
|
|
17
|
+
} from './useAndroidRippleForView';
|
|
18
|
+
import type {
|
|
19
|
+
AccessibilityActionEvent,
|
|
20
|
+
AccessibilityActionInfo,
|
|
21
|
+
AccessibilityRole,
|
|
22
|
+
AccessibilityState,
|
|
23
|
+
AccessibilityValue,
|
|
24
|
+
} from '../View/ViewAccessibility';
|
|
25
|
+
import {PressabilityDebugView} from '../../Pressability/PressabilityDebug';
|
|
26
|
+
import usePressability from '../../Pressability/usePressability';
|
|
27
|
+
import {normalizeRect, type RectOrSize} from '../../StyleSheet/Rect';
|
|
28
|
+
import type {
|
|
29
|
+
LayoutEvent,
|
|
30
|
+
PressEvent,
|
|
31
|
+
// [Windows
|
|
32
|
+
MouseEvent,
|
|
33
|
+
BlurEvent,
|
|
34
|
+
FocusEvent, // Windows]
|
|
35
|
+
} from '../../Types/CoreEventTypes';
|
|
36
|
+
import View from '../View/View';
|
|
37
|
+
import TextInputState from '../TextInput/TextInputState';
|
|
38
|
+
|
|
39
|
+
type ViewStyleProp = $ElementType<React.ElementConfig<typeof View>, 'style'>;
|
|
40
|
+
|
|
41
|
+
export type StateCallbackType = $ReadOnly<{|
|
|
42
|
+
pressed: boolean,
|
|
43
|
+
|}>;
|
|
44
|
+
|
|
45
|
+
type Props = $ReadOnly<{|
|
|
46
|
+
/**
|
|
47
|
+
* Accessibility.
|
|
48
|
+
*/
|
|
49
|
+
accessibilityActions?: ?$ReadOnlyArray<AccessibilityActionInfo>,
|
|
50
|
+
accessibilityElementsHidden?: ?boolean,
|
|
51
|
+
accessibilityHint?: ?Stringish,
|
|
52
|
+
accessibilityIgnoresInvertColors?: ?boolean,
|
|
53
|
+
accessibilityLabel?: ?Stringish,
|
|
54
|
+
accessibilityLiveRegion?: ?('none' | 'polite' | 'assertive'),
|
|
55
|
+
accessibilityRole?: ?AccessibilityRole,
|
|
56
|
+
accessibilityState?: ?AccessibilityState,
|
|
57
|
+
accessibilityValue?: ?AccessibilityValue,
|
|
58
|
+
accessibilityViewIsModal?: ?boolean,
|
|
59
|
+
accessible?: ?boolean,
|
|
60
|
+
focusable?: ?boolean,
|
|
61
|
+
importantForAccessibility?: ?('auto' | 'yes' | 'no' | 'no-hide-descendants'),
|
|
62
|
+
onAccessibilityAction?: ?(event: AccessibilityActionEvent) => mixed,
|
|
63
|
+
|
|
64
|
+
/**
|
|
65
|
+
* Either children or a render prop that receives a boolean reflecting whether
|
|
66
|
+
* the component is currently pressed.
|
|
67
|
+
*/
|
|
68
|
+
children: React.Node | ((state: StateCallbackType) => React.Node),
|
|
69
|
+
|
|
70
|
+
/**
|
|
71
|
+
* Duration to wait after hover in before calling `onHoverIn`.
|
|
72
|
+
*/
|
|
73
|
+
delayHoverIn?: ?number,
|
|
74
|
+
|
|
75
|
+
/**
|
|
76
|
+
* Duration to wait after hover out before calling `onHoverOut`.
|
|
77
|
+
*/
|
|
78
|
+
delayHoverOut?: ?number,
|
|
79
|
+
|
|
80
|
+
/**
|
|
81
|
+
* Duration (in milliseconds) from `onPressIn` before `onLongPress` is called.
|
|
82
|
+
*/
|
|
83
|
+
delayLongPress?: ?number,
|
|
84
|
+
|
|
85
|
+
/**
|
|
86
|
+
* Whether the press behavior is disabled.
|
|
87
|
+
*/
|
|
88
|
+
disabled?: ?boolean,
|
|
89
|
+
|
|
90
|
+
/**
|
|
91
|
+
* Additional distance outside of this view in which a press is detected.
|
|
92
|
+
*/
|
|
93
|
+
hitSlop?: ?RectOrSize,
|
|
94
|
+
|
|
95
|
+
/**
|
|
96
|
+
* Additional distance outside of this view in which a touch is considered a
|
|
97
|
+
* press before `onPressOut` is triggered.
|
|
98
|
+
*/
|
|
99
|
+
pressRetentionOffset?: ?RectOrSize,
|
|
100
|
+
|
|
101
|
+
/**
|
|
102
|
+
* Called when this view's layout changes.
|
|
103
|
+
*/
|
|
104
|
+
onLayout?: ?(event: LayoutEvent) => void,
|
|
105
|
+
|
|
106
|
+
/**
|
|
107
|
+
* Called when the hover is activated to provide visual feedback.
|
|
108
|
+
*/
|
|
109
|
+
onHoverIn?: ?(event: MouseEvent) => mixed,
|
|
110
|
+
|
|
111
|
+
/**
|
|
112
|
+
* Called when the hover is deactivated to undo visual feedback.
|
|
113
|
+
*/
|
|
114
|
+
onHoverOut?: ?(event: MouseEvent) => mixed,
|
|
115
|
+
|
|
116
|
+
/**
|
|
117
|
+
* Called when a long-tap gesture is detected.
|
|
118
|
+
*/
|
|
119
|
+
onLongPress?: ?(event: PressEvent) => void,
|
|
120
|
+
|
|
121
|
+
/**
|
|
122
|
+
* Called when a single tap gesture is detected.
|
|
123
|
+
*/
|
|
124
|
+
onPress?: ?(event: PressEvent) => void,
|
|
125
|
+
|
|
126
|
+
/**
|
|
127
|
+
* Called when a touch is engaged before `onPress`.
|
|
128
|
+
*/
|
|
129
|
+
onPressIn?: ?(event: PressEvent) => void,
|
|
130
|
+
|
|
131
|
+
/**
|
|
132
|
+
* Called when a touch is released before `onPress`.
|
|
133
|
+
*/
|
|
134
|
+
onPressOut?: ?(event: PressEvent) => void,
|
|
135
|
+
|
|
136
|
+
/**
|
|
137
|
+
* Called after the element loses focus.
|
|
138
|
+
*/
|
|
139
|
+
onBlur?: ?(event: BlurEvent) => mixed,
|
|
140
|
+
|
|
141
|
+
/**
|
|
142
|
+
* Called after the element is focused.
|
|
143
|
+
*/
|
|
144
|
+
onFocus?: ?(event: FocusEvent) => mixed,
|
|
145
|
+
|
|
146
|
+
/**
|
|
147
|
+
* Either view styles or a function that receives a boolean reflecting whether
|
|
148
|
+
* the component is currently pressed and returns view styles.
|
|
149
|
+
*/
|
|
150
|
+
style?: ViewStyleProp | ((state: StateCallbackType) => ViewStyleProp),
|
|
151
|
+
|
|
152
|
+
/**
|
|
153
|
+
* Identifier used to find this view in tests.
|
|
154
|
+
*/
|
|
155
|
+
testID?: ?string,
|
|
156
|
+
|
|
157
|
+
/**
|
|
158
|
+
* If true, doesn't play system sound on touch.
|
|
159
|
+
*/
|
|
160
|
+
android_disableSound?: ?boolean,
|
|
161
|
+
|
|
162
|
+
/**
|
|
163
|
+
* Enables the Android ripple effect and configures its color.
|
|
164
|
+
*/
|
|
165
|
+
android_ripple?: ?RippleConfig,
|
|
166
|
+
|
|
167
|
+
/**
|
|
168
|
+
* Used only for documentation or testing (e.g. snapshot testing).
|
|
169
|
+
*/
|
|
170
|
+
testOnly_pressed?: ?boolean,
|
|
171
|
+
|
|
172
|
+
/**
|
|
173
|
+
* Duration to wait after press down before calling `onPressIn`.
|
|
174
|
+
*/
|
|
175
|
+
unstable_pressDelay?: ?number,
|
|
176
|
+
|}>;
|
|
177
|
+
|
|
178
|
+
/**
|
|
179
|
+
* Component used to build display components that should respond to whether the
|
|
180
|
+
* component is currently pressed or not.
|
|
181
|
+
*/
|
|
182
|
+
function Pressable(props: Props, forwardedRef): React.Node {
|
|
183
|
+
const {
|
|
184
|
+
accessible,
|
|
185
|
+
android_disableSound,
|
|
186
|
+
android_ripple,
|
|
187
|
+
children,
|
|
188
|
+
delayHoverIn,
|
|
189
|
+
delayHoverOut,
|
|
190
|
+
delayLongPress,
|
|
191
|
+
disabled,
|
|
192
|
+
focusable,
|
|
193
|
+
onHoverIn,
|
|
194
|
+
onHoverOut,
|
|
195
|
+
onLongPress,
|
|
196
|
+
onPress,
|
|
197
|
+
onPressIn,
|
|
198
|
+
onPressOut,
|
|
199
|
+
// [Windows
|
|
200
|
+
onBlur,
|
|
201
|
+
onFocus,
|
|
202
|
+
// Windows]
|
|
203
|
+
pressRetentionOffset,
|
|
204
|
+
style,
|
|
205
|
+
testOnly_pressed,
|
|
206
|
+
unstable_pressDelay,
|
|
207
|
+
...restProps
|
|
208
|
+
} = props;
|
|
209
|
+
|
|
210
|
+
const viewRef = useRef<React.ElementRef<typeof View> | null>(null);
|
|
211
|
+
useImperativeHandle(forwardedRef, () => viewRef.current);
|
|
212
|
+
|
|
213
|
+
// [Windows
|
|
214
|
+
const _onBlur = (event: BlurEvent) => {
|
|
215
|
+
TextInputState.blurInput(viewRef.current);
|
|
216
|
+
if (props.onBlur) {
|
|
217
|
+
props.onBlur(event);
|
|
218
|
+
}
|
|
219
|
+
};
|
|
220
|
+
|
|
221
|
+
const _onFocus = (event: FocusEvent) => {
|
|
222
|
+
TextInputState.focusInput(viewRef.current);
|
|
223
|
+
if (props.onFocus) {
|
|
224
|
+
props.onFocus(event);
|
|
225
|
+
}
|
|
226
|
+
};
|
|
227
|
+
// Windows]
|
|
228
|
+
|
|
229
|
+
const android_rippleConfig = useAndroidRippleForView(android_ripple, viewRef);
|
|
230
|
+
|
|
231
|
+
const [pressed, setPressed] = usePressState(testOnly_pressed === true);
|
|
232
|
+
|
|
233
|
+
const hitSlop = normalizeRect(props.hitSlop);
|
|
234
|
+
|
|
235
|
+
const restPropsWithDefaults: React.ElementConfig<typeof View> = {
|
|
236
|
+
...restProps,
|
|
237
|
+
...android_rippleConfig?.viewProps,
|
|
238
|
+
accessible: accessible !== false,
|
|
239
|
+
focusable: focusable !== false,
|
|
240
|
+
hitSlop,
|
|
241
|
+
};
|
|
242
|
+
|
|
243
|
+
const config = useMemo(
|
|
244
|
+
() => ({
|
|
245
|
+
disabled,
|
|
246
|
+
hitSlop,
|
|
247
|
+
pressRectOffset: pressRetentionOffset,
|
|
248
|
+
android_disableSound,
|
|
249
|
+
delayHoverIn,
|
|
250
|
+
delayHoverOut,
|
|
251
|
+
delayLongPress,
|
|
252
|
+
delayPressIn: unstable_pressDelay,
|
|
253
|
+
onHoverIn,
|
|
254
|
+
onHoverOut,
|
|
255
|
+
onLongPress,
|
|
256
|
+
onPress,
|
|
257
|
+
onPressIn(event: PressEvent): void {
|
|
258
|
+
if (android_rippleConfig != null) {
|
|
259
|
+
android_rippleConfig.onPressIn(event);
|
|
260
|
+
}
|
|
261
|
+
setPressed(true);
|
|
262
|
+
if (onPressIn != null) {
|
|
263
|
+
onPressIn(event);
|
|
264
|
+
}
|
|
265
|
+
},
|
|
266
|
+
onPressMove: android_rippleConfig?.onPressMove,
|
|
267
|
+
onPressOut(event: PressEvent): void {
|
|
268
|
+
if (android_rippleConfig != null) {
|
|
269
|
+
android_rippleConfig.onPressOut(event);
|
|
270
|
+
}
|
|
271
|
+
setPressed(false);
|
|
272
|
+
if (onPressOut != null) {
|
|
273
|
+
onPressOut(event);
|
|
274
|
+
}
|
|
275
|
+
},
|
|
276
|
+
// [Windows
|
|
277
|
+
onBlur,
|
|
278
|
+
onFocus,
|
|
279
|
+
// Windows]
|
|
280
|
+
}),
|
|
281
|
+
[
|
|
282
|
+
android_disableSound,
|
|
283
|
+
android_rippleConfig,
|
|
284
|
+
delayHoverIn,
|
|
285
|
+
delayHoverOut,
|
|
286
|
+
delayLongPress,
|
|
287
|
+
disabled,
|
|
288
|
+
hitSlop,
|
|
289
|
+
onHoverIn,
|
|
290
|
+
onHoverOut,
|
|
291
|
+
onLongPress,
|
|
292
|
+
onPress,
|
|
293
|
+
onPressIn,
|
|
294
|
+
onPressOut,
|
|
295
|
+
// [Windows
|
|
296
|
+
onBlur,
|
|
297
|
+
onFocus,
|
|
298
|
+
// Windows]
|
|
299
|
+
pressRetentionOffset,
|
|
300
|
+
setPressed,
|
|
301
|
+
unstable_pressDelay,
|
|
302
|
+
],
|
|
303
|
+
);
|
|
304
|
+
const eventHandlers = usePressability(config);
|
|
305
|
+
|
|
306
|
+
return (
|
|
307
|
+
<View
|
|
308
|
+
{...restPropsWithDefaults}
|
|
309
|
+
{...eventHandlers}
|
|
310
|
+
// [Windows
|
|
311
|
+
onBlur={_onBlur}
|
|
312
|
+
onFocus={_onFocus}
|
|
313
|
+
// Windows]
|
|
314
|
+
ref={viewRef}
|
|
315
|
+
style={typeof style === 'function' ? style({pressed}) : style}>
|
|
316
|
+
{typeof children === 'function' ? children({pressed}) : children}
|
|
317
|
+
{__DEV__ ? <PressabilityDebugView color="red" hitSlop={hitSlop} /> : null}
|
|
318
|
+
</View>
|
|
319
|
+
);
|
|
320
|
+
}
|
|
321
|
+
|
|
322
|
+
function usePressState(forcePressed: boolean): [boolean, (boolean) => void] {
|
|
323
|
+
const [pressed, setPressed] = useState(false);
|
|
324
|
+
return [pressed || forcePressed, setPressed];
|
|
325
|
+
}
|
|
326
|
+
|
|
327
|
+
const MemoedPressable = React.memo(React.forwardRef(Pressable));
|
|
328
|
+
MemoedPressable.displayName = 'Pressable';
|
|
329
|
+
|
|
330
|
+
export default (MemoedPressable: React.AbstractComponent<
|
|
331
|
+
Props,
|
|
332
|
+
React.ElementRef<typeof View>,
|
|
333
|
+
>);
|
|
@@ -68,11 +68,11 @@ var FocusMoverTestComponent = /** @class */ (function (_super) {
|
|
|
68
68
|
}
|
|
69
69
|
FocusMoverTestComponent.prototype.render = function () {
|
|
70
70
|
return (React.createElement(ViewWin32_1.ViewWin32, null,
|
|
71
|
-
React.createElement(ViewWin32_1.ViewWin32, { ref: this._labeledBy, accessibilityLabel: "separate label for test" }),
|
|
71
|
+
React.createElement(ViewWin32_1.ViewWin32, { ref: this._labeledBy, accessibilityLabel: "separate label for test", accessibilityItemType: "Comment" }),
|
|
72
72
|
React.createElement(ViewWin32_1.ViewWin32, { style: { flexDirection: 'row', alignItems: 'center', justifyContent: 'space-around', marginVertical: 5 } },
|
|
73
73
|
React.createElement(react_native_1.TouchableHighlight, { onPress: this._onPress },
|
|
74
74
|
React.createElement(ViewWin32_1.ViewWin32, { accessibilityLabeledBy: this._labeledBy, style: styles.blackbox })),
|
|
75
|
-
React.createElement(ViewWin32_1.ViewWin32, { ref: this._setRef, focusable: true, style: this.state.hasFocus ? { backgroundColor: '#aee8fcff' } : { backgroundColor: '#00000000' }, onFocus: this._onFocus, onBlur: this._onBlur },
|
|
75
|
+
React.createElement(ViewWin32_1.ViewWin32, { ref: this._setRef, focusable: true, style: this.state.hasFocus ? { backgroundColor: '#aee8fcff' } : { backgroundColor: '#00000000' }, onFocus: this._onFocus, onBlur: this._onBlur, enableFocusRing: false },
|
|
76
76
|
React.createElement(react_native_1.Text, null, this.state.hasFocus ? 'Focus: Yes' : 'Focus: No')))));
|
|
77
77
|
};
|
|
78
78
|
return FocusMoverTestComponent;
|
|
@@ -113,7 +113,7 @@ var KeyboardTestComponent = /** @class */ (function (_super) {
|
|
|
113
113
|
}
|
|
114
114
|
KeyboardTestComponent.prototype.render = function () {
|
|
115
115
|
return (React.createElement(ViewWin32_1.ViewWin32, { keyDownEvents: handledNativeKeyboardEvents, keyUpEvents: handledNativeKeyboardEvents },
|
|
116
|
-
React.createElement(ViewWin32_1.ViewWin32, { style: this.state.hasFocus ? [styles.keyComponentRoot, styles.border] : styles.keyComponentRoot, focusable: true, onKeyUp: this._onKeyUp, onKeyDown: this._onKeyDown, onFocus: this._onFocus, onBlur: this._onBlur },
|
|
116
|
+
React.createElement(ViewWin32_1.ViewWin32, { style: this.state.hasFocus ? [styles.keyComponentRoot, styles.border] : styles.keyComponentRoot, focusable: true, onKeyUp: this._onKeyUp, onKeyDown: this._onKeyDown, onFocus: this._onFocus, onBlur: this._onBlur, enableFocusRing: false },
|
|
117
117
|
React.createElement(ViewWin32_1.ViewWin32, { style: styles.keyEnterVisualizer },
|
|
118
118
|
React.createElement(react_native_1.Text, null, "OnKeyDown"),
|
|
119
119
|
React.createElement(react_native_1.Text, null, "----"),
|
|
@@ -189,6 +189,44 @@ var CursorExample = function () {
|
|
|
189
189
|
React.createElement(CursorTestComponent, { cursor: 'text' }),
|
|
190
190
|
React.createElement(CursorTestComponent, { cursor: 'we-resize' })));
|
|
191
191
|
};
|
|
192
|
+
var EnableFocusRingExample = /** @class */ (function (_super) {
|
|
193
|
+
__extends(EnableFocusRingExample, _super);
|
|
194
|
+
function EnableFocusRingExample(props) {
|
|
195
|
+
var _this = _super.call(this, props) || this;
|
|
196
|
+
_this._onFocus = function () {
|
|
197
|
+
_this.setState({
|
|
198
|
+
hasFocus: true,
|
|
199
|
+
});
|
|
200
|
+
};
|
|
201
|
+
_this._onBlur = function () {
|
|
202
|
+
_this.setState({
|
|
203
|
+
hasFocus: false,
|
|
204
|
+
});
|
|
205
|
+
};
|
|
206
|
+
_this.state = {
|
|
207
|
+
hasFocus: false,
|
|
208
|
+
};
|
|
209
|
+
return _this;
|
|
210
|
+
}
|
|
211
|
+
EnableFocusRingExample.prototype.render = function () {
|
|
212
|
+
return (React.createElement(ViewWin32_1.ViewWin32, { style: { flexDirection: 'row', alignItems: 'center', justifyContent: 'space-around', marginVertical: 5 } },
|
|
213
|
+
React.createElement(ViewWin32_1.ViewWin32, { style: {
|
|
214
|
+
backgroundColor: 'pink',
|
|
215
|
+
height: 100,
|
|
216
|
+
width: 100,
|
|
217
|
+
}, enableFocusRing: true, focusable: true },
|
|
218
|
+
React.createElement(react_native_1.Text, null, "enableFocusRing set to true")),
|
|
219
|
+
React.createElement(ViewWin32_1.ViewWin32, { style: {
|
|
220
|
+
backgroundColor: 'pink',
|
|
221
|
+
height: 100,
|
|
222
|
+
width: 100,
|
|
223
|
+
}, enableFocusRing: false, focusable: true, onFocus: this._onFocus, onBlur: this._onBlur },
|
|
224
|
+
React.createElement(React.Fragment, null,
|
|
225
|
+
React.createElement(react_native_1.Text, null, "enableFocusRing set to false"),
|
|
226
|
+
React.createElement(react_native_1.Text, null, this.state.hasFocus ? 'Focus: Yes' : 'Focus: No')))));
|
|
227
|
+
};
|
|
228
|
+
return EnableFocusRingExample;
|
|
229
|
+
}(React.Component));
|
|
192
230
|
exports.title = 'ViewWin32';
|
|
193
231
|
exports.displayName = 'ViewWin32 Example';
|
|
194
232
|
exports.description = 'All the stock View props plus Win32 specific ones';
|
|
@@ -231,5 +269,12 @@ exports.examples = [
|
|
|
231
269
|
return React.createElement(CursorExample, null);
|
|
232
270
|
},
|
|
233
271
|
},
|
|
272
|
+
{
|
|
273
|
+
title: 'EnableFocusRing example',
|
|
274
|
+
description: 'Displays focus visuals that are driven by native',
|
|
275
|
+
render: function () {
|
|
276
|
+
return React.createElement(EnableFocusRingExample, null);
|
|
277
|
+
},
|
|
278
|
+
},
|
|
234
279
|
];
|
|
235
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ViewWin32Test.js","sourceRoot":"","sources":["../../../../src/Libraries/Components/View/Tests/ViewWin32Test.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;;;;;;;;;;;;;;;;AACb,6BAA+B;AAC/B,6CAAoE;AACpE,0CAAyC;AAGzC,IAAM,MAAM,GAAG,yBAAU,CAAC,MAAM,CAAC;IAC/B,MAAM,EAAE;QACN,WAAW,EAAE,QAAQ;QACrB,WAAW,EAAE,OAAO;KACrB;IACD,gBAAgB,EAAE;QAChB,WAAW,EAAE,CAAC;QACd,aAAa,EAAE,KAAK;QACpB,cAAc,EAAE,CAAC;QACjB,eAAe,EAAE,YAAY;QAC7B,cAAc,EAAE,cAAc;KAC/B;IACD,kBAAkB,EAAE;QAClB,MAAM,EAAE,CAAC;QACT,UAAU,EAAE,QAAQ;QACpB,QAAQ,EAAE,GAAG;QACb,SAAS,EAAE,EAAE;KACd;IACD,QAAQ,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,WAAW,EAAE,OAAO,EAAE,WAAW,EAAE,CAAC,EAAE;CAC1E,CAAC,CAAC;AAMH;IAAsC,2CAA6C;IAIjF,iCAAmB,KAAK;QAAxB,YACE,kBAAM,KAAK,CAAC,SAKb;QATO,kBAAY,GAAc,IAAI,CAAC;QAgCtB,aAAO,GAAG,UAAC,GAAc;YACxC,KAAI,CAAC,YAAY,GAAG,GAAG,CAAC;QAC1B,CAAC,CAAC;QAEe,cAAQ,GAAG;YAC1B,IAAI,KAAI,CAAC,YAAY,KAAK,SAAS,EAAE;gBACnC,KAAI,CAAC,YAAY,CAAC,KAAK,EAAE,CAAC;aAC3B;QACH,CAAC,CAAC;QAEe,cAAQ,GAAG;YAC1B,KAAI,CAAC,QAAQ,CAAC;gBACZ,QAAQ,EAAE,IAAI;aACf,CAAC,CAAC;QACL,CAAC,CAAC;QAEe,aAAO,GAAG;YACzB,KAAI,CAAC,QAAQ,CAAC;gBACZ,QAAQ,EAAE,KAAK;aAChB,CAAC,CAAC;QACL,CAAC,CAAC;QA/CA,KAAI,CAAC,KAAK,GAAG;YACX,QAAQ,EAAE,KAAK;SAChB,CAAC;QACF,KAAI,CAAC,UAAU,GAAG,KAAK,CAAC,SAAS,EAAa,CAAC;;IACjD,CAAC;IACM,wCAAM,GAAb;QACE,OAAO,CACL,oBAAC,qBAAS;YACR,oBAAC,qBAAS,IAAC,GAAG,EAAE,IAAI,CAAC,UAAU,EAAE,kBAAkB,EAAC,yBAAyB,GAAG;YAClF,oBAAC,qBAAS,IAAC,KAAK,EAAE,EAAE,aAAa,EAAE,KAAK,EAAE,UAAU,EAAE,QAAQ,EAAE,cAAc,EAAE,cAAc,EAAE,cAAc,EAAE,CAAC,EAAE;gBACjH,oBAAC,iCAAkB,IAAC,OAAO,EAAE,IAAI,CAAC,QAAQ;oBACxC,oBAAC,qBAAS,IAAC,sBAAsB,EAAE,IAAI,CAAC,UAAU,EAAE,KAAK,EAAE,MAAM,CAAC,QAAQ,GAAI,CAC3D;gBACrB,oBAAC,qBAAS,IACR,GAAG,EAAE,IAAI,CAAC,OAAO,EACjB,SAAS,QACT,KAAK,EAAE,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,eAAe,EAAE,WAAW,EAAE,CAAC,CAAC,CAAC,EAAE,eAAe,EAAE,WAAW,EAAE,EAChG,OAAO,EAAE,IAAI,CAAC,QAAQ,EACtB,MAAM,EAAE,IAAI,CAAC,OAAO;oBAEpB,oBAAC,mBAAI,QAAE,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,WAAW,CAAQ,CACrD,CACF,CACA,CACb,CAAC;IACJ,CAAC;IAuBH,8BAAC;AAAD,CAAC,AAtDD,CAAsC,KAAK,CAAC,SAAS,GAsDpD;AAOD,IAAM,2BAA2B,GAA4B;IAC3D,EAAE,GAAG,EAAE,WAAW,EAAE;IACpB,EAAE,GAAG,EAAE,SAAS,EAAE;IAClB,EAAE,GAAG,EAAE,WAAW,EAAE;IACpB,EAAE,GAAG,EAAE,YAAY,EAAE;IACrB,EAAE,GAAG,EAAE,KAAK,EAAE;CACf,CAAC;AAEF;IAAoC,yCAA2E;IAC7G,+BAAmB,KAAK;QAAxB,YACE,kBAAM,KAAK,CAAC,SAMb;QA4BgB,cAAQ,GAAG;YAC1B,KAAI,CAAC,QAAQ,CAAC;gBACZ,QAAQ,EAAE,IAAI;aACf,CAAC,CAAC;QACL,CAAC,CAAC;QAEe,aAAO,GAAG;YACzB,KAAI,CAAC,QAAQ,CAAC;gBACZ,QAAQ,EAAE,KAAK;aAChB,CAAC,CAAC;QACL,CAAC,CAAC;QAEe,cAAQ,GAAG,UAAC,EAAkB;YAC7C,KAAI,CAAC,QAAQ,CAAC,EAAE,SAAS,EAAE,EAAE,CAAC,WAAW,CAAC,GAAG,EAAE,WAAW,EAAE,IAAI,EAAE,CAAC,CAAC;QACtE,CAAC,CAAC;QAEe,gBAAU,GAAG,UAAC,EAAkB;YAC/C,KAAI,CAAC,QAAQ,CAAC,EAAE,WAAW,EAAE,EAAE,CAAC,WAAW,CAAC,GAAG,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;QACtE,CAAC,CAAC;QAnDA,KAAI,CAAC,KAAK,GAAG;YACX,QAAQ,EAAE,KAAK;YACf,WAAW,EAAE,IAAI;YACjB,SAAS,EAAE,IAAI;SAChB,CAAC;;IACJ,CAAC;IAEM,sCAAM,GAAb;QACE,OAAO,CACL,oBAAC,qBAAS,IAAC,aAAa,EAAE,2BAA2B,EAAE,WAAW,EAAE,2BAA2B;YAC7F,oBAAC,qBAAS,IACR,KAAK,EAAE,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,gBAAgB,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,gBAAgB,EAC/F,SAAS,QACT,OAAO,EAAE,IAAI,CAAC,QAAQ,EACtB,SAAS,EAAE,IAAI,CAAC,UAAU,EAC1B,OAAO,EAAE,IAAI,CAAC,QAAQ,EACtB,MAAM,EAAE,IAAI,CAAC,OAAO;gBAEpB,oBAAC,qBAAS,IAAC,KAAK,EAAE,MAAM,CAAC,kBAAkB;oBACzC,oBAAC,mBAAI,oBAAiB;oBACtB,oBAAC,mBAAI,eAAY;oBACjB,oBAAC,mBAAI,QAAE,IAAI,CAAC,KAAK,CAAC,WAAW,KAAK,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC,CAAC,GAAG,CAAQ,CACnE;gBACZ,oBAAC,qBAAS,IAAC,KAAK,EAAE,MAAM,CAAC,kBAAkB;oBACzC,oBAAC,mBAAI,kBAAe;oBACpB,oBAAC,mBAAI,eAAY;oBACjB,oBAAC,mBAAI,QAAE,IAAI,CAAC,KAAK,CAAC,SAAS,KAAK,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,CAAQ,CAC/D,CACF,CACF,CACb,CAAC;IACJ,CAAC;IAqBH,4BAAC;AAAD,CAAC,AAvDD,CAAoC,KAAK,CAAC,SAAS,GAuDlD;AAKD;IAAiC,sCAA+D;IAC9F,4BAAmB,KAAK;QAAxB,YACE,kBAAM,KAAK,CAAC,SAIb;QAWgB,mBAAa,GAAG;YAC/B,KAAI,CAAC,QAAQ,CAAC,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,CAAC;QACrC,CAAC,CAAC;QACe,mBAAa,GAAG;YAC/B,KAAI,CAAC,QAAQ,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC;QACpC,CAAC,CAAC;QAnBA,KAAI,CAAC,KAAK,GAAG;YACX,QAAQ,EAAE,KAAK;SAChB,CAAC;;IACJ,CAAC;IAEM,mCAAM,GAAb;QACE,OAAO,CACL,oBAAC,qBAAS,IACR,YAAY,EAAE,IAAI,CAAC,aAAa,EAChC,YAAY,EAAE,IAAI,CAAC,aAAa,EAChC,KAAK,EAAE,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,QAAQ,EAAE,EAAE,eAAe,EAAE,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,QAAQ,GACvG,CACH,CAAC;IACJ,CAAC;IAOH,yBAAC;AAAD,CAAC,AAvBD,CAAiC,KAAK,CAAC,SAAS,GAuB/C;AAED;IAA2B,gCAAe;IAA1C;;IAcA,CAAC;IAbQ,6BAAM,GAAb;QACE,OAAO,CACL,oBAAC,qBAAS,IAAC,KAAK,EAAE,EAAE,aAAa,EAAE,KAAK,EAAE,gBAAgB,EAAE,EAAE,EAAE,cAAc,EAAE,cAAc,EAAE;YAC9F,oBAAC,kBAAkB,IAAC,KAAK,EAAC,KAAK,GAAG;YAClC,oBAAC,kBAAkB,IAAC,KAAK,EAAC,QAAQ,GAAG;YACrC,oBAAC,kBAAkB,IAAC,KAAK,EAAC,QAAQ,GAAG;YACrC,oBAAC,kBAAkB,IAAC,KAAK,EAAC,OAAO,GAAG;YACpC,oBAAC,kBAAkB,IAAC,KAAK,EAAC,MAAM,GAAG;YACnC,oBAAC,kBAAkB,IAAC,KAAK,EAAC,QAAQ,GAAG;YACrC,oBAAC,kBAAkB,IAAC,KAAK,EAAC,QAAQ,GAAG,CAC3B,CACb,CAAC;IACJ,CAAC;IACH,mBAAC;AAAD,CAAC,AAdD,CAA2B,KAAK,CAAC,SAAS,GAczC;AAED,IAAM,cAAc,GAAgC;IAClD,OAAO,CACL,oBAAC,qBAAS,IACR,KAAK,EAAE;YACL,eAAe,EAAE,KAAK;YACtB,MAAM,EAAE,GAAG;YACX,KAAK,EAAE,GAAG;SACX,EACD,OAAO,EAAC,iBAAiB,EACzB,MAAM,EAAC,SAAS,GAChB,CACH,CAAC;AACJ,CAAC,CAAC;AAMF,IAAM,mBAAmB,GAAuD,UAAC,KAAK;IACpF,OAAO,CACL,oBAAC,qBAAS,IAAC,KAAK,EAAE,EAAC,aAAa,EAAE,QAAQ,EAAC;QACzC,oBAAC,mBAAI,QAAE,KAAK,CAAC,MAAM,CAAQ;QAC3B,oBAAC,qBAAS,IAAC,MAAM,EAAE,KAAK,CAAC,MAAM,EAAE,KAAK,EAAE,MAAM,CAAC,QAAQ,GAAI,CACjD,CACb,CAAA;AACH,CAAC,CAAA;AAED,IAAM,aAAa,GAA4B;IAC7C,OAAO,CACL,oBAAC,qBAAS,IAAC,KAAK,EAAE,EAAE,aAAa,EAAE,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE;QACxE,oBAAC,mBAAmB,IAAC,MAAM,EAAC,MAAM,GAAG;QACrC,oBAAC,mBAAmB,IAAC,MAAM,EAAC,SAAS,GAAG;QACxC,oBAAC,mBAAmB,IAAC,MAAM,EAAC,MAAM,GAAG;QACrC,oBAAC,mBAAmB,IAAC,MAAM,EAAC,aAAa,GAAG;QAC5C,oBAAC,mBAAmB,IAAC,MAAM,EAAC,aAAa,GAAG;QAC5C,oBAAC,mBAAmB,IAAC,MAAM,EAAC,WAAW,GAAG;QAC1C,oBAAC,mBAAmB,IAAC,MAAM,EAAC,aAAa,GAAG;QAC5C,oBAAC,mBAAmB,IAAC,MAAM,EAAC,SAAS,GAAG;QACxC,oBAAC,mBAAmB,IAAC,MAAM,EAAC,MAAM,GAAG;QACrC,oBAAC,mBAAmB,IAAC,MAAM,EAAC,MAAM,GAAG;QACrC,oBAAC,mBAAmB,IAAC,MAAM,EAAC,MAAM,GAAG;QACrC,oBAAC,mBAAmB,IAAC,MAAM,EAAC,WAAW,GAAG,CAChC,CACb,CAAC;AACJ,CAAC,CAAA;AAEY,QAAA,KAAK,GAAG,WAAW,CAAC;AACpB,QAAA,WAAW,GAAG,mBAAmB,CAAC;AAClC,QAAA,WAAW,GAAG,mDAAmD,CAAC;AAClE,QAAA,QAAQ,GAAG;IACtB;QACE,KAAK,EAAE,wBAAwB;QAC/B,WAAW,EAAE,qEAAqE;QAClF,MAAM,EAAN;YACE,OAAO,CACL,oBAAC,qBAAS;gBACR,oBAAC,uBAAuB,OAAG;gBAC3B,oBAAC,uBAAuB,OAAG;gBAC3B,oBAAC,uBAAuB,OAAG,CACjB,CACb,CAAC;QACJ,CAAC;KACF;IACD;QACE,KAAK,EAAE,wBAAwB;QAC/B,WAAW,EAAE,uCAAuC;QACpD,MAAM,EAAN;YACE,OAAO,oBAAC,qBAAqB,OAAG,CAAC;QACnC,CAAC;KACF;IACD;QACE,KAAK,EAAE,eAAe;QACtB,WAAW,EAAE,iBAAiB;QAC9B,MAAM,EAAN;YACE,OAAO,oBAAC,YAAY,OAAG,CAAC;QAC1B,CAAC;KACF;IACD;QACE,KAAK,EAAE,iBAAiB;QACxB,WAAW,EAAE,6BAA6B;QAC1C,MAAM,EAAN;YACE,OAAO,oBAAC,cAAc,OAAG,CAAC;QAC5B,CAAC;KACF;IACD;QACE,KAAK,EAAE,gBAAgB;QACvB,WAAW,EAAE,uDAAuD;QACpE,MAAM,EAAN;YACE,OAAO,oBAAC,aAAa,OAAG,CAAC;QAC3B,CAAC;KACF;CACF,CAAC","sourcesContent":["'use strict';\nimport * as React from 'react';\nimport { StyleSheet, Text, TouchableHighlight } from 'react-native';\nimport { ViewWin32 } from '../ViewWin32';\nimport { Cursor, IKeyboardEvent, IHandledKeyboardEvent } from '../ViewWin32.Props';\n\nconst styles = StyleSheet.create({\n  border: {\n    borderStyle: 'dotted',\n    borderColor: 'black',\n  },\n  keyComponentRoot: {\n    borderWidth: 2,\n    flexDirection: 'row',\n    marginVertical: 5,\n    backgroundColor: 'whitesmoke',\n    justifyContent: 'space-around',\n  },\n  keyEnterVisualizer: {\n    margin: 5,\n    alignItems: 'center',\n    minWidth: 100,\n    minHeight: 30,\n  },\n  blackbox: { height: 30, width: 30, borderColor: 'black', borderWidth: 3 },\n});\n\ninterface IFocusableComponentState {\n  hasFocus: boolean;\n}\n\nclass FocusMoverTestComponent extends React.Component<{}, IFocusableComponentState> {\n  private _focusTarget: ViewWin32 = null;\n  private readonly _labeledBy: React.RefObject<ViewWin32>;\n\n  public constructor(props) {\n    super(props);\n    this.state = {\n      hasFocus: false,\n    };\n    this._labeledBy = React.createRef<ViewWin32>();\n  }\n  public render() {\n    return (\n      <ViewWin32>\n        <ViewWin32 ref={this._labeledBy} accessibilityLabel=\"separate label for test\" />\n      <ViewWin32 style={{ flexDirection: 'row', alignItems: 'center', justifyContent: 'space-around', marginVertical: 5 }}>\n        <TouchableHighlight onPress={this._onPress}>\n          <ViewWin32 accessibilityLabeledBy={this._labeledBy} style={styles.blackbox} />\n        </TouchableHighlight>\n        <ViewWin32\n          ref={this._setRef}\n          focusable\n          style={this.state.hasFocus ? { backgroundColor: '#aee8fcff' } : { backgroundColor: '#00000000' }}\n          onFocus={this._onFocus}\n          onBlur={this._onBlur}\n        >\n          <Text>{this.state.hasFocus ? 'Focus: Yes' : 'Focus: No'}</Text>\n        </ViewWin32>\n      </ViewWin32>\n      </ViewWin32>\n    );\n  }\n\n  private readonly _setRef = (ref: ViewWin32) => {\n    this._focusTarget = ref;\n  };\n\n  private readonly _onPress = () => {\n    if (this._focusTarget !== undefined) {\n      this._focusTarget.focus();\n    }\n  };\n\n  private readonly _onFocus = () => {\n    this.setState({\n      hasFocus: true,\n    });\n  };\n\n  private readonly _onBlur = () => {\n    this.setState({\n      hasFocus: false,\n    });\n  };\n}\n\ninterface IKeyboardableComponentState {\n  lastKeyDown: string;\n  lastKeyUp: string;\n}\n\nconst handledNativeKeyboardEvents: IHandledKeyboardEvent[] = [\n  { key: 'ArrowDown' },\n  { key: 'ArrowUp' },\n  { key: 'ArrowLeft' },\n  { key: 'ArrowRight' },\n  { key: 'Tab' },\n];\n\nclass KeyboardTestComponent extends React.Component<{}, IFocusableComponentState & IKeyboardableComponentState> {\n  public constructor(props) {\n    super(props);\n    this.state = {\n      hasFocus: false,\n      lastKeyDown: null,\n      lastKeyUp: null,\n    };\n  }\n\n  public render() {\n    return (\n      <ViewWin32 keyDownEvents={handledNativeKeyboardEvents} keyUpEvents={handledNativeKeyboardEvents}>\n        <ViewWin32\n          style={this.state.hasFocus ? [styles.keyComponentRoot, styles.border] : styles.keyComponentRoot}\n          focusable\n          onKeyUp={this._onKeyUp}\n          onKeyDown={this._onKeyDown}\n          onFocus={this._onFocus}\n          onBlur={this._onBlur}\n        >\n          <ViewWin32 style={styles.keyEnterVisualizer}>\n            <Text>OnKeyDown</Text>\n            <Text>----</Text>\n            <Text>{this.state.lastKeyDown !== null ? this.state.lastKeyDown : ' '}</Text>\n          </ViewWin32>\n          <ViewWin32 style={styles.keyEnterVisualizer}>\n            <Text>OnKeyUp</Text>\n            <Text>----</Text>\n            <Text>{this.state.lastKeyUp !== null ? this.state.lastKeyUp : ' '}</Text>\n          </ViewWin32>\n        </ViewWin32>\n      </ViewWin32>\n    );\n  }\n\n  private readonly _onFocus = () => {\n    this.setState({\n      hasFocus: true,\n    });\n  };\n\n  private readonly _onBlur = () => {\n    this.setState({\n      hasFocus: false,\n    });\n  };\n\n  private readonly _onKeyUp = (ev: IKeyboardEvent) => {\n    this.setState({ lastKeyUp: ev.nativeEvent.key, lastKeyDown: null });\n  };\n\n  private readonly _onKeyDown = (ev: IKeyboardEvent) => {\n    this.setState({ lastKeyDown: ev.nativeEvent.key, lastKeyUp: null });\n  };\n}\n\ninterface IHoverComponentProps {\n  color: string;\n}\nclass HoverTestComponent extends React.Component<IHoverComponentProps, IFocusableComponentState> {\n  public constructor(props) {\n    super(props);\n    this.state = {\n      hasFocus: false,\n    };\n  }\n\n  public render() {\n    return (\n      <ViewWin32\n        onMouseEnter={this._onMouseEnter}\n        onMouseLeave={this._onMouseLeave}\n        style={this.state.hasFocus ? [styles.blackbox, { backgroundColor: this.props.color }] : styles.blackbox}\n      />\n    );\n  }\n  private readonly _onMouseLeave = () => {\n    this.setState({ hasFocus: false });\n  };\n  private readonly _onMouseEnter = () => {\n    this.setState({ hasFocus: true });\n  };\n}\n\nclass HoverExample extends React.Component {\n  public render() {\n    return (\n      <ViewWin32 style={{ flexDirection: 'row', marginHorizontal: 75, justifyContent: 'space-around' }}>\n        <HoverTestComponent color=\"red\" />\n        <HoverTestComponent color=\"orange\" />\n        <HoverTestComponent color=\"yellow\" />\n        <HoverTestComponent color=\"green\" />\n        <HoverTestComponent color=\"blue\" />\n        <HoverTestComponent color=\"indigo\" />\n        <HoverTestComponent color=\"violet\" />\n      </ViewWin32>\n    );\n  }\n}\n\nconst ToolTipExample: React.FunctionComponent<{}> = () => {\n  return (\n    <ViewWin32\n      style={{\n        backgroundColor: 'red',\n        height: 100,\n        width: 100,\n      }}\n      tooltip=\"Example tooltip\"\n      cursor=\"pointer\"\n    />\n  );\n};\n\ninterface ICursorTestComponentProps {\n  cursor: Cursor\n}\n\nconst CursorTestComponent: React.FunctionComponent<ICursorTestComponentProps> = (props) => {\n  return (\n    <ViewWin32 style={{flexDirection: 'column'}}>\n      <Text>{props.cursor}</Text>\n      <ViewWin32 cursor={props.cursor} style={styles.blackbox} />\n    </ViewWin32>\n  )\n}\n\nconst CursorExample: React.FunctionComponent = () => {\n  return (\n    <ViewWin32 style={{ flexDirection: 'row', justifyContent: 'space-around' }}>\n      <CursorTestComponent cursor='auto' />\n      <CursorTestComponent cursor='default' />\n      <CursorTestComponent cursor='help' />\n      <CursorTestComponent cursor='nesw-resize' />\n      <CursorTestComponent cursor='not-allowed' />\n      <CursorTestComponent cursor='ns-resize' />\n      <CursorTestComponent cursor='nwse-resize' />\n      <CursorTestComponent cursor='pointer' />\n      <CursorTestComponent cursor='wait' />\n      <CursorTestComponent cursor='move' />\n      <CursorTestComponent cursor='text' />\n      <CursorTestComponent cursor='we-resize' />\n    </ViewWin32>\n  );\n}\n\nexport const title = 'ViewWin32';\nexport const displayName = 'ViewWin32 Example';\nexport const description = 'All the stock View props plus Win32 specific ones';\nexport const examples = [\n  {\n    title: 'focus() method example',\n    description: 'Each of these black boxes moves focus to the ViewWin32 on the right',\n    render(): JSX.Element {\n      return (\n        <ViewWin32>\n          <FocusMoverTestComponent />\n          <FocusMoverTestComponent />\n          <FocusMoverTestComponent />\n        </ViewWin32>\n      );\n    },\n  },\n  {\n    title: 'KeyboardEvents example',\n    description: 'Native keyboarding has been prevented',\n    render(): JSX.Element {\n      return <KeyboardTestComponent />;\n    },\n  },\n  {\n    title: 'Hover example',\n    description: 'Hover a rainbow',\n    render(): JSX.Element {\n      return <HoverExample />;\n    },\n  },\n  {\n    title: 'Tooltip example',\n    description: 'Displays a tooltip on hover',\n    render(): JSX.Element {\n      return <ToolTipExample />;\n    },\n  },\n  {\n    title: 'Cursor example',\n    description: 'Each of these boxes should display a different cursor',\n    render(): JSX.Element {\n      return <CursorExample />;\n    },\n  },\n];\n"]}
|
|
280
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ViewWin32Test.js","sourceRoot":"","sources":["../../../../src/Libraries/Components/View/Tests/ViewWin32Test.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;;;;;;;;;;;;;;;;AACb,6BAA+B;AAC/B,6CAAoE;AACpE,0CAAyC;AAGzC,IAAM,MAAM,GAAG,yBAAU,CAAC,MAAM,CAAC;IAC/B,MAAM,EAAE;QACN,WAAW,EAAE,QAAQ;QACrB,WAAW,EAAE,OAAO;KACrB;IACD,gBAAgB,EAAE;QAChB,WAAW,EAAE,CAAC;QACd,aAAa,EAAE,KAAK;QACpB,cAAc,EAAE,CAAC;QACjB,eAAe,EAAE,YAAY;QAC7B,cAAc,EAAE,cAAc;KAC/B;IACD,kBAAkB,EAAE;QAClB,MAAM,EAAE,CAAC;QACT,UAAU,EAAE,QAAQ;QACpB,QAAQ,EAAE,GAAG;QACb,SAAS,EAAE,EAAE;KACd;IACD,QAAQ,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,WAAW,EAAE,OAAO,EAAE,WAAW,EAAE,CAAC,EAAE;CAC1E,CAAC,CAAC;AAMH;IAAsC,2CAA6C;IAIjF,iCAAmB,KAAK;QAAxB,YACE,kBAAM,KAAK,CAAC,SAKb;QATO,kBAAY,GAAc,IAAI,CAAC;QAiCtB,aAAO,GAAG,UAAC,GAAc;YACxC,KAAI,CAAC,YAAY,GAAG,GAAG,CAAC;QAC1B,CAAC,CAAC;QAEe,cAAQ,GAAG;YAC1B,IAAI,KAAI,CAAC,YAAY,KAAK,SAAS,EAAE;gBACnC,KAAI,CAAC,YAAY,CAAC,KAAK,EAAE,CAAC;aAC3B;QACH,CAAC,CAAC;QAEe,cAAQ,GAAG;YAC1B,KAAI,CAAC,QAAQ,CAAC;gBACZ,QAAQ,EAAE,IAAI;aACf,CAAC,CAAC;QACL,CAAC,CAAC;QAEe,aAAO,GAAG;YACzB,KAAI,CAAC,QAAQ,CAAC;gBACZ,QAAQ,EAAE,KAAK;aAChB,CAAC,CAAC;QACL,CAAC,CAAC;QAhDA,KAAI,CAAC,KAAK,GAAG;YACX,QAAQ,EAAE,KAAK;SAChB,CAAC;QACF,KAAI,CAAC,UAAU,GAAG,KAAK,CAAC,SAAS,EAAa,CAAC;;IACjD,CAAC;IACM,wCAAM,GAAb;QACE,OAAO,CACL,oBAAC,qBAAS;YACR,oBAAC,qBAAS,IAAC,GAAG,EAAE,IAAI,CAAC,UAAU,EAAE,kBAAkB,EAAC,yBAAyB,EAAC,qBAAqB,EAAC,SAAS,GAAG;YAClH,oBAAC,qBAAS,IAAC,KAAK,EAAE,EAAE,aAAa,EAAE,KAAK,EAAE,UAAU,EAAE,QAAQ,EAAE,cAAc,EAAE,cAAc,EAAE,cAAc,EAAE,CAAC,EAAE;gBACjH,oBAAC,iCAAkB,IAAC,OAAO,EAAE,IAAI,CAAC,QAAQ;oBACxC,oBAAC,qBAAS,IAAC,sBAAsB,EAAE,IAAI,CAAC,UAAU,EAAE,KAAK,EAAE,MAAM,CAAC,QAAQ,GAAI,CAC3D;gBACrB,oBAAC,qBAAS,IACR,GAAG,EAAE,IAAI,CAAC,OAAO,EACjB,SAAS,QACT,KAAK,EAAE,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,eAAe,EAAE,WAAW,EAAE,CAAC,CAAC,CAAC,EAAE,eAAe,EAAE,WAAW,EAAE,EAChG,OAAO,EAAE,IAAI,CAAC,QAAQ,EACtB,MAAM,EAAE,IAAI,CAAC,OAAO,EACpB,eAAe,EAAE,KAAK;oBAEtB,oBAAC,mBAAI,QAAE,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,WAAW,CAAQ,CACrD,CACF,CACA,CACb,CAAC;IACJ,CAAC;IAuBH,8BAAC;AAAD,CAAC,AAvDD,CAAsC,KAAK,CAAC,SAAS,GAuDpD;AAOD,IAAM,2BAA2B,GAA4B;IAC3D,EAAE,GAAG,EAAE,WAAW,EAAE;IACpB,EAAE,GAAG,EAAE,SAAS,EAAE;IAClB,EAAE,GAAG,EAAE,WAAW,EAAE;IACpB,EAAE,GAAG,EAAE,YAAY,EAAE;IACrB,EAAE,GAAG,EAAE,KAAK,EAAE;CACf,CAAC;AAEF;IAAoC,yCAA2E;IAC7G,+BAAmB,KAAK;QAAxB,YACE,kBAAM,KAAK,CAAC,SAMb;QA6BgB,cAAQ,GAAG;YAC1B,KAAI,CAAC,QAAQ,CAAC;gBACZ,QAAQ,EAAE,IAAI;aACf,CAAC,CAAC;QACL,CAAC,CAAC;QAEe,aAAO,GAAG;YACzB,KAAI,CAAC,QAAQ,CAAC;gBACZ,QAAQ,EAAE,KAAK;aAChB,CAAC,CAAC;QACL,CAAC,CAAC;QAEe,cAAQ,GAAG,UAAC,EAAkB;YAC7C,KAAI,CAAC,QAAQ,CAAC,EAAE,SAAS,EAAE,EAAE,CAAC,WAAW,CAAC,GAAG,EAAE,WAAW,EAAE,IAAI,EAAE,CAAC,CAAC;QACtE,CAAC,CAAC;QAEe,gBAAU,GAAG,UAAC,EAAkB;YAC/C,KAAI,CAAC,QAAQ,CAAC,EAAE,WAAW,EAAE,EAAE,CAAC,WAAW,CAAC,GAAG,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;QACtE,CAAC,CAAC;QApDA,KAAI,CAAC,KAAK,GAAG;YACX,QAAQ,EAAE,KAAK;YACf,WAAW,EAAE,IAAI;YACjB,SAAS,EAAE,IAAI;SAChB,CAAC;;IACJ,CAAC;IAEM,sCAAM,GAAb;QACE,OAAO,CACL,oBAAC,qBAAS,IAAC,aAAa,EAAE,2BAA2B,EAAE,WAAW,EAAE,2BAA2B;YAC7F,oBAAC,qBAAS,IACR,KAAK,EAAE,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,gBAAgB,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,gBAAgB,EAC/F,SAAS,QACT,OAAO,EAAE,IAAI,CAAC,QAAQ,EACtB,SAAS,EAAE,IAAI,CAAC,UAAU,EAC1B,OAAO,EAAE,IAAI,CAAC,QAAQ,EACtB,MAAM,EAAE,IAAI,CAAC,OAAO,EACpB,eAAe,EAAE,KAAK;gBAEtB,oBAAC,qBAAS,IAAC,KAAK,EAAE,MAAM,CAAC,kBAAkB;oBACzC,oBAAC,mBAAI,oBAAiB;oBACtB,oBAAC,mBAAI,eAAY;oBACjB,oBAAC,mBAAI,QAAE,IAAI,CAAC,KAAK,CAAC,WAAW,KAAK,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC,CAAC,GAAG,CAAQ,CACnE;gBACZ,oBAAC,qBAAS,IAAC,KAAK,EAAE,MAAM,CAAC,kBAAkB;oBACzC,oBAAC,mBAAI,kBAAe;oBACpB,oBAAC,mBAAI,eAAY;oBACjB,oBAAC,mBAAI,QAAE,IAAI,CAAC,KAAK,CAAC,SAAS,KAAK,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,CAAQ,CAC/D,CACF,CACF,CACb,CAAC;IACJ,CAAC;IAqBH,4BAAC;AAAD,CAAC,AAxDD,CAAoC,KAAK,CAAC,SAAS,GAwDlD;AAKD;IAAiC,sCAA+D;IAC9F,4BAAmB,KAAK;QAAxB,YACE,kBAAM,KAAK,CAAC,SAIb;QAWgB,mBAAa,GAAG;YAC/B,KAAI,CAAC,QAAQ,CAAC,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,CAAC;QACrC,CAAC,CAAC;QACe,mBAAa,GAAG;YAC/B,KAAI,CAAC,QAAQ,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC;QACpC,CAAC,CAAC;QAnBA,KAAI,CAAC,KAAK,GAAG;YACX,QAAQ,EAAE,KAAK;SAChB,CAAC;;IACJ,CAAC;IAEM,mCAAM,GAAb;QACE,OAAO,CACL,oBAAC,qBAAS,IACR,YAAY,EAAE,IAAI,CAAC,aAAa,EAChC,YAAY,EAAE,IAAI,CAAC,aAAa,EAChC,KAAK,EAAE,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,QAAQ,EAAE,EAAE,eAAe,EAAE,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,QAAQ,GACvG,CACH,CAAC;IACJ,CAAC;IAOH,yBAAC;AAAD,CAAC,AAvBD,CAAiC,KAAK,CAAC,SAAS,GAuB/C;AAED;IAA2B,gCAAe;IAA1C;;IAcA,CAAC;IAbQ,6BAAM,GAAb;QACE,OAAO,CACL,oBAAC,qBAAS,IAAC,KAAK,EAAE,EAAE,aAAa,EAAE,KAAK,EAAE,gBAAgB,EAAE,EAAE,EAAE,cAAc,EAAE,cAAc,EAAE;YAC9F,oBAAC,kBAAkB,IAAC,KAAK,EAAC,KAAK,GAAG;YAClC,oBAAC,kBAAkB,IAAC,KAAK,EAAC,QAAQ,GAAG;YACrC,oBAAC,kBAAkB,IAAC,KAAK,EAAC,QAAQ,GAAG;YACrC,oBAAC,kBAAkB,IAAC,KAAK,EAAC,OAAO,GAAG;YACpC,oBAAC,kBAAkB,IAAC,KAAK,EAAC,MAAM,GAAG;YACnC,oBAAC,kBAAkB,IAAC,KAAK,EAAC,QAAQ,GAAG;YACrC,oBAAC,kBAAkB,IAAC,KAAK,EAAC,QAAQ,GAAG,CAC3B,CACb,CAAC;IACJ,CAAC;IACH,mBAAC;AAAD,CAAC,AAdD,CAA2B,KAAK,CAAC,SAAS,GAczC;AAED,IAAM,cAAc,GAAgC;IAClD,OAAO,CACL,oBAAC,qBAAS,IACR,KAAK,EAAE;YACL,eAAe,EAAE,KAAK;YACtB,MAAM,EAAE,GAAG;YACX,KAAK,EAAE,GAAG;SACX,EACD,OAAO,EAAC,iBAAiB,EACzB,MAAM,EAAC,SAAS,GAChB,CACH,CAAC;AACJ,CAAC,CAAC;AAMF,IAAM,mBAAmB,GAAuD,UAAC,KAAK;IACpF,OAAO,CACL,oBAAC,qBAAS,IAAC,KAAK,EAAE,EAAC,aAAa,EAAE,QAAQ,EAAC;QACzC,oBAAC,mBAAI,QAAE,KAAK,CAAC,MAAM,CAAQ;QAC3B,oBAAC,qBAAS,IAAC,MAAM,EAAE,KAAK,CAAC,MAAM,EAAE,KAAK,EAAE,MAAM,CAAC,QAAQ,GAAI,CACjD,CACb,CAAA;AACH,CAAC,CAAA;AAED,IAAM,aAAa,GAA4B;IAC7C,OAAO,CACL,oBAAC,qBAAS,IAAC,KAAK,EAAE,EAAE,aAAa,EAAE,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE;QACxE,oBAAC,mBAAmB,IAAC,MAAM,EAAC,MAAM,GAAG;QACrC,oBAAC,mBAAmB,IAAC,MAAM,EAAC,SAAS,GAAG;QACxC,oBAAC,mBAAmB,IAAC,MAAM,EAAC,MAAM,GAAG;QACrC,oBAAC,mBAAmB,IAAC,MAAM,EAAC,aAAa,GAAG;QAC5C,oBAAC,mBAAmB,IAAC,MAAM,EAAC,aAAa,GAAG;QAC5C,oBAAC,mBAAmB,IAAC,MAAM,EAAC,WAAW,GAAG;QAC1C,oBAAC,mBAAmB,IAAC,MAAM,EAAC,aAAa,GAAG;QAC5C,oBAAC,mBAAmB,IAAC,MAAM,EAAC,SAAS,GAAG;QACxC,oBAAC,mBAAmB,IAAC,MAAM,EAAC,MAAM,GAAG;QACrC,oBAAC,mBAAmB,IAAC,MAAM,EAAC,MAAM,GAAG;QACrC,oBAAC,mBAAmB,IAAC,MAAM,EAAC,MAAM,GAAG;QACrC,oBAAC,mBAAmB,IAAC,MAAM,EAAC,WAAW,GAAG,CAChC,CACb,CAAC;AACJ,CAAC,CAAA;AACD;IAAqC,0CAA6C;IAChF,gCAAmB,KAAK;QAAxB,YACE,kBAAM,KAAK,CAAC,SAIb;QAoCgB,cAAQ,GAAG;YAC1B,KAAI,CAAC,QAAQ,CAAC;gBACZ,QAAQ,EAAE,IAAI;aACf,CAAC,CAAC;QACL,CAAC,CAAC;QAEe,aAAO,GAAG;YACzB,KAAI,CAAC,QAAQ,CAAC;gBACZ,QAAQ,EAAE,KAAK;aAChB,CAAC,CAAC;QACL,CAAC,CAAC;QAjDA,KAAI,CAAC,KAAK,GAAG;YACX,QAAQ,EAAE,KAAK;SAChB,CAAC;;IACJ,CAAC;IAEM,uCAAM,GAAb;QACE,OAAO,CACL,oBAAC,qBAAS,IAAC,KAAK,EAAE,EAAE,aAAa,EAAE,KAAK,EAAE,UAAU,EAAE,QAAQ,EAAE,cAAc,EAAE,cAAc,EAAE,cAAc,EAAE,CAAC,EAAE;YACjH,oBAAC,qBAAS,IACR,KAAK,EAAE;oBACL,eAAe,EAAE,MAAM;oBACvB,MAAM,EAAE,GAAG;oBACX,KAAK,EAAE,GAAG;iBACX,EACD,eAAe,EAAE,IAAI,EACrB,SAAS;gBAET,oBAAC,mBAAI,sCAAmC,CAC9B;YACZ,oBAAC,qBAAS,IACR,KAAK,EAAE;oBACL,eAAe,EAAE,MAAM;oBACvB,MAAM,EAAE,GAAG;oBACX,KAAK,EAAE,GAAG;iBACX,EACD,eAAe,EAAE,KAAK,EACtB,SAAS,QACT,OAAO,EAAE,IAAI,CAAC,QAAQ,EACtB,MAAM,EAAE,IAAI,CAAC,OAAO;gBAEpB;oBACE,oBAAC,mBAAI,uCAAoC;oBACzC,oBAAC,mBAAI,QAAE,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,WAAW,CAAQ,CAC9D,CACO,CACF,CACb,CAAC;IACJ,CAAC;IAaH,6BAAC;AAAD,CAAC,AArDD,CAAqC,KAAK,CAAC,SAAS,GAqDnD;AAGY,QAAA,KAAK,GAAG,WAAW,CAAC;AACpB,QAAA,WAAW,GAAG,mBAAmB,CAAC;AAClC,QAAA,WAAW,GAAG,mDAAmD,CAAC;AAClE,QAAA,QAAQ,GAAG;IACtB;QACE,KAAK,EAAE,wBAAwB;QAC/B,WAAW,EAAE,qEAAqE;QAClF,MAAM,EAAN;YACE,OAAO,CACL,oBAAC,qBAAS;gBACR,oBAAC,uBAAuB,OAAG;gBAC3B,oBAAC,uBAAuB,OAAG;gBAC3B,oBAAC,uBAAuB,OAAG,CACjB,CACb,CAAC;QACJ,CAAC;KACF;IACD;QACE,KAAK,EAAE,wBAAwB;QAC/B,WAAW,EAAE,uCAAuC;QACpD,MAAM,EAAN;YACE,OAAO,oBAAC,qBAAqB,OAAG,CAAC;QACnC,CAAC;KACF;IACD;QACE,KAAK,EAAE,eAAe;QACtB,WAAW,EAAE,iBAAiB;QAC9B,MAAM,EAAN;YACE,OAAO,oBAAC,YAAY,OAAG,CAAC;QAC1B,CAAC;KACF;IACD;QACE,KAAK,EAAE,iBAAiB;QACxB,WAAW,EAAE,6BAA6B;QAC1C,MAAM,EAAN;YACE,OAAO,oBAAC,cAAc,OAAG,CAAC;QAC5B,CAAC;KACF;IACD;QACE,KAAK,EAAE,gBAAgB;QACvB,WAAW,EAAE,uDAAuD;QACpE,MAAM,EAAN;YACE,OAAO,oBAAC,aAAa,OAAG,CAAC;QAC3B,CAAC;KACF;IACD;QACE,KAAK,EAAE,yBAAyB;QAChC,WAAW,EAAE,kDAAkD;QAC/D,MAAM,EAAN;YACE,OAAO,oBAAC,sBAAsB,OAAG,CAAC;QACpC,CAAC;KACF;CACF,CAAC","sourcesContent":["'use strict';\nimport * as React from 'react';\nimport { StyleSheet, Text, TouchableHighlight } from 'react-native';\nimport { ViewWin32 } from '../ViewWin32';\nimport { Cursor, IKeyboardEvent, IHandledKeyboardEvent } from '../ViewWin32.Props';\n\nconst styles = StyleSheet.create({\n  border: {\n    borderStyle: 'dotted',\n    borderColor: 'black',\n  },\n  keyComponentRoot: {\n    borderWidth: 2,\n    flexDirection: 'row',\n    marginVertical: 5,\n    backgroundColor: 'whitesmoke',\n    justifyContent: 'space-around',\n  },\n  keyEnterVisualizer: {\n    margin: 5,\n    alignItems: 'center',\n    minWidth: 100,\n    minHeight: 30,\n  },\n  blackbox: { height: 30, width: 30, borderColor: 'black', borderWidth: 3 },\n});\n\ninterface IFocusableComponentState {\n  hasFocus: boolean;\n}\n\nclass FocusMoverTestComponent extends React.Component<{}, IFocusableComponentState> {\n  private _focusTarget: ViewWin32 = null;\n  private readonly _labeledBy: React.RefObject<ViewWin32>;\n\n  public constructor(props) {\n    super(props);\n    this.state = {\n      hasFocus: false,\n    };\n    this._labeledBy = React.createRef<ViewWin32>();\n  }\n  public render() {\n    return (\n      <ViewWin32>\n        <ViewWin32 ref={this._labeledBy} accessibilityLabel=\"separate label for test\" accessibilityItemType=\"Comment\" />\n      <ViewWin32 style={{ flexDirection: 'row', alignItems: 'center', justifyContent: 'space-around', marginVertical: 5 }}>\n        <TouchableHighlight onPress={this._onPress}>\n          <ViewWin32 accessibilityLabeledBy={this._labeledBy} style={styles.blackbox} />\n        </TouchableHighlight>\n        <ViewWin32\n          ref={this._setRef}\n          focusable\n          style={this.state.hasFocus ? { backgroundColor: '#aee8fcff' } : { backgroundColor: '#00000000' }}\n          onFocus={this._onFocus}\n          onBlur={this._onBlur}\n          enableFocusRing={false}\n        >\n          <Text>{this.state.hasFocus ? 'Focus: Yes' : 'Focus: No'}</Text>\n        </ViewWin32>\n      </ViewWin32>\n      </ViewWin32>\n    );\n  }\n\n  private readonly _setRef = (ref: ViewWin32) => {\n    this._focusTarget = ref;\n  };\n\n  private readonly _onPress = () => {\n    if (this._focusTarget !== undefined) {\n      this._focusTarget.focus();\n    }\n  };\n\n  private readonly _onFocus = () => {\n    this.setState({\n      hasFocus: true,\n    });\n  };\n\n  private readonly _onBlur = () => {\n    this.setState({\n      hasFocus: false,\n    });\n  };\n}\n\ninterface IKeyboardableComponentState {\n  lastKeyDown: string;\n  lastKeyUp: string;\n}\n\nconst handledNativeKeyboardEvents: IHandledKeyboardEvent[] = [\n  { key: 'ArrowDown' },\n  { key: 'ArrowUp' },\n  { key: 'ArrowLeft' },\n  { key: 'ArrowRight' },\n  { key: 'Tab' },\n];\n\nclass KeyboardTestComponent extends React.Component<{}, IFocusableComponentState & IKeyboardableComponentState> {\n  public constructor(props) {\n    super(props);\n    this.state = {\n      hasFocus: false,\n      lastKeyDown: null,\n      lastKeyUp: null,\n    };\n  }\n\n  public render() {\n    return (\n      <ViewWin32 keyDownEvents={handledNativeKeyboardEvents} keyUpEvents={handledNativeKeyboardEvents}>\n        <ViewWin32\n          style={this.state.hasFocus ? [styles.keyComponentRoot, styles.border] : styles.keyComponentRoot}\n          focusable\n          onKeyUp={this._onKeyUp}\n          onKeyDown={this._onKeyDown}\n          onFocus={this._onFocus}\n          onBlur={this._onBlur}\n          enableFocusRing={false}\n        >\n          <ViewWin32 style={styles.keyEnterVisualizer}>\n            <Text>OnKeyDown</Text>\n            <Text>----</Text>\n            <Text>{this.state.lastKeyDown !== null ? this.state.lastKeyDown : ' '}</Text>\n          </ViewWin32>\n          <ViewWin32 style={styles.keyEnterVisualizer}>\n            <Text>OnKeyUp</Text>\n            <Text>----</Text>\n            <Text>{this.state.lastKeyUp !== null ? this.state.lastKeyUp : ' '}</Text>\n          </ViewWin32>\n        </ViewWin32>\n      </ViewWin32>\n    );\n  }\n\n  private readonly _onFocus = () => {\n    this.setState({\n      hasFocus: true,\n    });\n  };\n\n  private readonly _onBlur = () => {\n    this.setState({\n      hasFocus: false,\n    });\n  };\n\n  private readonly _onKeyUp = (ev: IKeyboardEvent) => {\n    this.setState({ lastKeyUp: ev.nativeEvent.key, lastKeyDown: null });\n  };\n\n  private readonly _onKeyDown = (ev: IKeyboardEvent) => {\n    this.setState({ lastKeyDown: ev.nativeEvent.key, lastKeyUp: null });\n  };\n}\n\ninterface IHoverComponentProps {\n  color: string;\n}\nclass HoverTestComponent extends React.Component<IHoverComponentProps, IFocusableComponentState> {\n  public constructor(props) {\n    super(props);\n    this.state = {\n      hasFocus: false,\n    };\n  }\n\n  public render() {\n    return (\n      <ViewWin32\n        onMouseEnter={this._onMouseEnter}\n        onMouseLeave={this._onMouseLeave}\n        style={this.state.hasFocus ? [styles.blackbox, { backgroundColor: this.props.color }] : styles.blackbox}\n      />\n    );\n  }\n  private readonly _onMouseLeave = () => {\n    this.setState({ hasFocus: false });\n  };\n  private readonly _onMouseEnter = () => {\n    this.setState({ hasFocus: true });\n  };\n}\n\nclass HoverExample extends React.Component {\n  public render() {\n    return (\n      <ViewWin32 style={{ flexDirection: 'row', marginHorizontal: 75, justifyContent: 'space-around' }}>\n        <HoverTestComponent color=\"red\" />\n        <HoverTestComponent color=\"orange\" />\n        <HoverTestComponent color=\"yellow\" />\n        <HoverTestComponent color=\"green\" />\n        <HoverTestComponent color=\"blue\" />\n        <HoverTestComponent color=\"indigo\" />\n        <HoverTestComponent color=\"violet\" />\n      </ViewWin32>\n    );\n  }\n}\n\nconst ToolTipExample: React.FunctionComponent<{}> = () => {\n  return (\n    <ViewWin32\n      style={{\n        backgroundColor: 'red',\n        height: 100,\n        width: 100,\n      }}\n      tooltip=\"Example tooltip\"\n      cursor=\"pointer\"\n    />\n  );\n};\n\ninterface ICursorTestComponentProps {\n  cursor: Cursor\n}\n\nconst CursorTestComponent: React.FunctionComponent<ICursorTestComponentProps> = (props) => {\n  return (\n    <ViewWin32 style={{flexDirection: 'column'}}>\n      <Text>{props.cursor}</Text>\n      <ViewWin32 cursor={props.cursor} style={styles.blackbox} />\n    </ViewWin32>\n  )\n}\n\nconst CursorExample: React.FunctionComponent = () => {\n  return (\n    <ViewWin32 style={{ flexDirection: 'row', justifyContent: 'space-around' }}>\n      <CursorTestComponent cursor='auto' />\n      <CursorTestComponent cursor='default' />\n      <CursorTestComponent cursor='help' />\n      <CursorTestComponent cursor='nesw-resize' />\n      <CursorTestComponent cursor='not-allowed' />\n      <CursorTestComponent cursor='ns-resize' />\n      <CursorTestComponent cursor='nwse-resize' />\n      <CursorTestComponent cursor='pointer' />\n      <CursorTestComponent cursor='wait' />\n      <CursorTestComponent cursor='move' />\n      <CursorTestComponent cursor='text' />\n      <CursorTestComponent cursor='we-resize' />\n    </ViewWin32>\n  );\n}\nclass EnableFocusRingExample extends React.Component<{}, IFocusableComponentState> {\n  public constructor(props) {\n    super(props);\n    this.state = {\n      hasFocus: false,\n    };\n  }\n  \n  public render() {\n    return (\n      <ViewWin32 style={{ flexDirection: 'row', alignItems: 'center', justifyContent: 'space-around', marginVertical: 5 }}>\n        <ViewWin32\n          style={{\n            backgroundColor: 'pink',\n            height: 100,\n            width: 100,\n          }}\n          enableFocusRing={true}\n          focusable\n        >\n          <Text>enableFocusRing set to true</Text>\n        </ViewWin32>\n        <ViewWin32\n          style={{\n            backgroundColor: 'pink',\n            height: 100,\n            width: 100,\n          }}\n          enableFocusRing={false}\n          focusable\n          onFocus={this._onFocus}\n          onBlur={this._onBlur}\n        >\n          <>\n            <Text>enableFocusRing set to false</Text>\n            <Text>{this.state.hasFocus ? 'Focus: Yes' : 'Focus: No'}</Text>\n          </>\n        </ViewWin32>\n      </ViewWin32>\n    );\n  }\n\n  private readonly _onFocus = () => {\n    this.setState({\n      hasFocus: true,\n    });\n  };\n\n  private readonly _onBlur = () => {\n    this.setState({\n      hasFocus: false,\n    });\n  };\n}\n\n\nexport const title = 'ViewWin32';\nexport const displayName = 'ViewWin32 Example';\nexport const description = 'All the stock View props plus Win32 specific ones';\nexport const examples = [\n  {\n    title: 'focus() method example',\n    description: 'Each of these black boxes moves focus to the ViewWin32 on the right',\n    render(): JSX.Element {\n      return (\n        <ViewWin32>\n          <FocusMoverTestComponent />\n          <FocusMoverTestComponent />\n          <FocusMoverTestComponent />\n        </ViewWin32>\n      );\n    },\n  },\n  {\n    title: 'KeyboardEvents example',\n    description: 'Native keyboarding has been prevented',\n    render(): JSX.Element {\n      return <KeyboardTestComponent />;\n    },\n  },\n  {\n    title: 'Hover example',\n    description: 'Hover a rainbow',\n    render(): JSX.Element {\n      return <HoverExample />;\n    },\n  },\n  {\n    title: 'Tooltip example',\n    description: 'Displays a tooltip on hover',\n    render(): JSX.Element {\n      return <ToolTipExample />;\n    },\n  },\n  {\n    title: 'Cursor example',\n    description: 'Each of these boxes should display a different cursor',\n    render(): JSX.Element {\n      return <CursorExample />;\n    },\n  },\n  {\n    title: 'EnableFocusRing example',\n    description: 'Displays focus visuals that are driven by native',\n    render(): JSX.Element {\n      return <EnableFocusRingExample />;\n    },\n  },\n];\n"]}
|