Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/exyte/concentriconboarding
SwiftUI library for a walkthrough or onboarding flow with tap actions
https://github.com/exyte/concentriconboarding
cocoapods ios onboarding swift swift-library swiftui ui
Last synced: 3 days ago
JSON representation
SwiftUI library for a walkthrough or onboarding flow with tap actions
- Host: GitHub
- URL: https://github.com/exyte/concentriconboarding
- Owner: exyte
- License: mit
- Created: 2019-09-09T08:21:56.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2024-02-14T10:47:35.000Z (11 months ago)
- Last Synced: 2024-03-15T12:22:50.833Z (10 months ago)
- Topics: cocoapods, ios, onboarding, swift, swift-library, swiftui, ui
- Language: Swift
- Homepage:
- Size: 15.2 MB
- Stars: 1,243
- Watchers: 13
- Forks: 74
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
Concentric Onboarding
iOS library for a walkthrough or onboarding flow with tap actions written with SwiftUI
[![](https://img.shields.io/endpoint?url=https%3A%2F%2Fswiftpackageindex.com%2Fapi%2Fpackages%2Fexyte%2FConcentricOnboarding%2Fbadge%3Ftype%3Dswift-versions)](https://swiftpackageindex.com/exyte/ConcentricOnboarding)
[![](https://img.shields.io/endpoint?url=https%3A%2F%2Fswiftpackageindex.com%2Fapi%2Fpackages%2Fexyte%2FConcentricOnboarding%2Fbadge%3Ftype%3Dplatforms)](https://swiftpackageindex.com/exyte/ConcentricOnboarding)
[![SPM Compatible](https://img.shields.io/badge/SwiftPM-Compatible-brightgreen.svg)](https://swiftpackageindex.com/exyte/ConcentricOnboarding)
[![Cocoapods Compatible](https://img.shields.io/badge/cocoapods-Compatible-brightgreen.svg)](https://cocoapods.org/pods/ConcentricOnboarding)
[![Carthage Compatible](https://img.shields.io/badge/Carthage-compatible-brightgreen.svg?style=flat)](https://github.com/Carthage/Carthage)
[![License: MIT](https://img.shields.io/badge/License-MIT-black.svg)](https://opensource.org/licenses/MIT)# Usage
1. Create `View`'s descendant class for your pages.
2. Create at least two pages and fill them with content.
3. Create an array of tuple - (page, background color).
4. Create ConcentricOnboardingView and place it in your view hierarchy.
```swift
struct ContentView: View {
var body: some View {
return ConcentricOnboardingView(pageContents: [, ])
}
}
```
5. Pass duration as an argument if you want animation to be faster/slower
```swift
ConcentricOnboardingView(pageContents: [, ])
.(duration: 2.0)
```6. Pass icon name as an argument if you want to change default icon on the button
```swift
ConcentricOnboardingView(pageContents: [, ])
.(nextIcon: "chevron.forward")
```
### Public interface
`goToNextPage(animated: Bool = true)` - call this method manually if you need to
`goToPreviousPage(animated: Bool = true)` - call this method manually if you need to
### Assignable closures`.animationWillBegin` - called before animation starts
`.animationDidEnd` - called after animation ends
`.didGoToLastPage` - called after animation leading to last page ends
`.didChangeCurrentPage` - called after page changes
`.insteadOfCyclingToFirstPage` - replaces default navigation to first page after pressing next on last page
`.insteadOfCyclingToLastPage` - replaces default navigation to last page after pressing prev on first page while navigating backwards
`.didPressNextButton` - replaces default button action with user's custom closure
## ExamplesTo try ConcentricOnboarding examples:
- Clone the repo `https://github.com/exyte/ConcentricOnboarding.git`
- Open terminal and run `cd /Example/`
- Run `pod install` to install all dependencies
- Run open `ConcentricOnboardingExample.xcworkspace/` to open project in the Xcode
- Try it!## Installation
### [Swift Package Manager](https://swift.org/package-manager/)
```swift
dependencies: [
.package(url: "https://github.com/exyte/ConcentricOnboarding.git")
]
```### [CocoaPods](http://cocoapods.org)
To install `ConcentricOnboarding`, simply add the following line to your Podfile:
```ruby
pod 'ConcentricOnboarding'
```### [Carthage](http://github.com/Carthage/Carthage)
To integrate `ConcentricOnboarding` into your Xcode project using Carthage, specify it in your `Cartfile`
```ruby
github "Exyte/ConcentricOnboarding"
```## Requirements
* iOS 14+
* Xcode 12+## Acknowledgements
Many thanks to [Cuberto team](https://dribbble.com/shots/6654320-Animated-Onboarding-Screens) for the design idea and inspiration.
## Our other open source SwiftUI libraries
[PopupView](https://github.com/exyte/PopupView) - Toasts and popups library
[Grid](https://github.com/exyte/Grid) - The most powerful Grid container
[ScalingHeaderScrollView](https://github.com/exyte/ScalingHeaderScrollView) - A scroll view with a sticky header which shrinks as you scroll
[AnimatedTabBar](https://github.com/exyte/AnimatedTabBar) - A tabbar with a number of preset animations
[MediaPicker](https://github.com/exyte/mediapicker) - Customizable media picker
[Chat](https://github.com/exyte/chat) - Chat UI framework with fully customizable message cells, input view, and a built-in media picker
[OpenAI](https://github.com/exyte/OpenAI) Wrapper lib for [OpenAI REST API](https://platform.openai.com/docs/api-reference/introduction)
[AnimatedGradient](https://github.com/exyte/AnimatedGradient) - Animated linear gradient
[FloatingButton](https://github.com/exyte/FloatingButton) - Floating button menu
[ActivityIndicatorView](https://github.com/exyte/ActivityIndicatorView) - A number of animated loading indicators
[ProgressIndicatorView](https://github.com/exyte/ProgressIndicatorView) - A number of animated progress indicators
[FlagAndCountryCode](https://github.com/exyte/FlagAndCountryCode) - Phone codes and flags for every country
[SVGView](https://github.com/exyte/SVGView) - SVG parser
[LiquidSwipe](https://github.com/exyte/LiquidSwipe) - Liquid navigation animation