React Native Alternate Icons for iOS 10.3+
- React Native 0.44+ (only tested on 0.44)
npm install @hawkrives/react-native-alternate-icons@latest --save
react-native link
https://facebook.github.io/react-native/docs/linking-libraries-ios.html
<key>supportsAlternateIcons</key>
<true/>
<key>CFBundleIcons</key>
<dict>
<key>CFBundlePrimaryIcon</key>
<dict>
<key>CFBundleIconFiles</key>
<array>
<string>icon_filename</string>
</array>
<key>UIPrerenderedIcon</key>
<true/>
</dict>
<key>CFBundleAlternateIcons</key>
<dict>
<key>icon_type_alternate_name</key>
<dict>
<key>CFBundleIconFiles</key>
<array>
<string>alternate_icon_filename</string>
</array>
<key>UIPrerenderedIcon</key>
<true/>
</dict>
</dict>
</dict>
setIconName(name: string): Promise<void>
– takes one of the icon "names" defined in your Info.plist (icon_type_alternate_name
, in the example above)getIconName(): Promise<string>
– returns the current icon's namereset(): Promise<void>
– resets the icon to the default bundle iconisSupported(): Promise<boolean>
– checks if the current devide is supported. Always returnsfalse
on Android.
Because these all return promises, you can use them with ES2016's async/await syntax, too!
For example, you can import all of the functions as a namespace:
import * as Icons from '@hawkrives/react-native-alternate-icons';
await Icons.setIconName(iconName);
or import just one or two of them:
import {getIconName} from '@hawkrives/react-native-alternate-icons';
await getIconName();