-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Đức Anh
committed
Jun 11, 2023
1 parent
924ae88
commit 4f24ac0
Showing
5 changed files
with
162 additions
and
85 deletions.
There are no files selected for viewing
21 changes: 0 additions & 21 deletions
21
InstagramClone/Assets.xcassets/heroImage.imageset/Contents.json
This file was deleted.
Oops, something went wrong.
21 changes: 0 additions & 21 deletions
21
InstagramClone/Assets.xcassets/more-icon.imageset/Contents.json
This file was deleted.
Oops, something went wrong.
21 changes: 0 additions & 21 deletions
21
InstagramClone/Assets.xcassets/three-line.imageset/Contents.json
This file was deleted.
Oops, something went wrong.
21 changes: 0 additions & 21 deletions
21
InstagramClone/Assets.xcassets/vtv24-logo.imageset/Contents.json
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1 +1,162 @@ | ||
# Instagram-Clone | ||
<!-- PROJECT LOGO --> | ||
<br /> | ||
<div align="center"> | ||
<a href="https://github.com/othneildrew/Best-README-Template"> | ||
<img src="images/instagram-logo.png" alt="Logo" width="80" height="80"> | ||
</a> | ||
|
||
<h3 align="center">Instagram Clone</h3> | ||
|
||
<p align="center"> | ||
An Instagram clone app made with Swift and Firebase. | ||
<br /> | ||
<a href="https://github.com/othneildrew/Best-README-Template"><strong>Explore the docs »</strong></a> | ||
<br /> | ||
<br /> | ||
<a href="https://github.com/othneildrew/Best-README-Template">View Demo</a> | ||
· | ||
<a href="https://github.com/othneildrew/Best-README-Template/issues">Report Bug</a> | ||
· | ||
<a href="https://github.com/othneildrew/Best-README-Template/issues">Request Feature</a> | ||
</p> | ||
</div> | ||
|
||
<!-- TABLE OF CONTENTS --> | ||
<details> | ||
<summary>Table of Contents</summary> | ||
<ol> | ||
<li> | ||
<a href="#about-the-project">About The Project</a> | ||
</li> | ||
<li> | ||
<a href="#features">Features</a> | ||
</li> | ||
<li><a href="#preview">Preview</a></li> | ||
<li><a href="#installation">Installation</a></li> | ||
<li><a href="#upcoming features">Upcoming Features</a></li> | ||
<li><a href="#contact">Contact</a></li> | ||
</ol> | ||
</details> | ||
|
||
<!-- ABOUT THE PROJECT --> | ||
## About The Project | ||
|
||
This project is being developed for educational purpose and is still under development, I will continue to add more feartures to it. | ||
|
||
In this repository, I try my best to mimic the key features of the Instagram. I have utilized serveral frameworks and classes in order to create a complex UI and ehanced UX, which include: | ||
|
||
- Architecture: | ||
- MVVM | ||
- UI: | ||
- PhotoKit: Allow user to select image from their Photo Library. | ||
- UICollectionViewCompositionalLayout: To create a complex layout with multi section and various layout. | ||
- UIView animate: For smoother experience and transition. | ||
- Database: | ||
- FirebaseAuth: Used for authenticating user. | ||
- FireStore: Used for storing and querying data of users and posts. | ||
- Storage: Used for storing user-generated content such as images. | ||
|
||
|
||
<p align="right">(<a href="#readme-top">back to top</a>)</p> | ||
|
||
<!-- Features --> | ||
## Features | ||
|
||
- Login and Signup Screen: | ||
- Allow user to log in if they already have an account or create a new one. | ||
- Home Screen: | ||
- View all posts from users that you are following. | ||
- Like post. | ||
- View all users who have liked the post. | ||
- View all comments on a post. | ||
- Explore Screen: | ||
- Display all photos of user's posts excluding from your own posts. | ||
- Be able to search user based on usernames. | ||
- Upload Post Screen: | ||
- Allow user to add photo to post from Library or Camera. | ||
- Post's caption is optional. | ||
- Profile Screen: | ||
- Support both horizontal and vertical scrolling like Instagram. | ||
- Be able to follow or unfollow user. | ||
- Be able to change user's info such as: fullname, username, bio and avatar. | ||
- Support dark mode. | ||
|
||
## Preview | ||
|
||
- Login Screen | ||
|
||
| Log in | Sign up | | ||
| :--------------------------: | :---------------------------: | | ||
| data:image/s3,"s3://crabby-images/279f8/279f8adee9805e1aff3e580faf60478d6811b80e" alt="" | data:image/s3,"s3://crabby-images/5d4eb/5d4eb9754cfb00b7a0ccd8aa71c5d8ceff8839d7" alt="" | | ||
|
||
- Home Screen | ||
|
||
Self-sizing cell and remain photo aspect ratio. | ||
Be able to load more comments. | ||
|
||
| Home | Like | Comment | Other Profile | | ||
| :---------: | :---------: | :------------: | :------------: | | ||
| data:image/s3,"s3://crabby-images/696f0/696f00a61bfaef8f5e42fa41e14560622e4430aa" alt="" | data:image/s3,"s3://crabby-images/acc70/acc70517a9779dc6dcb99bee172d974fdf10d40b" alt="" | data:image/s3,"s3://crabby-images/63036/63036f8560ac0c2f48a72a92214bf509007c23eb" alt="" | data:image/s3,"s3://crabby-images/60168/60168966e2207f0a108ab2854e214efd049a1546" alt="" | | ||
|
||
- Explore Screen | ||
|
||
| Explore | Search | Post Detail | | ||
| :--------: | :--------: | :--------: | | ||
| data:image/s3,"s3://crabby-images/f4bd5/f4bd56ca47f1248065dfd03cbab2cb7eaed2d5c9" alt="" | data:image/s3,"s3://crabby-images/12561/12561c57ac3ab097da75c140cd0401f7e3fafbbe" alt="" | data:image/s3,"s3://crabby-images/3217a/3217ac33f26322128fd3454a4957fdc7957d1baa" alt="" | | ||
|
||
- Upload Post | ||
|
||
| Upload post | | ||
| :---------: | | ||
| data:image/s3,"s3://crabby-images/61098/61098bc950660046e2f9473d34f7e910ed496e7d" alt="" | | ||
|
||
- Profile Screen | ||
|
||
| Profile | Edit Profile | Settings | Check Follow | | ||
| :--------: | :--------: | :--------: | :--------: | | ||
| data:image/s3,"s3://crabby-images/54e05/54e05e6220ab2856af533fbae331f58cb0f528bb" alt="" | data:image/s3,"s3://crabby-images/02040/02040e4b3de4667047d33318863f0b0caac128f2" alt="" | data:image/s3,"s3://crabby-images/d2ad0/d2ad0aff4f0df43c42470d028bb5ae30150c51c2" alt="" | data:image/s3,"s3://crabby-images/91850/91850283759133427f471cd6139f5528e4f6590c" alt="" | | ||
|
||
- Dark Mode: | ||
|
||
| Dark Mode | | ||
| :---------: | | ||
| data:image/s3,"s3://crabby-images/e0e45/e0e4586141859958fca9620eda4ccc8ba2cecf48" alt="" | | ||
|
||
## Installation | ||
|
||
1. Clone the repo: | ||
|
||
```sh | ||
git clone https://github.com/ducanh2211/Instagram-Clone.git | ||
cd Instagram-Clone/ | ||
``` | ||
|
||
2. Delete the following file and folder: `Podfile.lock`, `InstagramClone.xcworkspace` and `Pods`. | ||
|
||
3. Install the dependencies through `CocoaPods` by run command: | ||
|
||
``` sh | ||
pod install | ||
``` | ||
|
||
4. Set up [Firebase](https://firebase.google.com) project by following the instruction. | ||
|
||
5. Delete file `GoogleService-Info.plist` and change the bundle Id. | ||
|
||
<p align="right">(<a href="#readme-top">back to top</a>)</p> | ||
|
||
## Upcoming Features | ||
|
||
- Notifications for likes, comments, follow, etc. | ||
- Add stories. | ||
- Delete posts. | ||
- One-to-one messages. | ||
|
||
<p align="right">(<a href="#readme-top">back to top</a>)</p> | ||
|
||
## Contact | ||
|
||
- Email: ducanhtran221100@gmail.com | ||
- Github: https://github.com/ducanh2211 | ||
|
||
<p align="right">(<a href="#readme-top">back to top</a>)</p> |