title | category |
---|---|
IoC References |
Infusion |
The Infusion IoC Framework uses a basic syntax for referencing objects in the current context.
References always take the syntactic form {context-name}.some.path.segments
, which we name as the type <reference>
-
the meaning and form of the context name can vary and have a different meaning in different contexts:
Different permitted forms for a <reference> string | |
---|---|
Syntax | Description |
{<componentRef>}.<path to member> |
|
{arguments}.<index> |
|
{source}.<path to member> |
|
{<iocss expression>}.<path to member> |
|
IoC references may be used almost anywhere within a component's options, for example:
- in the subcomponent definitions,
- in invoker specifications,
- in options distributions,
- in listeners specifications, including as the left hand side key specifying an event in a listeners block.
- in events specifications, including as the left hand side key specifying an event in an events block
- or indeed almost anywhere else
For a conventional IoC reference (of the style <componentRef>
rather than the style <iocss expression>
), a search is
begun upwards from the site of the reference in the component tree to find the first component which matches the context
name. The following diagram shows a possible such reference site in green:
The set of components which are in scope for resolution from this site are shown in yellow (circles) and orange (diamonds) in this diagram. These are components which are either
- an ancestor of the component holding the reference site, or
- a sibling of such a component.
- a component anywhere in the tree which has been marked with the grade fluid.resolveRoot - these are the ones shown in orange diamonds
The context reference matches a component if it matches via the 2nd, 3rd or 4th rules in the first row of the above
table - either it agrees with a fully-qualified grade or type name of a component, or it
agrees with the last path segment of such a name, or it agrees with the component's member name. If no context name
matches anywhere in the tree, the reference expression resolves to undefined
. In this case, if the path segments
following the context name in the reference expression are not empty, the framework will throw an error.
Components which are not in scope for resolution from the reference site (shown as a green pentagon) are shown as blue squares.
In the example below, the IoC reference {that}
refers to the component in which it is being used.
fluid.defaults("fluid.prefs.separatedPanel", {
gradeNames: ["fluid.prefs.prefsEditorLoader"],
listeners: {
onCreate: {
funcName: "fluid.prefs.prefsEditorLoader.hideReset",
args: ["{that}"]
}
}
});
This could equally be written using the short name of the fluid.prefs.separatedPanel
component, as shown below:
fluid.defaults("fluid.prefs.separatedPanel", {
gradeNames: ["fluid.prefs.prefsEditorLoader"],
listeners: {
onCreate: {
funcName: "fluid.prefs.prefsEditorLoader.hideReset",
args: ["{separatedPanel}"]
}
}
});
The above two examples are equivalent.
In the example below, the IoC expression {fluid.prefs.enactor.tableOfContents}
refers to the component being defined
by the defaults
block. The short name tableOfContents
must not be used here, because it would not be unique: It
would be unclear whether the nickname was referring to fluid.prefs.enactor.tableOfContents
or fluid.tableOfContents
.
fluid.defaults("fluid.prefs.enactor.tableOfContents", {
gradeNames: ["fluid.viewComponent", "fluid.prefs.enactor"],
components: {
tableOfContents: {
type: "fluid.tableOfContents",
container: "{fluid.prefs.enactor.tableOfContents}.container",
options: {
// ...
}
}
}
});
Another way to avoid the ambiguity mentioned above would be to use the member name, which is the name used when defining
the subcomponent in the components block. In the example below {toc}
refers to the name used to define the
subcomponent in the component block.
fluid.defaults("fluid.prefs.enactor.tableOfContents", {
gradeNames: ["fluid.viewComponent", "fluid.prefs.enactor"],
components: {
toc: {
type: "fluid.tableOfContents",
container: "{fluid.prefs.enactor.tableOfContents}.container",
options: {
components: {
type: "fluid.tableOfContents.levels",
container: "{toc}.dom.tocContainer"
}
}
}
}
});
The example below includes several IoC references. All of them are inside a subcomponent declaration and all include
{controllers}
, which in this case is a reference to the parent component. Specifically:
{controllers}.model
is a reference to the model that is a member of the parent component - note that this reference sets up a permanent model relay between these two models;- the IoC expressions in the subcomponent's events block are references to events defined on the parent component's event block;
{controllers}.dom.scrubberContainer
is a reference to one of the selectors defined on the parent component.
fluid.defaults("fluid.videoPlayer.controllers", {
gradeNames: ["fluid.viewComponent"],
selectors: {
scrubberContainer: ".flc-videoPlayer-scrubberContainer"
},
events: {
onScrub: null,
onStartScrub: null,
afterScrub: null
},
components: {
scrubber: {
type: "fluid.videoPlayer.controllers.scrubber",
container: "{controllers}.dom.scrubberContainer",
options: {
model: "{controllers}.model",
events: {
onScrub: "{controllers}.events.onScrub",
afterScrub: "{controllers}.events.afterScrub",
onStartScrub: "{controllers}.events.onStartScrub"
}
}
}
}
});
The example below uses the {arguments}.n
syntax to deliver the first and second arguments passed to listeners to the
onMove
event to the fluid.moduleLayout.onMoveListener
function.
fluid.defaults("fluid.moduleLayoutHandler", {
gradeNames: ["fluid.layoutHandler"],
events: {
onMove: "{reorderer}.events.onMove"
},
listeners: {
onMove: {
funcName: "fluid.moduleLayout.onMoveListener",
args: ["{arguments}.0", "{arguments}.1", "{that}.layout"]
}
}
});
The example below uses an IoCSS expression {that > moreText}.options.selectors.images
. The expression
refers to the images
selector in the moreText
subcomponent that is a direct descendent of the current component.
fluid.defaults("gpii.explorationTool.enactors.showMoreText", {
gradeNames: ["fluid.viewComponent", "fluid.prefs.enactor"],
selectors: {
images: "img, [role~='img']"
}
});
fluid.defaults("gpii.explorationTool.enactorSet", {
gradeNames: ["fluid.uiEnhancer.starterEnactors"],
components: {
moreText: {
type: "gpii.explorationTool.enactors.showMoreText"
}
},
distributeOptions: {
source: "{that}.options.moreTextSelector",
removeSource: true,
target: "{that > moreText}.options.selectors.images"
}
});
// Range Annotator
fluid.defaults("fluid.pagedTable.rangeAnnotator", {
gradeNames : ["fluid.component"],
listeners : {
"{pagedTable}.events.onRenderPageLinks" : {
funcName : "fluid.pagedTable.rangeAnnotator.onRenderPageLinks",
args : ["{pagedTable}", "{arguments}.0", "{arguments}.1"]
}
}
});
// Paged Table
fluid.defaults("fluid.pagedTable", {
gradeNames : ["fluid.pager", "fluid.table"],
components : {
rangeAnnotator : {
type : "fluid.pagedTable.rangeAnnotator"
}
}
// ...
});
The above example defines a rangeAnnotator
, which is used as a subcomponent of a pagedTable. This definition uses
several IoC references:
- the expression "{pagedTable}.events.onRenderPageLinks" is used to refer to the onRenderPageLinks event of the pagedTable component
- the IoC references:
{pagedTable}.events.onRenderPageLinks
refers to thepagedTable
component{arguments}.0
and{arguments}.1
refer to the first and second arguments supplied when the source event is firedonRenderPageLinks
fluid.defaults("fluid.videoPlayer.languageControls.eventBinder", {
gradeNames: ["fluid.component"],
listeners: {
"{button}.events.onPress": "{menu}.toggleView"
}
});
The above example uses two IoC references:
{button}.events.onPress
refers to theonPress
even of thebutton
component{menu}.toggleView
refers to thetoggleView
method of themenu
component
fluid.defaults("fluid.uploader", {
gradeNames: ["fluid.viewComponent"],
components: {
uploaderImpl: {
type: "fluid.uploaderImpl"
}
},
distributeOptions: {
source: "{that}.options",
removeSource: true,
exclusions: ["components.uploaderContext", "components.uploaderImpl"],
target: "{that > uploaderImpl}.options"
}
});
The above example uses IoC references in the distributeOptions
block:
{that}.options
identifies theoptions
block of the currentthat
(i.e.fluid.uploader
){that > uploaderImpl}.options
identifies theuploaderImpl
subcomponent of the currentthat
(fluid.uploader
) (see IoCSS for more information about this notation)
The following context names are reserved within the IoC system:
- that
- arguments
- source
- sourcePath
- change
- instantiator
As a result, you should typically avoid defining types that use these names as the final segment (e.g todoList.source
or todoList.panel.that
), since it will be impossible to resolve references to these components in many contexts.