react-native-customemoji

Replace <Text> to putting <Image> inline with TextView for React Native

Usage no npm install needed!

<script type="module">
  import reactNativeCustomemoji from 'https://cdn.skypack.dev/react-native-customemoji';
</script>

README

react-native-customemoji

npm version

Replace <Text> to inline <Image> with <Text> for React Native

<CustomEmoji> component for react-native Modules.

Installation

npm i --save react-native-customemoji

Props

name desc type default
emojiStyle <Image> with styles Text.propTypes.style
emojis Emoji URL Defination Arrays Array {}
responsibleImage This issue fixes a bug in React Native with <Image> component inside of <Text> components. latest RN Version is fixed. bool false

ScreenShots

Examples

react-native-customemoji Example App

import React from "react";
import { StyleSheet, Text, View } from "react-native";
import CustomEmoji from "react-native-customemoji";

const emojiArray = {
  reactnative: {
    uri: "https://facebook.github.io/react-native/docs/assets/favicon.png"
  },
  mobile: require("./assets/mobile.png"),
  javascript: require("./assets/javascript.png"),
  react: {
    uri:
      ""
  }
};

export default class App extends React.Component {
  render() {
    return (
      <View style={styles.view}>
        <View style={styles.container}>
          <Text style={styles.largeText}>Welcome to :reactnative: !</Text>
          <Text style={styles.mediumText}>
            Build native :mobile: apps using :javascript: and :react:.
          </Text>
        </View>
        <View style={styles.container}>
          <CustomEmoji
            emojis={emojiArray}
            emojiStyle={{ borderRadius: 5, width: 30, height: 30 }}
          >
            <Text style={styles.largeText}>Welcome to :reactnative: !</Text>
          </CustomEmoji>
          <CustomEmoji emojis={emojiArray}>
            <Text style={styles.mediumText}>
              Build native :mobile: apps using :javascript: and :react:.
            </Text>
          </CustomEmoji>
        </View>
      </View>
    );
  }
}

const styles = StyleSheet.create({
  view: {
    flex: 1
  },
  container: {
    flex: 1,
    backgroundColor: "#fff",
    alignItems: "center",
    justifyContent: "center"
  },
  largeText: {
    fontSize: 30
  },
  mediumText: {
    fontSize: 14
  }
});

License

MIT