Awesome
SideMenu
Overview
SideMenu is a simple side menu Navigation control written in SwiftUI for SwiftUI
Preview Samples
Left Panel | Right Panel |
---|---|
Requirements
- Xcode 11
- Swift 5.1
- iOS 13 or higher.
Installation
Swift Package Manager
Select the project in Navigator, go to the Swift Packages tab and add the following url
https://github.com/Vidhyadharan-Mohanram/SideMenu
Usage
Initialization
SideMenu takes a single view binding for the center view and an instance of SideMenuConfig class as paramenters, depending on the requirments SideMenu can be initialized with either the left, right or both panel.
import SideMenu
struct MainView : View {
var body: some View {
SideMenu(leftMenu: LeftMenu(),
rightMenu: RightMenu(),
centerView: LatestPhotosView())
.environmentObject(ShimmerConfig())
}
}
Toggling panels
SideMenu exposes the panel state using environment values, to show or hide a given panel declare the relevant environment variable and update the environment variables wrapped value.
import SideMenu
struct MyView: View {
@Environment(\.sideMenuLeftPanelKey) var sideMenuLeftPanel
...
var body: some View {
...
self.sideMenuLeftPanel.wrappedValue = true
...
}
}
similary the panel gesture can be enabled or disabled using the environment key (.sideMenuGestureModeKey)
Customization
SideMenuConfig
SideMenuConfig
supports the following customizations
// color of the background view. Default is Color.black
public var menuBGColor: Color
// The opacity of the menu background view. Default is 0.3
public var menuBGOpacity: Double
// The width of the menu. Default is 300
public var menuWidth: Length
// The duration taken by the menu to slide out. Default is 0.3
public var animationDuration: Double
Known Issues
- Shimmers when active causes the simulator and mac OS to stutter. Run the example app in device to prevent stuttering.
ShimmerView
For the shimmering effect go to https://github.com/Vidhyadharan-Mohanram/ShimmerView
for more details.