added a wrapper view for tabs along with constraints so that we can expand and collapse margins based on the tabs configuration
Signed-off-by: Matt Bruce <matt.bruce@verizon.com>
This commit is contained in:
parent
d56f34258d
commit
eb2d660760
@ -22,14 +22,34 @@ open class SubNavManagerController: ViewController, MVMCoreViewManagerProtocol,
|
||||
|
||||
/// Used to layout the ui.
|
||||
public lazy var stackView: UIStackView = {
|
||||
let stackView = UIStackView(arrangedSubviews: [tabs, subNavigationController.view])
|
||||
let stackView = UIStackView(arrangedSubviews: [tabsWrapper, subNavigationController.view])
|
||||
stackView.translatesAutoresizingMaskIntoConstraints = false
|
||||
stackView.isAccessibilityElement = false
|
||||
stackView.axis = .vertical
|
||||
return stackView
|
||||
}()
|
||||
|
||||
private var tabsLeadingConstraint: NSLayoutConstraint?
|
||||
private var tabsTrailingConstraint: NSLayoutConstraint?
|
||||
|
||||
private lazy var tabsWrapper: UIView = {
|
||||
// create the wrapper view for tabs
|
||||
let tabsWrapper = UIView()
|
||||
tabsWrapper.translatesAutoresizingMaskIntoConstraints = false
|
||||
tabsWrapper.addSubview(tabs)
|
||||
|
||||
// tabs constraints on wrapper
|
||||
tabs.pinTop()
|
||||
tabs.pinBottom()
|
||||
tabsLeadingConstraint = tabs.pinLeading(anchor: tabsWrapper.leadingAnchor)?.activate()
|
||||
tabsTrailingConstraint = tabs.pinTrailing(anchor: tabsWrapper.trailingAnchor)?.activate()
|
||||
return tabsWrapper
|
||||
}()
|
||||
|
||||
private var isFillContainer: Bool { tabsModel.tabs.count <= fillContainerTabsCount }
|
||||
|
||||
private var tabsModel: TabsModel
|
||||
|
||||
public lazy var tabs: Tabs = {
|
||||
let tabs = Tabs(model: tabsModel, delegateObjectIVar, nil)
|
||||
tabs.backgroundColor = (viewController as? PageProtocol)?.pageModel?.navigationBar?.backgroundColor?.uiColor ?? VDSColor.backgroundPrimaryLight
|
||||
@ -60,7 +80,7 @@ open class SubNavManagerController: ViewController, MVMCoreViewManagerProtocol,
|
||||
super.init(nibName: nil, bundle: nil)
|
||||
setup(with: loadObject, shouldEnableSwipeGestures: shouldEnableSwipeGestures)
|
||||
}
|
||||
|
||||
|
||||
public init(viewControllers: [UIViewController], tabsModel: TabsModel, loadObject: MVMCoreLoadObject, shouldEnableSwipeGestures: Bool) {
|
||||
self.tabsModel = tabsModel
|
||||
self.viewControllers = viewControllers
|
||||
@ -72,7 +92,11 @@ open class SubNavManagerController: ViewController, MVMCoreViewManagerProtocol,
|
||||
func setup(with loadObject: MVMCoreLoadObject, shouldEnableSwipeGestures: Bool) {
|
||||
self.loadObject = loadObject
|
||||
pageType = loadObject.pageType
|
||||
tabs.fillContainer = tabsModel.tabs.count <= fillContainerTabsCount
|
||||
|
||||
//update the tabs
|
||||
tabs.fillContainer = isFillContainer
|
||||
updateTabsMargin()
|
||||
|
||||
if shouldEnableSwipeGestures {
|
||||
customInteractor = SubNavInteractor(viewController: self)
|
||||
}
|
||||
@ -126,6 +150,12 @@ open class SubNavManagerController: ViewController, MVMCoreViewManagerProtocol,
|
||||
super.viewWillAppear(animated)
|
||||
hideNavigationBarLine(true)
|
||||
}
|
||||
/// ensures margin for tabs are correct
|
||||
private func updateTabsMargin() {
|
||||
let tabsGutterSpacing = isFillContainer ? 0 : Padding.Component.horizontalPaddingForSize(stackView.bounds.width)
|
||||
tabsLeadingConstraint?.constant = tabsGutterSpacing
|
||||
tabsTrailingConstraint?.constant = tabsGutterSpacing
|
||||
}
|
||||
|
||||
/// Hides/Shows the navigation bar for the page.
|
||||
open func hideNavigationBarLine(_ isHidden: Bool) {
|
||||
@ -143,7 +173,7 @@ open class SubNavManagerController: ViewController, MVMCoreViewManagerProtocol,
|
||||
open override func updateViews() {
|
||||
super.updateViews()
|
||||
if screenSizeChanged() {
|
||||
tabs.updateView(view.bounds.size.width)
|
||||
updateTabsMargin()
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
Loading…
Reference in New Issue
Block a user