UISheetPresentationController
under the hood.sheet
API under the hood, ensuring maximum compatibility & stability.sheet
implementation.UISheetPresentationController
from any child views in the presented sheet's content view.interactiveDismissDisabled(_:Bool)
modifier.UISheetPresentationController
configuration options.Environment
value.~44kB
thin when installed via SwiftPM.The codebase supports iOS and requires Xcode 12.0 or newer
Open your project. Navigate to File > Swift Packages > Add Package Dependency
. Enter the url https://github.com/ericlewis/PageSheet
and tap Next
.
Select the PageSheet
target and press Add Package
.
Add the following line to the dependencies
in your Package.swift
file:
.package(url: "https://github.com/ericlewis/PageSheet.git", .upToNextMajor(from: "1.0.0"))
Next, add PageSheet
as a dependency for your targets:
.target(name: "AppTarget", dependencies: ["PageSheet"])
A completed example may look like this:
// swift-tools-version:5.5
import PackageDescription
let package = Package(
name: "App",
dependencies: [
.package(
url: "https://github.com/ericlewis/PageSheet.git",
.upToNextMajor(from: "1.0.0"))
],
targets: [
.target(
name: "AppTarget",
dependencies: ["PageSheet"])
]
)
If you are using Xcode 13.2.1 you can navigate to the Example
folder and open the enclosed Swift App Playground to test various features (and see how they are implemented).
PageSheet
works similarly to a typical sheet
view modifier.
import SwiftUI
import PageSheet
struct ContentView: View {
@State
private var sheetPresented = false
var body: some View {
Button("Open Sheet") {
sheetPresented = true
}
.pageSheet(isPresented: $sheetPresented) {
Text("Hello!")
}
}
}
PageSheet
also supports presentation via conditional Identifiable
objects.
import SwiftUI
import PageSheet
struct ContentView: View {
@State
private var string: String?
var body: some View {
Button("Open Sheet") {
string = "Hello!"
}
.pageSheet(item: $string) { unwrappedString in
Text(unwrappedString)
}
}
}
extension String: Identifiable {
public var id: String { self }
}
PageSheet
can also be customized using a collection of view modifiers applied to the sheet's content.
import SwiftUI
import PageSheet
struct ContentView: View {
@State
private var sheetPresented = false
var body: some View {
Button("Open Sheet") {
sheetPresented = true
}
.pageSheet(isPresented: $sheetPresented) {
Text("Hello!")
.preferGrabberVisible(true)
}
}
}
PageSheet
is split into three different modules, with PageSheetCore
handling implementation
and PageSheetPlus
providing a new modifier called sheetPreferences(_:)
.
The namesake module is PageSheet
, which combines PageSheetCore
& PageSheetPlus
into a single import.
If you want to only use PageSheet without the fancy extra modifier (and extra dependency), then use PageSheetCore
.
PageSheet is released under the MIT license. See LICENSE for details.
link |
Stars: 51 |
Last commit: 5 weeks ago |
Full Changelog: https://github.com/ericlewis/PageSheet/compare/1.2.4...1.2.5
Swiftpack is being maintained by Petr Pavlik | @ptrpavlik | @swiftpackco | API | Analytics