Open source Github iOS client written in RxSwift and MVVM architecture.
Mind Mapping (full version)
- Basic and OAuth2 authentication
- View trending repositories and users (github-trending-api)
- Advanced searching and sorting repositories and users, filter by language
- View repository and user details, events, issues, commits, pull requests, contributors, etc...
- Source file viewer and syntax highlighting (Highlightr)
- Color themes in light and dark modes (RxTheme)
- In-app language switching (en, zh, ru, hy) (Localize-Swift)
- Whats New functionality (WhatsNewKit)
- Invite friends functionality
- Support iPhone and iPad (Split View)
- Clone repository directly to app (SwiftGit2)
- Clean architecture (RxSwift and MVVM)
- Flow coordinators (Realm demo)
- Networking REST API v3 (Moya)
- Custom transition animations (Hero)
- Programmatically UI (SnapKit)
- Mixpanel and Firebase analytics events (Umbrella)
- Crash reporting (Crashlytics)
- Logging (CocoaLumberjack)
- Google ads implementation, can be enabled/disabled from settings (Firebase AdMob)
- Migrating to GraphQL API v4 (Apollo)
- Dependency injection (Swinject)
- Add tests
- Bundler - Manage your Ruby application's gem dependencies
- Fastlane - The easiest way to automate building and releasing your iOS and Android apps
- SwiftLint - A tool to enforce Swift style and conventions
- Jazzy - Soulful docs for Swift & Objective-C
- JSONExport - Is a desktop application which enables you to export JSON objects as model classes
- R.swift - Get strong typed, autocompleted resources like images, fonts and segues in Swift projects
- Flex - An in-app debugging and exploration tool for iOS
- Postman - A powerful HTTP client for testing web services (view)
- Sketch - A digital design app (paid) (view)
- iThoughtsX - A mind mapping app for Windows, Mac, iPad and iPhone (paid) (view)
You'll need a few things before we get started. Make sure you have Xcode installed from the App Store. Then run the following two commands to install Xcode's command line tools and bundler
, if you don't have that yet.
[sudo] gem install bundler
xcode-select --install
The following commands will set up SwiftHub.
cd SwiftHub
bundle install
bundle exec fastlane setup
Try pod update
if you got some errors.
Alrighty! We're ready to go!
You can generate the API docs locally. Run jazzy
from the root of this repository. This requires installation of jazzy. You will find the output in docs/
. You can set options for your project’s documentation in a configuration file, .jazzy.yaml by default.
Flex debugging tool has been integrated in this application. To enable it, just swipe right anywhere in the application. There are also included debugging Hero animations. To use it, swipe right with two fingers. Repeat this to disable.
Fastlane automates common development tasks - for example bumping version numbers, running tests on multiple configurations, or submitting to the App Store. You can list the available lanes (our project-specific scripts) using bundle exec fastlane lanes
. You can list available actions (all actions available to be scripted via lanes) using bundle exec fastlane actions
. The fastlane configuration and scripts are in the fastlane
folder.
All icons used in the application are taken from the Feather. Thanks to them for the beautiful open source icons.
- CleanArchitectureRxSwift - Clean architecture with RxSwift
- View Model in RxSwift - Good article
MIT License. See LICENSE.