2018-01-05 23:06:22 -08:00
|
|
|
/**
|
|
|
|
* Copyright (c) 2013-present, Facebook, Inc.
|
|
|
|
*
|
2018-02-16 18:24:55 -08:00
|
|
|
* This source code is licensed under the MIT license found in the
|
|
|
|
* LICENSE file in the root directory of this source tree.
|
2018-01-05 23:06:22 -08:00
|
|
|
*
|
|
|
|
* @flow
|
|
|
|
* @format
|
|
|
|
*/
|
|
|
|
|
|
|
|
'use strict';
|
|
|
|
|
accessibilityTraits + accessibilityComponentType >> accessibilityRole + accessibilityStates 1/3
Summary:
Previously, I created two props, `accessibilityRole` and `accessibilityStates` for view. These props were intended to be a cross-platform solution to replace `accessibilityComponentType` on Android and `accessibilityTraits` on iOS.
In this stack, I ran a code mod to replace instances of the two old properties used in our codebase with the new ones.
For this diff, I wrote a script that focuses on replacing instances of the two properties that only added a single role to `accessibilityTraits` and `accessibilityComponentType`. In summary, this script:
* replaces instances of `accessibilityTraits = "<iOStrait>"` with `accessibilityRole = "<iOStrait>"`
* replaces instances of `accessibilityTraits = {['<iOStrait>']}` with `accessibilityRole = "<iOStrait>"`
* replaces instances of `accessibilityTraits = {"<iOStrait>"}` with `accessibilityRole = "<iOStrait>"`
* removes instances of `accessibilityComponentType`
```
The following is the codeshift script I wrote:
/**
* Copyright (c) 2015-present, Facebook, Inc.
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*
* format
*/
'use strict';
export default function transformer(file, api) {
const j = api.jscodeshift;
const root = j(file.source);
let hasChanges = false;
const elements = root.find(j.JSXElement);
let values;
let valuess;
let valuesss;
elements.forEach(path => {
const openEl = path.node.openingElement;
hasChanges = true;
for (let i = 0; i < openEl.attributes.length; i++) {
if (openEl.attributes[i].name.name === 'accessibilityComponentType') {
openEl.attributes.splice(i, 1);
}
if (openEl.attributes[i].name.name === 'accessibilityTraits') {
if (openEl.attributes[i].value.expression) {
if (openEl.attributes[i].value.expression.type === 'Literal') {
values = openEl.attributes[i].value.expression.value;
openEl.attributes[i] = j.jsxAttribute(
j.jsxIdentifier('accessibilityRole'),
j.literal(values),
);
}
}
if (openEl.attributes[i].value) {
if (
openEl.attributes[i].value &&
openEl.attributes[i].value.type === 'Literal'
) {
valuess = openEl.attributes[i].value.value;
openEl.attributes[i] = j.jsxAttribute(
j.jsxIdentifier('accessibilityRole'),
j.literal(valuess),
);
}
}
if (openEl.attributes[i].value.expression) {
if (
openEl.attributes[i].value.expression.type === 'ArrayExpression' &&
openEl.attributes[i].value.expression.elements.length === 1
) {
valuesss = openEl.attributes[i].value.expression.elements[0].value;
openEl.attributes[i] = j.jsxAttribute(
j.jsxIdentifier('accessibilityRole'),
j.literal(valuesss),
);
}
}
}
}
});
if (hasChanges) {
return root.toSource();
} else {
return null;
}
}
```
I then used this command to run the codemod:
```
./scripts/js1/node_modules/.bin/jscodeshift -c 10 --parser=flow --transform ./scripts/js1/commands/codeshift/add-accessibilityRoles/index.js /data/sandcastle/boxes/instance-ide/xplat/js/RKJSModules/Apps
hg status -n | xargs /data/sandcastle/boxes/instance-ide/tools/third-party/prettier/node_modules/.bin/prettier --single-quote --no-bracket-spacing --jsx-bracket-same-line --trailing-comma all --parser flow --write --require-pragma --no-config
hg status -n | xargs ./scripts/eslint/eslint --plugin lint --no-eslintrc --parser babel-eslint --rule "lint/sort-requires: 1" --fix
js1 build buckfiles
```
Lastly, I had to add a few manual fixes:
* Checked that instances of `accessibilityComponentType` that were deleted were indeed replaced with `accessibilityRole`
* Added props `accessibilityRole` and `accessibilityStates` to `TouchableWithoutFeedBack` components and `TextProps` because they don't inherit properties directly from view.
Reviewed By: PeteTheHeat
Differential Revision: D8937323
fbshipit-source-id: 85bf4d596e8e7c7ace75ab0b0e68599043760840
2018-07-25 23:37:14 -07:00
|
|
|
import type {AccessibilityRole} from 'ViewAccessibility';
|
|
|
|
import type {AccessibilityState} from 'ViewAccessibility';
|
2018-04-19 13:13:10 -07:00
|
|
|
import type {AccessibilityTrait} from 'ViewAccessibility';
|
|
|
|
|
2018-01-05 23:06:22 -08:00
|
|
|
import type {Node} from 'react';
|
|
|
|
|
2018-03-10 18:29:06 -08:00
|
|
|
import type {LayoutEvent, PressEvent} from 'CoreEventTypes';
|
|
|
|
import type {DangerouslyImpreciseStyleProp} from 'StyleSheet';
|
2018-01-05 23:06:22 -08:00
|
|
|
|
2018-05-09 00:47:54 -07:00
|
|
|
export type PressRetentionOffset = $ReadOnly<{|
|
2018-01-05 23:06:22 -08:00
|
|
|
top: number,
|
|
|
|
left: number,
|
|
|
|
bottom: number,
|
|
|
|
right: number,
|
2018-05-09 00:47:54 -07:00
|
|
|
|}>;
|
2018-01-05 23:06:22 -08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @see https://facebook.github.io/react-native/docs/text.html#reference
|
|
|
|
*/
|
2018-03-10 18:29:06 -08:00
|
|
|
export type TextProps = $ReadOnly<{
|
|
|
|
accessible?: ?boolean,
|
accessibilityTraits + accessibilityComponentType >> accessibilityRole + accessibilityStates 1/3
Summary:
Previously, I created two props, `accessibilityRole` and `accessibilityStates` for view. These props were intended to be a cross-platform solution to replace `accessibilityComponentType` on Android and `accessibilityTraits` on iOS.
In this stack, I ran a code mod to replace instances of the two old properties used in our codebase with the new ones.
For this diff, I wrote a script that focuses on replacing instances of the two properties that only added a single role to `accessibilityTraits` and `accessibilityComponentType`. In summary, this script:
* replaces instances of `accessibilityTraits = "<iOStrait>"` with `accessibilityRole = "<iOStrait>"`
* replaces instances of `accessibilityTraits = {['<iOStrait>']}` with `accessibilityRole = "<iOStrait>"`
* replaces instances of `accessibilityTraits = {"<iOStrait>"}` with `accessibilityRole = "<iOStrait>"`
* removes instances of `accessibilityComponentType`
```
The following is the codeshift script I wrote:
/**
* Copyright (c) 2015-present, Facebook, Inc.
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*
* format
*/
'use strict';
export default function transformer(file, api) {
const j = api.jscodeshift;
const root = j(file.source);
let hasChanges = false;
const elements = root.find(j.JSXElement);
let values;
let valuess;
let valuesss;
elements.forEach(path => {
const openEl = path.node.openingElement;
hasChanges = true;
for (let i = 0; i < openEl.attributes.length; i++) {
if (openEl.attributes[i].name.name === 'accessibilityComponentType') {
openEl.attributes.splice(i, 1);
}
if (openEl.attributes[i].name.name === 'accessibilityTraits') {
if (openEl.attributes[i].value.expression) {
if (openEl.attributes[i].value.expression.type === 'Literal') {
values = openEl.attributes[i].value.expression.value;
openEl.attributes[i] = j.jsxAttribute(
j.jsxIdentifier('accessibilityRole'),
j.literal(values),
);
}
}
if (openEl.attributes[i].value) {
if (
openEl.attributes[i].value &&
openEl.attributes[i].value.type === 'Literal'
) {
valuess = openEl.attributes[i].value.value;
openEl.attributes[i] = j.jsxAttribute(
j.jsxIdentifier('accessibilityRole'),
j.literal(valuess),
);
}
}
if (openEl.attributes[i].value.expression) {
if (
openEl.attributes[i].value.expression.type === 'ArrayExpression' &&
openEl.attributes[i].value.expression.elements.length === 1
) {
valuesss = openEl.attributes[i].value.expression.elements[0].value;
openEl.attributes[i] = j.jsxAttribute(
j.jsxIdentifier('accessibilityRole'),
j.literal(valuesss),
);
}
}
}
}
});
if (hasChanges) {
return root.toSource();
} else {
return null;
}
}
```
I then used this command to run the codemod:
```
./scripts/js1/node_modules/.bin/jscodeshift -c 10 --parser=flow --transform ./scripts/js1/commands/codeshift/add-accessibilityRoles/index.js /data/sandcastle/boxes/instance-ide/xplat/js/RKJSModules/Apps
hg status -n | xargs /data/sandcastle/boxes/instance-ide/tools/third-party/prettier/node_modules/.bin/prettier --single-quote --no-bracket-spacing --jsx-bracket-same-line --trailing-comma all --parser flow --write --require-pragma --no-config
hg status -n | xargs ./scripts/eslint/eslint --plugin lint --no-eslintrc --parser babel-eslint --rule "lint/sort-requires: 1" --fix
js1 build buckfiles
```
Lastly, I had to add a few manual fixes:
* Checked that instances of `accessibilityComponentType` that were deleted were indeed replaced with `accessibilityRole`
* Added props `accessibilityRole` and `accessibilityStates` to `TouchableWithoutFeedBack` components and `TextProps` because they don't inherit properties directly from view.
Reviewed By: PeteTheHeat
Differential Revision: D8937323
fbshipit-source-id: 85bf4d596e8e7c7ace75ab0b0e68599043760840
2018-07-25 23:37:14 -07:00
|
|
|
accessibilityRole?: AccessibilityRole,
|
|
|
|
accessibilityStates?: Array<AccessibilityState>,
|
2018-04-19 13:13:10 -07:00
|
|
|
accessibilityTraits?: AccessibilityTrait | Array<AccessibilityTrait>,
|
2018-03-10 18:29:06 -08:00
|
|
|
allowFontScaling?: ?boolean,
|
2018-02-07 17:23:43 -08:00
|
|
|
children?: Node,
|
2018-01-05 23:06:22 -08:00
|
|
|
ellipsizeMode?: 'clip' | 'head' | 'middle' | 'tail',
|
|
|
|
nativeID?: string,
|
2018-03-10 18:29:06 -08:00
|
|
|
numberOfLines?: ?number,
|
|
|
|
onLayout?: ?(event: LayoutEvent) => mixed,
|
|
|
|
onLongPress?: ?(event: PressEvent) => mixed,
|
|
|
|
onPress?: ?(event: PressEvent) => mixed,
|
|
|
|
onResponderGrant?: ?Function,
|
|
|
|
onResponderMove?: ?Function,
|
|
|
|
onResponderRelease?: ?Function,
|
|
|
|
onResponderTerminate?: ?Function,
|
|
|
|
onResponderTerminationRequest?: ?Function,
|
|
|
|
onStartShouldSetResponder?: ?Function,
|
|
|
|
pressRetentionOffset?: ?PressRetentionOffset,
|
|
|
|
selectable?: ?boolean,
|
|
|
|
style?: ?DangerouslyImpreciseStyleProp,
|
2018-01-05 23:06:22 -08:00
|
|
|
testID?: string,
|
|
|
|
|
|
|
|
// Android Only
|
2018-03-10 18:29:06 -08:00
|
|
|
disabled?: ?boolean,
|
|
|
|
selectionColor?: ?string,
|
2018-01-05 23:06:22 -08:00
|
|
|
textBreakStrategy?: 'balanced' | 'highQuality' | 'simple',
|
|
|
|
|
|
|
|
// iOS Only
|
2018-03-10 18:29:06 -08:00
|
|
|
adjustsFontSizeToFit?: ?boolean,
|
|
|
|
minimumFontScale?: ?number,
|
|
|
|
suppressHighlighting?: ?boolean,
|
|
|
|
}>;
|