Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/kitasuke/PagingMenuController
Paging view controller with customizable menu in Swift
https://github.com/kitasuke/PagingMenuController
Last synced: 3 months ago
JSON representation
Paging view controller with customizable menu in Swift
- Host: GitHub
- URL: https://github.com/kitasuke/PagingMenuController
- Owner: kitasuke
- License: mit
- Archived: true
- Created: 2015-05-10T12:51:39.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2022-02-09T13:22:51.000Z (almost 3 years ago)
- Last Synced: 2024-09-26T22:21:12.964Z (4 months ago)
- Language: Swift
- Homepage:
- Size: 723 KB
- Stars: 2,496
- Watchers: 67
- Forks: 449
- Open Issues: 78
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
- awesome-swift-cn - PagingMenuController - Paging view controller with customizable menu in Swift. (Libs / UI)
- awesome-swift - PagingMenuController - Paging view controller with customizable menu in Swift (UI)
README
![](https://raw.githubusercontent.com/wiki/kitasuke/PagingMenuController/images/logo.png)
[![CI Status](http://img.shields.io/travis/kitasuke/PagingMenuController.svg?style=flat)](https://travis-ci.org/kitasuke/PagingMenuController)
[![Carthage compatible](https://img.shields.io/badge/Carthage-compatible-4BC51D.svg?style=flat)](https://github.com/kitasuke/PagingMenuController)
[![Version](https://img.shields.io/cocoapods/v/PagingMenuController.svg?style=flat)](http://cocoapods.org/pods/PagingMenuController)
[![License](https://img.shields.io/cocoapods/l/PagingMenuController.svg?style=flat)](http://cocoapods.org/pods/PagingMenuController)
[![Platform](https://img.shields.io/cocoapods/p/PagingMenuController.svg?style=flat)](http://cocoapods.org/pods/PagingMenuController)
![Swift 3.0.x](https://img.shields.io/badge/Swift-3.0.x-orange.svg)This library is inspired by [PageMenu](https://github.com/uacaps/PageMenu)
## Updates
See [CHANGELOG](https://github.com/kitasuke/PagingMenuController/blob/master/CHANGELOG.md) for details
## Description
### Standard mode with flexible item width
### Segmented control mode
### Infinite mode with fixed item width
## Customization
### PagingMenuControllerCustomizable
* default page index to show as a first view
```Swift
defaultPage: Int
```* duration for paging view animation
```Swift
animationDuration: TimeInterval
```* isScrollEnabled for paging view. **Set false in case of using swipe-to-delete on your table view**
```swift
isScrollEnabled: Bool
```* background color for paging view
```Swift
backgroundColor: UIColor
```* number of lazy loading pages
```swift
lazyLoadingPage: LazyLoadingPage
public enum LazyLoadingPage {
case one // Currently sets false to isScrollEnabled at this moment. Should be fixed in the future.
case three
case all // Currently not available for Infinite mode
}
```* a set of menu controller
```swift
menuControllerSet: MenuControllerSet
public enum MenuControllerSet {
case single
case multiple
}
```* component type of PagingMenuController
```swift
componentType: ComponentType
public enum ComponentType {
case menuView(menuOptions: MenuViewCustomizable)
case pagingController(pagingControllers: [UIViewController])
case all(menuOptions: MenuViewCustomizable, pagingControllers: [UIViewController])
}
```### MenuViewCustomizable
* background color for menu view
```Swift
backgroundColor: UIColor
```* background color for selected menu item
```Swift
selectedBackgroundColor: UIColor
```* height for menu view
```Swift
height: CGFloat
```* duration for menu view animation
```Swift
animationDuration: TimeInterval
```* decelerating rate for menu view
```swift
deceleratingRate: CGFloat
```* menu item position
```swift
menuSelectedItemCenter: Bool
```* menu mode and scrolling mode
```swift
displayMode: MenuDisplayModepublic enum MenuDisplayMode {
case standard(widthMode: MenuItemWidthMode, centerItem: Bool, scrollingMode: MenuScrollingMode)
case segmentedControl
case infinite(widthMode: MenuItemWidthMode, scrollingMode: MenuScrollingMode) // Requires three paging views at least
}public enum MenuItemWidthMode {
case flexible
case fixed(width: CGFloat)
}public enum MenuScrollingMode {
case scrollEnabled
case scrollEnabledAndBouces
case pagingEnabled
}
```if `centerItem` is true, selected menu item is always on center
if `MenuScrollingMode` is `ScrollEnabled` or `ScrollEnabledAndBouces`, menu view allows scrolling to select any menu item
if `MenuScrollingMode` is `PagingEnabled`, menu item should be selected one by one* menu item focus mode
```Swift
focusMode: MenuFocusMode
public enum MenuFocusMode {
case none
case underline(height: CGFloat, color: UIColor, horizontalPadding: CGFloat, verticalPadding: CGFloat)
case roundRect(radius: CGFloat, horizontalPadding: CGFloat, verticalPadding: CGFloat, selectedColor: UIColor)
}
```* dummy item view number for Infinite mode
```swift
dummyItemViewsSet: Int
```* menu position
```swift
menuPosition: MenuPositionpublic enum MenuPosition {
case top
case bottom
}
```* divider image to display right aligned in each menu item
```swift
dividerImage: UIImage?
```### MenuItemViewCustomizable
* horizontal margin for menu item
```swift
horizontalMargin: CGFloat
```* menu item mode
```swift
displayMode: MenuItemDisplayMode
public enum MenuItemDisplayMode {
case text(title: MenuItemText)
case multilineText(title: MenuItemText, description: MenuItemText)
case image(image: UIImage, selectedImage: UIImage?)
case custom(view: UIView)
}
```## Usage
`import PagingMenuController` to use PagingMenuController in your file.
### Using Storyboard
```Swift
struct MenuItem1: MenuItemViewCustomizable {}
struct MenuItem2: MenuItemViewCustomizable {}struct MenuOptions: MenuViewCustomizable {
var itemsOptions: [MenuItemViewCustomizable] {
return [MenuItem1(), MenuItem2()]
}
}struct PagingMenuOptions: PagingMenuControllerCustomizable {
var componentType: ComponentType {
return .all(menuOptions: MenuOptions(), pagingControllers: [UIViewController(), UIViewController()])
}
}let pagingMenuController = self.childViewControllers.first as! PagingMenuController
pagingMenuController.setup(options)
pagingMenuController.onMove = { state in
switch state {
case let .willMoveController(menuController, previousMenuController):
print(previousMenuController)
print(menuController)
case let .didMoveController(menuController, previousMenuController):
print(previousMenuController)
print(menuController)
case let .willMoveItem(menuItemView, previousMenuItemView):
print(previousMenuItemView)
print(menuItemView)
case let .didMoveItem(menuItemView, previousMenuItemView):
print(previousMenuItemView)
print(menuItemView)
case .didScrollStart:
print("Scroll start")
case .didScrollEnd:
print("Scroll end")
}
}
```
* You should add `ContainerView` into your view controller's view and set `PagingMenuController` as the embedded view controller's classSee `PagingMenuControllerDemo` target in demo project for more details
### Coding only
```Swift
struct MenuItem1: MenuItemViewCustomizable {}
struct MenuItem2: MenuItemViewCustomizable {}struct MenuOptions: MenuViewCustomizable {
var itemsOptions: [MenuItemViewCustomizable] {
return [MenuItem1(), MenuItem2()]
}
}struct PagingMenuOptions: PagingMenuControllerCustomizable {
var componentType: ComponentType {
return .all(menuOptions: MenuOptions(), pagingControllers: [UIViewController(), UIViewController()])
}
}let options = PagingMenuOptions()
let pagingMenuController = PagingMenuController(options: options)addChildViewController(pagingMenuController)
view.addSubview(pagingMenuController.view)
pagingMenuController.didMove(toParentViewController: self)
```See `PagingMenuControllerDemo2` target in demo project for more details
### Menu move handler (optional)
```Swift
public enum MenuMoveState {
case willMoveController(to: UIViewController, from: UIViewController)
case didMoveController(to: UIViewController, from: UIViewController)
case willMoveItem(to: MenuItemView, from: MenuItemView)
case didMoveItem(to: MenuItemView, from: MenuItemView)
case didScrollStart
case didScrollEnd
}pagingMenuController.onMove = { state in
switch state {
case let .willMoveController(menuController, previousMenuController):
print(previousMenuController)
print(menuController)
case let .didMoveController(menuController, previousMenuController):
print(previousMenuController)
print(menuController)
case let .willMoveItem(menuItemView, previousMenuItemView):
print(previousMenuItemView)
print(menuItemView)
case let .didMoveItem(menuItemView, previousMenuItemView):
print(previousMenuItemView)
print(menuItemView)
case .didScrollStart:
print("Scroll start")
case .didScrollEnd:
print("Scroll end")
}
}
```### Moving to a menu tag programmatically
```swift
// if you pass a nonexistent page number, it'll be ignored
pagingMenuController.move(toPage: 1, animated: true)
```### Changing PagingMenuController's option
Call `setup` method with new options again.
It creates a new paging menu controller. Do not forget to cleanup properties in child view controller.## Requirements
iOS9+
Swift 3.0+
Xcode 8.0+[v1.4.0](https://github.com/kitasuke/PagingMenuController/releases/tag/1.4.0) for iOS 8 in Swift 3.0
[v1.2.0](https://github.com/kitasuke/PagingMenuController/releases/tag/1.2.0) for iOS 8 in Swift 2.3## Installation
### CocoaPods
PagingMenuController is available through [CocoaPods](http://cocoapods.org). To install
it, simply add the following line to your Podfile:```ruby
source 'https://github.com/CocoaPods/Specs.git'
platform :ios, '9.0'
use_frameworks!pod "PagingMenuController"
post_install do |installer|
installer.pods_project.targets.each do |target|
target.build_configurations.each do |config|
config.build_settings['SWIFT_VERSION'] = '3.0'
end
end
end
```Then, run `pod install`
In case you haven't installed CocoaPods yet, run the following command
```ruby
$ gem install cocoapods
```### Carthage
PagingMenuController is available through [Carthage](https://github.com/Carthage/Carthage).To install PagingMenuController into your Xcode project using Carthage, specify it in your Cartfile:
```ruby
github "kitasuke/PagingMenuController"
```Then, run `carthage update --toolchain com.apple.dt.toolchain.Swift_3_0`
You can see `Carthage/Build/iOS/PagingMenuController.framework` now, so drag and drop it to `Linked Frameworks and Libraries` in General menu tab with your project.
Add the following script to `New Run Script Phase` in Build Phases menu tab.
```ruby
/usr/local/bin/carthage copy-frameworks
```Also add the following script in `Input Files`
```ruby
$(SRCROOT)/Carthage/Build/iOS/PagingMenuController.framework
```In case you haven't installed Carthage yet, download the latest pkg from [Carthage](https://github.com/Carthage/Carthage/releases)
### Manual
Copy all the files in `Pod/Classes` directory into your project.
## License
PagingMenuController is available under the MIT license. See the [LICENSE](https://github.com/kitasuke/PagingMenuController/blob/master/LICENSE) file for more info.