Finder-style iOS file browser written in Swift
Switch branches/tags
Clone or download
Latest commit b03284f Sep 20, 2017

FileBrowser - iOS Finder-style file browser in Swift

Build Status Version Carthage compatible


iOS Finder-style file browser in Swift 4.0 with search, file previews and 3D touch. Simple and quick to use.


โœจ Features
๐Ÿ“ฑ Browse and select files and folders with a familiar UI on iOS.
๐Ÿ” Pull down to search.
๐Ÿ‘“ Preview most file types. Including plist and json.
๐Ÿ“ Edit/delete files.
๐Ÿ‘† 3D touch support for faster previews with Peek & Pop.
๐Ÿ’ฎ Fully customizable.


Import FileBrowser at the top of the Swift file.

import FileBrowser

To show the file browser, all you need to do is:

let fileBrowser = FileBrowser()
present(fileBrowser, animated: true, completion: nil)

By default, the file browser will open in your app's documents directory. When users select a file, a preview will be displayed - offering an action sheet of options based on the file type.

Advanced Usage

You can open FileBrowser in a different root folder by initialising with an NSURL file path of your choice.

let fileBrowser = FileBrowser(initialPath: customPath)

You can also allow editing/deleting files.

let fileBrowser = FileBrowser(initialPath: customPath, allowEditing: true)

Use the didSelectFile closure to change FileBrowser's behaviour when a file is selected.

fileBrowser.didSelectFile = { (file: FBFile) -> Void in

To exclude a certain file type or a specific file path:

fileBrowser.excludesFileExtensions = ["zip"]
fileBrowser.excludesFilepaths = [secretFile]

Setting up with CocoaPods

source ''
pod 'FileBrowser', '~> 1.0'

Setting up with Carthage

Carthage is a decentralized dependency manager that automates the process of adding frameworks to your Cocoa application.

You can install Carthage with Homebrew using the following command:

$ brew update
$ brew install carthage

To integrate FileBrowser into your Xcode project using Carthage, specify it in your Cartfile:

github "marmelroy/FileBrowser"