UNPKG

@iterable/react-native-sdk

Version:
69 lines (65 loc) 3.04 kB
"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