SwiftUI's standard TabView component lacks basic functionality from UIKit like hiding the TabBar in specific screens.
RSTabBar aims to fix that while keeping the default look and feel of the OG TabBar
- SwiftUI
- iOS 15.0 or newer
RSTabBar is available through Swift Package Manager
Xcode > File > Swift Packages > Add Package Dependency > https://github.com/rursache/RSTabBar
The following view will have 2 custom tabs, each with their Text view:
import SwiftUI
import RSTabBar
struct DemoView: View {
static let tabs = [
TabItem(index: 0, title: "Home", icon: "house", iconSelected: "house.fill"),
TabItem(index: 1, title: "More", icon: "bolt.car")
]
@State var tabBarVisible: Bool = true
@State var tabs = DemoView.tabs
@State var selectedTab: TabItem = DemoView.tabs.first!
var body: some View {
RSTabBar(tabs: $tabs, selectedTab: $selectedTab, tabBarVisible: $tabBarVisible) {
Text("First view")
.font(.title).bold()
.padding()
.tag(self.tabs[0])
Text("Second view")
.font(.title).bold()
.padding()
.tag(self.tabs[1])
}
}
}Hiding the tabbar is easy! Just tabBarVisible = false anywhere
Check out the more advanced example to understand how to further customize RSTabBar
- The safe area of the OG transparent
TabBaris there and this is on purpose. However there are cases where you don't want that padding. Something like.padding(.bottom, -40)will adjust or remove that padding. I'm not sure what I can do about this.
If you struggle with something feel free to open an issue. Pull requests are also appreciated as I still learn SwiftUI.
RSTabBar is under the terms and conditions of the MIT license.