2023-11-09 11:19:08 -08:00
|
|
|
|
|
|
|
import * as React from 'react';
|
2024-01-18 03:22:20 -08:00
|
|
|
import { TextStyle, Text } from 'react-native';
|
|
|
|
|
2023-11-09 11:19:08 -08:00
|
|
|
const FontAwesomeIcon = require('react-native-vector-icons/FontAwesome5').default;
|
2024-01-18 03:22:20 -08:00
|
|
|
const AntIcon = require('react-native-vector-icons/AntDesign').default;
|
2024-05-25 06:41:27 -07:00
|
|
|
const MaterialCommunityIcon = require('react-native-vector-icons/MaterialCommunityIcons').default;
|
|
|
|
const Ionicon = require('react-native-vector-icons/Ionicons').default;
|
2023-11-09 11:19:08 -08:00
|
|
|
|
|
|
|
interface Props {
|
|
|
|
name: string;
|
|
|
|
style: TextStyle;
|
|
|
|
|
|
|
|
// If `null` is given, the content must be labeled elsewhere.
|
|
|
|
accessibilityLabel: string|null;
|
2024-01-18 03:22:20 -08:00
|
|
|
|
|
|
|
allowFontScaling?: boolean;
|
2023-11-09 11:19:08 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
const Icon: React.FC<Props> = props => {
|
|
|
|
// Matches:
|
|
|
|
// 1. A prefix of word characters (\w+)
|
|
|
|
// 2. A suffix of non-spaces (\S+)
|
|
|
|
// An "fa-" at the beginning of the suffix is ignored.
|
|
|
|
const nameMatch = props.name.match(/^(\w+)\s+(?:fa-)?(\S+)$/);
|
|
|
|
|
|
|
|
const namePrefix = nameMatch ? nameMatch[1] : '';
|
|
|
|
const nameSuffix = nameMatch ? nameMatch[2] : props.name;
|
|
|
|
|
|
|
|
// If there's no label, make sure that the screen reader doesn't try
|
|
|
|
// to read the characters from the icon font (they don't make sense
|
|
|
|
// without the icon font applied).
|
|
|
|
const accessibilityHidden = props.accessibilityLabel === null;
|
2024-01-18 03:22:20 -08:00
|
|
|
const importantForAccessibility = accessibilityHidden ? 'no-hide-descendants' : 'yes';
|
|
|
|
|
|
|
|
const sharedProps = {
|
|
|
|
importantForAccessibility,
|
|
|
|
'aria-hidden': accessibilityHidden,
|
|
|
|
accessibilityLabel: props.accessibilityLabel,
|
|
|
|
style: props.style,
|
|
|
|
allowFontScaling: props.allowFontScaling,
|
|
|
|
};
|
2023-11-09 11:19:08 -08:00
|
|
|
|
2024-01-18 03:22:20 -08:00
|
|
|
if (namePrefix.match(/^fa[bsr]?$/)) {
|
|
|
|
return (
|
|
|
|
<FontAwesomeIcon
|
|
|
|
brand={namePrefix.startsWith('fab')}
|
|
|
|
solid={namePrefix.startsWith('fas')}
|
|
|
|
name={nameSuffix}
|
|
|
|
{...sharedProps}
|
|
|
|
/>
|
|
|
|
);
|
|
|
|
} else if (namePrefix === 'ant') {
|
|
|
|
return <AntIcon name={nameSuffix} {...sharedProps}/>;
|
|
|
|
} else if (namePrefix === 'material') {
|
2024-05-25 06:41:27 -07:00
|
|
|
return <MaterialCommunityIcon name={nameSuffix} {...sharedProps}/>;
|
|
|
|
} else if (namePrefix === 'ionicon') {
|
|
|
|
return <Ionicon name={nameSuffix} {...sharedProps}/>;
|
2024-01-18 03:22:20 -08:00
|
|
|
} else if (namePrefix === 'text') {
|
|
|
|
return (
|
|
|
|
<Text
|
|
|
|
style={props.style}
|
|
|
|
aria-hidden={accessibilityHidden}
|
|
|
|
importantForAccessibility={importantForAccessibility}
|
|
|
|
>
|
|
|
|
{nameSuffix}
|
|
|
|
</Text>
|
|
|
|
);
|
|
|
|
} else {
|
|
|
|
return <FontAwesomeIcon name='cog' {...sharedProps}/>;
|
|
|
|
}
|
2023-11-09 11:19:08 -08:00
|
|
|
};
|
|
|
|
|
|
|
|
export default Icon;
|