Instagram is a photo sharing app using Parse as its backend.
Time spent: 11 hours spent on required features, 14 hours spent in total
The following required functionality is completed:
- User can sign up to create a new account using Parse authentication
- User can log in and log out of his or her account
- The current signed in user is persisted across app restarts
- User can take a photo, add a caption, and post it to "Instagram"
- User can view the last 20 posts submitted to "Instagram"
- User can pull to refresh the last 20 posts submitted to "Instagram"
- User can tap a post to view post details, including timestamp and caption.
The following optional features are implemented:
- Run your app on your phone and use the camera to take the photo
- Style the login page to look like the real Instagram login page.
- Style the feed to look like the real Instagram feed.
- User can use a tab bar to switch between all "Instagram" posts and posts published only by the user. AKA, tabs for Home Feed and Profile
- User can load more posts once he or she reaches the bottom of the feed using infinite scrolling.
- Show the username and creation time for each post
- After the user submits a new post, show a progress HUD while the post is being uploaded to Parse
- User Profiles:
- Allow the logged in user to add a profile photo
- Display the profile photo with each post
- Tapping on a post's username or profile photo goes to that user's profile page
- User can comment on a post and see all comments for each post in the post details screen.
- User can like a post and see number of likes for each post in the post details screen.
- Implement a custom camera view.
The following additional features are implemented:
- List anything else that you can get done to improve the app functionality!
Please list two areas of the assignment you'd like to discuss further with your peers during the next class (examples include better ways to implement something, how to extend your app in certain ways, etc):
- Different ways to implement gesture recognizers such as programmatically or through the storyboard and which is preferred.
- Resizing the image by making sure it is smaller than 10 MB rather than reducing the size of the image in pixels.
Here's a walkthrough of implemented user stories:
- Sign Up
- Log in / Log out
- User Persistence
- Compose, Post and Refresh
- View Feed
- Details
- Infinite Scrolling (5 new posts per fetch for demonstration purposes)
- Progress HUD
- Like/Dislike a post (implemented with a relation in the Posts table with Parse)
GIF created with LiceCap.
List an 3rd party libraries, icons, graphics, or other assets you used in your app.
- Due to a change in iOS 13, logging out did not take you back to the initial screen with the given snippet of code. The snippet of code needed to be updated so it is placed in the scene delegate rather than the app delegate in order to function properly.
- Displaying the imager picker was a bit confusing as I did not realize I had to present it as if I was presenting an alert. A quick search guided me toward the solution.
- Images posted from different devices were not appearing on other devices. For example, a post that came from an iPhone 8 would not appear on an iPhone SE. Enabling an exception for the database url fixed the issue.
Copyright 2020 David Lara
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.