Frames are parts of the screen intended for decomposition and reuse.
The iframe element of the screen’s XML is used to add a frame to the screen. It defines either path to the frame’s XML descriptor, or its identifier, if the frame is registered in screens.xml.
A frame controller should be derived from the AbstractFrame
class.
Rules for interaction between a screen and its enclosed frame are the following:
-
Frame components can be referenced from a screen using a dot:
frame_id.component_id
-
List of screen components can be obtained from a frame controller by invoking
getComponent(component_id)
method but only if there is no component with the same name in the frame itself. I.e. frame components mask screen components. -
Screen datasource can be obtained from a frame by invoking
getDsContext().get(ds_id)
method or injection, or usingds$ds_id
in query, but only if the data source with a matching name is not declared in the frame itself (same as for components). -
From a screen, frame data source can be obtained only by iterating
getDsContext().getChildren()
collection.
Screen commit also causes commits of modified datasources of the frame it uses.