PanelContainerControllerHolder

constructor(findContainerViewDataBinding: () -> ViewDataBinding?, createPanelContainerController: (PanelContainerContext) -> C?)

Parameters

findContainerViewDataBinding

Returns the ViewDataBinding containing the PanelContainer, if any. It is used to optimise the initialization of the PanelContainerController. This function is only called when panelContainerContext is set for the first time.

If findContainerViewDataBinding returns a valid ViewDataBinding then the holder listens for binding updates and invokes createPanelContainerController on update completing. That guarantees that a controller is created once when all property updates are completed.

If findContainerViewDataBinding returns a null then createPanelContainerController is called on every change of observed properties including panelContainerContext.

createPanelContainerController

Called when the holder has sufficient information for creating a PanelContainerController. The returned controller will be bound to the system UI and unbound when the controller is cleared or replaced. The function may return null when it is not ready to create a controller. In these cases it's common for the information that the controller creation depends on to be set using a delegate returned by rebuildOnChange such that controller creation is automatically re-attempted when then information becomes available.

CD

The type of the panel container data. The panel container data is the input data that is visualized by the panel container.

VM

The panel sub-container view model type.

SD

The type of the panel sub-container data.