All Projects → louisdh → Panelkit

louisdh / Panelkit

Licence: mit
PanelKit is a UI framework that enables panels on iOS. A panel can be presented in the following ways:

Programming Languages

swift
15916 projects
c
50402 projects - #5 most used programming language

Projects that are alternatives of or similar to Panelkit

KeyCommandAlertController
UIAlertController wrapper to add keyboard shortcuts easily
Stars: ✭ 16 (-99.58%)
Mutual labels:  ux, uikit, ipad
Panels
Panels is a framework to easily add sliding panels to your application
Stars: ✭ 1,457 (-62.01%)
Mutual labels:  ux, panels
Peel Off Animation Example Code
Example code for https://robb.is/working-on/a-peel-off-animation
Stars: ✭ 37 (-99.04%)
Mutual labels:  uikit, ux
Uikit Playground
Blog posts about things I learned over the years working with UIKit and accompanying sample code.
Stars: ✭ 95 (-97.52%)
Mutual labels:  uikit, ux
Overlap
Tiny iOS library to achieve overlap visual effect
Stars: ✭ 133 (-96.53%)
Mutual labels:  uikit, ux
ALButtonMenu
A simple, fully customizable menu solution for iOS.
Stars: ✭ 45 (-98.83%)
Mutual labels:  uikit, ipad
Shards Dashboard Vue
A free Vue admin dashboard template pack featuring a modern design system and lots of custom templates and components.
Stars: ✭ 363 (-90.53%)
Mutual labels:  uikit, ux
Uicollectionviewsplitlayout
UICollectionViewSplitLayout makes collection view more responsive.
Stars: ✭ 226 (-94.11%)
Mutual labels:  ipad, uikit
pikko
Color picker for iOS made with ❤️
Stars: ✭ 34 (-99.11%)
Mutual labels:  ux, uikit
BJOTPViewController
Entering OTP made simpler.
Stars: ✭ 42 (-98.9%)
Mutual labels:  uikit, ipad
awesome-neumorphism
A curated list of awesome Neumorphism resources.
Stars: ✭ 15 (-99.61%)
Mutual labels:  ux, uikit
Shadowview
An iOS Library that makes shadows management easy on UIView.
Stars: ✭ 391 (-89.8%)
Mutual labels:  uikit
Awesome Flutter Ui
10+ flutter(android, ios) UI design examples ⚡️ - login, books, profile, food order, movie streaming, walkthrough, widgets
Stars: ✭ 372 (-90.3%)
Mutual labels:  uikit
Starwars.ios
This component implements transition animation to crumble view-controller into tiny pieces.
Stars: ✭ 3,685 (-3.91%)
Mutual labels:  uikit
Sancho
Responsive and accessible React UI components built with Typescript
Stars: ✭ 365 (-90.48%)
Mutual labels:  uikit
Ipa Server
Upload and install IPA in web.
Stars: ✭ 392 (-89.78%)
Mutual labels:  ipad
Shards Vue
🌟Shards Vue is a free, beautiful and modern Vue.js UI kit based on Shards.
Stars: ✭ 390 (-89.83%)
Mutual labels:  uikit
Overwatch Ui
A UI library of Overwatch, built with Vue.js
Stars: ✭ 365 (-90.48%)
Mutual labels:  uikit
Coreui
Open Source UI Kit built on top of Bootstrap 4 and plain JavaScript without any additional libraries like jQuery
Stars: ✭ 361 (-90.59%)
Mutual labels:  uikit
Squishbutton
A button that squishes when pressed. As seen in the Clips app.
Stars: ✭ 401 (-89.54%)
Mutual labels:  uikit

PanelKit for iOS

Build Status Codecov
Swift PodVersion Carthage Compatible Platform: iOS
Twitter Donate via PayPal

PanelKit for iOS
Applications using PanelKit can be seen in the showcase.

About

PanelKit is a UI framework that enables panels on iOS. A panel can be presented in the following ways:

  • Modally
  • As a popover
  • Floating (drag the panel around)
  • Pinned (either left or right)

This framework does all the heavy lifting for dragging panels, pinning them and even moving/resizing them when a keyboard is shown/dismissed.

Implementing

A lot of effort has gone into making the API simple for a basic implementation, yet very customizable if needed. Since PanelKit is protocol based, you don't need to subclass anything in order to use it. There a two basic principles PanelKit entails: panels and a PanelManager.

Panels

A panel is created using the PanelViewController initializer, which expects a UIViewController, PanelContentDelegate and PanelManager.

PanelContentDelegate

PanelContentDelegate is a protocol that defines the appearance of a panel. Typically the PanelContentDelegate protocol is implemented for each panel on its UIViewController.

Example:

class MyPanelContentViewController: UIViewController, PanelContentDelegate {
    
    override func viewDidLoad() {
        super.viewDidLoad()
        
        self.title = "Panel title"	
    }
    
    var preferredPanelContentSize: CGSize {
        return CGSize(width: 320, height: 500)
    }	
}

A panel is explicitly (without your action) shown in a UINavigationController, but the top bar can be hidden or styled as with any UINavigationController.

PanelManager

PanelManager is a protocol that in its most basic form expects the following:

// The view in which the panels may be dragged around
var panelContentWrapperView: UIView {
    return contentWrapperView
}

// The content view, which will be moved/resized when panels pin
var panelContentView: UIView {
    return contentView
}

// An array of PanelViewController objects
var panels: [PanelViewController] {
    return []
}

Typically the PanelManager protocol is implemented on a UIViewController.

Advanced features

PanelKit has some advanced opt-in features:

Installation

CocoaPods

To install, add the following line to your Podfile:

pod 'PanelKit', '~> 2.0'

Carthage

To install, add the following line to your Cartfile:

github "louisdh/panelkit" ~> 2.0

Run carthage update to build the framework and drag the built PanelKit.framework into your Xcode project.

Requirements

  • iOS 10.0+
  • Xcode 9.0+

Todo

Long term:

  • Top/down pinning

License

This project is available under the MIT license. See the LICENSE file for more info.

Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].