@iterable/react-native-sdk
Version:
Iterable SDK for React Native.
69 lines (65 loc) • 3.04 kB
JavaScript
"use strict";
import { Image, PixelRatio, Platform, StyleSheet, Text, TouchableWithoutFeedback, View } from 'react-native';
import { ITERABLE_INBOX_COLORS } from "../constants/colors.js";
// Base64 encoded back arrow icons
// [Original image](https://github.com/react-navigation/react-navigation/blob/main/packages/elements/src/assets/back-icon%404x.ios.png)
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
const backArrowLarge = '';
export const ICON_SIZE = Platform.OS === 'ios' ? 21 : 24;
export const ICON_MARGIN = Platform.OS === 'ios' ? 8 : 3;
const ICON_COLOR = ITERABLE_INBOX_COLORS.BUTTON_PRIMARY_TEXT;
const styles = StyleSheet.create({
icon: {
height: ICON_SIZE,
margin: ICON_MARGIN,
width: ICON_SIZE
},
returnButton: {
alignItems: 'center',
display: 'flex',
flexDirection: 'row'
},
returnButtonText: {
color: ITERABLE_INBOX_COLORS.BUTTON_PRIMARY_TEXT,
fontSize: 20
}
});
/**
* Props for the HeaderBackButton component.
*/
/**
* A back arrow button used in a header
*
* @returns A button with a back arrow
*/
export const HeaderBackButton = ({
label,
imageUri = backArrowLarge,
imageSource = {
uri: imageUri,
width: PixelRatio.getPixelSizeForLayoutSize(ICON_SIZE),
height: PixelRatio.getPixelSizeForLayoutSize(ICON_SIZE)
},
...props
}) => {
return /*#__PURE__*/_jsx(TouchableWithoutFeedback, {
...props,
children: /*#__PURE__*/_jsxs(View, {
style: styles.returnButton,
children: [/*#__PURE__*/_jsx(Image, {
source: imageSource,
resizeMode: "contain",
fadeDuration: 0,
tintColor: ICON_COLOR,
style: styles.icon,
height: ICON_SIZE,
width: ICON_SIZE,
resizeMethod: "scale"
}), label && /*#__PURE__*/_jsx(Text, {
style: styles.returnButtonText,
children: label
})]
})
});
};
//# sourceMappingURL=HeaderBackButton.js.map