This is the updated version of public fork @alentoma/react-native-selectable-text.
- new project structure and updated dependencies
- rewrote the demo with newer react-native version
- fixed a few small issues
- added a feature I needed
- scrambled the heck out of this document
import {SelectableText} from '@armata99/react-native-selectable-text';
// Use normally, it is a drop-in replacement for react-native/Text
<SelectableText
menuItems={["Foo", "Bar"]}
/*
Called when the user taps in a item of the selection menu:
- eventType: (string) is the label
- content: (string) the selected text portion
- selectionStart: (int) is the start position of the selected text
- selectionEnd: (int) is the end position of the selected text
*/
onSelection={({ eventType, content, selectionStart, selectionEnd }) => {}}
value="I crave star damage"
/>;
I have NOT published this on NPM. Install it with repo URL if you need it.
npm i @armata99/react-native-selectable-text
yarn add @armata99/react-native-selectable-text
Create react-native.config.js in the root directory and execlude @armata99/react-native-selectable-text from linking
module.exports = {
dependencies: {
"@alentoma/react-native-selectable-text": {
platforms: {
android: null, // disable Android platform, other platforms will still autolink if provided
ios: null // disable IOS platform, other platforms will still autolink if provided
}
}
}
}
- In XCode, in the project navigator, right click
Libraries
➜Add Files to [your project's name]
- Go to
node_modules
➜@alentoma/react-native-selectable-text
and addRNSelectableText.xcodeproj
- In XCode, in the project navigator, select your project. Add
libRNSelectableText.a
to your project'sBuild Phases
➜Link Binary With Libraries
- Run your project (
Cmd+R
)<
- Add
pod 'RNSelectableText', :path => '../node_modules/@armata99/react-native-selectable-text/ios/RNSelectableText.podspec'
to your projects podfile - run
pod install
- Open up
android/app/src/main/java/[...]/MainActivity.java
- Add
import com.alentoma.selectabletext.RNSelectableTextPackage;
to the imports at the top of the file - Add
new RNSelectableTextPackage()
to the list returned by thegetPackages()
method
- Append the following lines to
android/settings.gradle
:include ':react-native-selectable-text' project(':react-native-selectable-text').projectDir = new File(rootProject.projectDir, '../node_modules/@alentoma/react-native-selectable-text/android')
- Insert the following lines inside the dependencies block in
android/app/build.gradle
:implementation project(':react-native-selectable-text')
Name | Description | Type | Default |
---|---|---|---|
value |
Text content | string |
"" |
onSelection |
Called when the user taps in a item of the selection menu | ({ eventType: string, content: string, selectionStart: int, selectionEnd: int }) => void |
() => {} |
menuItems |
Context menu items | array(string) |
[] |
style |
Additional styles to be applied to text | Object |
null |
highlights |
Array of text ranges that should be highlighted with an optional id | array({ id: string, start: int, end: int }) |
[] |
highlightColor |
Highlight color | string |
null |
onHighlightPress |
Called when the user taps the highlight | (id: string) => void |
() => {} |
appendToChildren |
Element to be added in the last line of text | ReactNode |
null |
TextComponent |
Text component used to render value |
ReactNode |
<Text> |
textValueProp |
Text value prop for TextComponent. Should be used when passing TextComponent. Defaults to 'children' which works for <Text> |
string |
'children' |
textComponentProps |
Additional props to pass to TextComponent | object |
null |