SkillAgentSearch skills...

SwiftHub

GitHub iOS client in RxSwift and MVVM-C clean architecture

Install / Use

/learn @khoren93/SwiftHub

README

<p align="center"> <img src="https://github.com/khoren93/SwiftHub/blob/master/Sketch/app_logo.svg" alt="SwiftHub logo" height="80" > </p> <p align="center"> GitHub iOS client in RxSwift and MVVM-C clean architecture. </p> <p align="center"> <a href="https://github.com/khoren93/FlutterHub"> FlutterHub - Flutter version available at an early stage </a> </p>

Content

Screenshots

<pre> <img alt="04_trending_repository_screen" src="https://github.com/khoren93/SwiftHub/blob/master/screenshots/04_trending_repository_screen.png?raw=true" width="250">&nbsp; <img alt="01_search_repository_screen" src="https://github.com/khoren93/SwiftHub/blob/master/screenshots/01_search_repository_screen.png?raw=true" width="250">&nbsp; <img alt="02_repository_details_screen" src="https://github.com/khoren93/SwiftHub/blob/master/screenshots/02_repository_details_screen.png?raw=true" width="250">&nbsp; <img alt="05_search_user_screen" src="https://github.com/khoren93/SwiftHub/blob/master/screenshots/05_search_user_screen.png?raw=true" width="250">&nbsp; <img alt="06_user_details_screen" src="https://github.com/khoren93/SwiftHub/blob/master/screenshots/06_user_details_screen.png?raw=true" width="250">&nbsp; <img alt="03_settings_screen" src="https://github.com/khoren93/SwiftHub/blob/master/screenshots/03_settings_screen.png?raw=true" width="250">&nbsp; </pre>

Mind Mapping (full version)

<p align="center"> <a href="https://github.com/khoren93/SwiftHub/blob/master/iThoughtsX/SwiftHub_full.pdf"> <img alt="SwiftHub mind note" src="https://github.com/khoren93/SwiftHub/blob/master/iThoughtsX/SwiftHub.png?raw=true" height="250"> </a> </p>

App Features

  • [x] Basic, Personal Access Token and OAuth2 authentication
  • [x] View trending repositories and users (github-trending-api)
  • [x] Advanced searching and sorting repositories and users, filter by language
  • [x] View repository and user details, events, issues, commits, pull requests, contributors, etc...
  • [x] View issue and pull request messages (MessageKit)
  • [x] Tool for counting lines of code from github repositories (codetabs) (Charts)
  • [x] The missing star history graph of github repos (stars-history)
  • [x] Quickly browse the history of a file from any git repository (git-history)
  • [x] Tool for visualizing GitHub profiles (profile-summary-for-github)
  • [x] View a 3D model of your GitHub contribution grap (skyline)
  • [x] Source file viewer and syntax highlighting (Highlightr)
  • [x] Color themes in light and dark modes (RxTheme)
  • [x] In-app language switching (en, zh, ru, hy) (Localize-Swift)
  • [x] Whats New functionality (WhatsNewKit)
  • [x] Invite friends functionality
  • [x] Support iPhone and iPad (Split View)
  • [ ] Clone repository directly to app (SwiftGit2)

Technologies

Tools

  • [x] Brew - The missing package manager for macOS
  • [x] Bundler - Manage your Ruby application's gem dependencies
  • [x] Fastlane - The easiest way to automate building and releasing your iOS and Android apps
  • [x] SwiftLint - A tool to enforce Swift style and conventions
  • [x] Jazzy - Soulful docs for Swift & Objective-C
  • [x] JSONExport - Is a desktop application which enables you to export JSON objects as model classes
  • [x] R.swift - Get strong typed, autocompleted resources like images, fonts and segues in Swift projects
  • [x] Flex - An in-app debugging and exploration tool for iOS
  • [x] Sourcetree - A free Git client for Windows and Mac
  • [x] Postman - A powerful HTTP client for testing web services (view)
  • [x] Sketch - A digital design app for Mac (paid) (view)
  • [x] iThoughtsX - A mind mapping app for Windows, Mac, iPad and iPhone (paid) (view)

Building and Running

You'll need a few things before we get started. Make sure you have Xcode installed from the App Store. Then run the following command to install Xcode's command line tools, if you don't have that yet

xcode-select --install

Install Bundler for managing Ruby gem dependencies

[sudo] gem install bundler

Install Brew package manager for macOS:

For MacOS Catalina, macOS Mojave, and MacOS Big Sur:

/usr/bin/ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"

For macOS High Sierra, Sierra, El Capitan, and earlier:

/bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install.sh)"

Install Node (required to install Apollo)

brew install node

The following commands will set up SwiftHub

cd SwiftHub
bundle install
bundle exec fastlane setup

To update all tools and pods

bundle exec fastlane update

Alrighty! We're ready to go!

Documentation

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.

Debugging

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

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.

Design

All icons used in the application are taken from the Feather. Thanks to them for the beautiful open source icons.

SwiftHub In

View on GitHub
GitHub Stars3.1k
CategoryDevelopment
Updated4h ago
Forks544

Languages

Swift

Security Score

100/100

Audited on Mar 30, 2026

No findings