Tweets come with all kinds of actionable elements inside them these days. Shortened URLs, #hashtags, @replies, and the actual message body. When you’re consuming a list of tweets, it’s important to be able to parse out these elements from the plain text so that they can be made into hyperlinks and directed at the proper location.
Take two common examples where this technique comes in handy: I) Displaying a tweet on a webpage. II) Displaying a tweet on an iOS application. In both cases you want the user to interact with the tweet if actions are available. With iOS this usually involves loading the tweet into a UIWebView so that you can work with multiple links within a single tweet. As is generally the case, there is more than one way to skin this cat.
Option 1: Parse the message body using Regular Expressions
Once you’ve retrieved the tweet message text, you can parse the action elements using the following functions:
Let’s say you’ve got the tweet text in a variable:
You can convert the plain text into hyperlinked action items by doing the following:
tweetText = tweetText.parseURL().parseUsername().parseHashtag();
Option 2: Reconstruct the message body using the entity array
The second option uses a separate array of elements returned by the Twitter API in conjunction with the message text to give you the actionable items (links, hashtags, mentions, media) and the insertion points within the text body.
For a more robust library, check out the twitter-text-js project on GitHub which also supports international character sets and handles a wide variety of common Twitter text processing tasks.