/twitter

twitter ios app

Primary LanguageObjective-C

Twitter iOS Application Redux

This is an enhanced version of the iOS iPhone Twitter Client made previously. In addition to the timeline view, a profile view has been added that contains a profile header along with tweet, following, and follower counts. Also added is a mentions view. A slide out menu (hamburger menu) has been added to switch between these main views. In the profile view, paging has been implemented to view the account description. Scaling and parallax have been implemented within the header view on pull down and scrolling. Tapping on a user's profile image loads the profile view for that user. When long-pressing the title bar or pulling down the profile screen, an account screen can be brought up to switch to another account, remove stored accounts, or authenticate with a new account.

Time spent: 32 hours spent in total

Completed user stories:

Hamburger menu

  • Dragging anywhere in the view should reveal the menu.
  • The menu should include links to your profile, the home timeline, and the mentions view.
  • Take liberty with the menu UI.

Profile page

  • Contains the user header view
  • Contains a section with the users basic stats: # tweets, # following, # followers
  • Optional: Implement the paging view for the user description.
  • Optional: As the paging view moves, increase the opacity of the background screen.
  • Optional: Pulling down the profile page should blur and resize the header image.

Home Timeline

  • Tapping on a user image should bring up that user's profile page
  • Optional: Account switching
  • Long press on tab bar to bring up Account view with animation
  • Tap account to switch to
  • Include a plus button to Add an Account
  • Swipe to delete an account

Notes

  • When tapping on a profile image for a user you are already viewing a profile for, a shake effect happens to indicate you are already viewing that user's profile, similar to today's twitter app.
  • Showing the accounts screen on long press was added to the navbar of the current user's profile page instead of the home timeline tab bar. No tab bar was used in this app.
  • Pulling down on the current user's profile page will bring up the accounts screen, similar to today's twitter app. The accounts screen can also be invoked via the slide out menu or by signing out the current user and there are other accounts stored.
  • I don't store multiple access tokens in this version so you still need to enter your password when switching accounts.

References:

Walkthrough of all user stories:

Video Walkthrough

GIF created with LiceCap.

Twitter iOS Application

This is an iOS iPhone Twitter Client that uses OAuth and the Twitter API Twitter API. The app can be used to sign into Twitter, tweet, view one's timeline, reply, retweet, and favorite a tweet.

Time spent: 21 hours spent in total

Completed user stories:

  • User can sign in using OAuth login flow
  • User can view last 20 tweets from their home timeline
  • The current signed in user will be persisted across restarts
  • In the home timeline, user can view tweet with the user profile picture, username, tweet text, and timestamp.
  • User can pull to refresh
  • User can compose a new tweet by tapping on a compose button.
  • User can tap on a tweet to view it, with controls to retweet, favorite, and reply.
  • Optional: When composing, you should have a countdown in the upper right for the tweet limit.
  • Optional: After creating a new tweet, a user should be able to view it in the timeline immediately without refetching the timeline from the network.
  • Optional: Retweeting and favoriting should increment the retweet and favorite count.
  • Optional: User should be able to unretweet and unfavorite and should decrement the retweet and favorite count.
  • Optional: Replies should be prefixed with the username and the reply_id should be set when posting the tweet,
  • Optional: User can load more tweets once they reach the bottom of the feed using infinite loading similar to the actual Twitter client.

References:

Walkthrough of all user stories:

Video Walkthrough

GIF created with LiceCap.