self-assert / SectionDraftAssistant
Class: SectionDraftAssistant<Model, ContainerModel, ComposedModels>
Assists in the creation of complex models by coordinating multiple inner DraftAssistant
.
It uses a CreationClosure function to combine the models created by its assistants into a single composed model.
Extends
DraftAssistant
<Model
,ContainerModel
>
Extended by
Type Parameters
Type Parameter | Default type | Description |
---|---|---|
Model | any | - |
ContainerModel | any | - |
ComposedModels extends unknown [] | any [] | An array of types representing the types of the models created by the inner assistants, in the same order as the assistants array. |
Constructors
Constructor
new SectionDraftAssistant<
Model
,ContainerModel
,ComposedModels
>(assistants
,creationClosure
,modelFromContainer
,assertionIds
):SectionDraftAssistant
<Model
,ContainerModel
,ComposedModels
>
Parameters
Parameter | Type |
---|---|
assistants | AssistantsIn <ComposedModels , Model > |
creationClosure | CreationClosure <Model , ComposedModels > |
modelFromContainer | ModelFromContainer <Model , ContainerModel > |
assertionIds | string [] |
Returns
SectionDraftAssistant
<Model
, ContainerModel
, ComposedModels
>
Overrides
DraftAssistant<Model, ContainerModel>.constructor
Error handling
handleError()
handleError(
possibleCreateModelError
):void
Parameters
Parameter | Type |
---|---|
possibleCreateModelError | unknown |
Returns
void
routeBrokenRulesOf()
routeBrokenRulesOf(
aRulesBrokenError
):void
Parameters
Parameter | Type |
---|---|
aRulesBrokenError | RulesBroken |
Returns
void
routeBrokenRule()
routeBrokenRule(
brokenRule
):void
Parameters
Parameter | Type |
---|---|
brokenRule | LabeledRule |
Returns
void
Model creation
isInvalidModel()
static
isInvalidModel(potentialModel
):boolean
Parameters
Parameter | Type |
---|---|
potentialModel | unknown |
Returns
boolean
Inherited from
createModel()
createModel():
Model
Attempts to create a model. It fails if any of the assertions fail.
Returns
Model
See
Throws
RulesBroken if the model is invalid
Overrides
setModel()
setModel(
newModel
):void
Parameters
Parameter | Type |
---|---|
newModel | Model |
Returns
void
Overrides
resetModel()
resetModel():
void
Resets the model to its initial value.
Returns
void
Overrides
withCreatedModelDo()
withCreatedModelDo<
ReturnType
>(validModelClosure
,invalidModelClosure
):ReturnType
Executes a closure depending on whether the model is valid or not after creating it.
Type Parameters
Type Parameter | Description |
---|---|
ReturnType | The type of the value returned by the closures. |
Parameters
Parameter | Type | Description |
---|---|---|
validModelClosure | (model ) => ReturnType | A closure that will be called with the created model if it's valid. |
invalidModelClosure | () => ReturnType | A closure that will be called if the model is invalid. |
Returns
ReturnType
The return value of the closure that was called.
Inherited from
DraftAssistant
.withCreatedModelDo
getModel()
getModel():
Model
Returns
Model
Inherited from
setModelFrom()
setModelFrom(
containerModel
):void
Sets the model from its container.
Parameters
Parameter | Type |
---|---|
containerModel | ContainerModel |
Returns
void
Inherited from
Rules
addBrokenRule()
addBrokenRule(
aBrokenRuleLabel
):void
Adds a rule to the list of broken rules.
Parameters
Parameter | Type |
---|---|
aBrokenRuleLabel | LabeledRule |
Returns
void
Inherited from
addBrokenRules()
addBrokenRules(
brokenRules
):void
Adds a list of rules to the list of broken rules.
Parameters
Parameter | Type |
---|---|
brokenRules | LabeledRule [] |
Returns
void
Inherited from
hasBrokenRules()
hasBrokenRules():
boolean
Returns
boolean
true
if the list of broken rules is not empty
Inherited from
doesNotHaveBrokenRules()
doesNotHaveBrokenRules():
boolean
Opposite of hasBrokenRules.
Returns
boolean
Inherited from
DraftAssistant
.doesNotHaveBrokenRules
brokenRulesDescriptions()
brokenRulesDescriptions():
string
[]
Returns
string
[]
The descriptions of the broken rules
Inherited from
DraftAssistant
.brokenRulesDescriptions
handles()
handles(
aRule
):boolean
Parameters
Parameter | Type |
---|---|
aRule | LabeledRule |
Returns
boolean
true
if this assistant handles the given Assertion
.
Inherited from
addLabelId()
addLabelId(
aLabelId
):void
Adds an assertion id to the list of handled assertions.
Parameters
Parameter | Type |
---|---|
aLabelId | string |
Returns
void
Inherited from
hasBrokenRule()
hasBrokenRule(
aBrokenRuleLabel
):boolean
Parameters
Parameter | Type |
---|---|
aBrokenRuleLabel | LabeledRule |
Returns
boolean
Inherited from
hasOnlyOneRuleBrokenIdentifiedAs()
hasOnlyOneRuleBrokenIdentifiedAs(
assertionId
):boolean
Parameters
Parameter | Type |
---|---|
assertionId | string |
Returns
boolean
true
if this assistant has only one failed assertion that is identified as the given assertionId
.
Remarks
Used mostly for testing.
Inherited from
DraftAssistant
.hasOnlyOneRuleBrokenIdentifiedAs
removeBrokenRules()
removeBrokenRules():
void
Returns
void
Inherited from
DraftAssistant
.removeBrokenRules
Viewers
accept()
accept(
aViewer
):void
Adds a viewer to the list of observers.
Parameters
Parameter | Type |
---|---|
aViewer | DraftViewer <Model > |
Returns
void
Inherited from
removeViewer()
removeViewer(
aViewer
):void
Removes a viewer from the list of observers.
Parameters
Parameter | Type |
---|---|
aViewer | DraftViewer <never > |
Returns
void
Inherited from
numberOfViewers()
numberOfViewers():
number
Returns
number
The number of viewers currently observing the assistant.
Inherited from
DraftAssistant
.numberOfViewers
Others
with()
static
with<Model
,ContainerModel
,ComposedModels
>(assistants
,creationClosure
,modelFromContainer
,assertionIds
):SectionDraftAssistant
<Model
,ContainerModel
,ComposedModels
>
Type Parameters
Type Parameter | Default type |
---|---|
Model | any |
ContainerModel | any |
ComposedModels extends unknown [] | any [] |
Parameters
Parameter | Type |
---|---|
assistants | AssistantsIn <ComposedModels , Model > |
creationClosure | CreationClosure <Model , ComposedModels > |
modelFromContainer | ModelFromContainer <Model , ContainerModel > |
assertionIds | string [] |
Returns
SectionDraftAssistant
<Model
, ContainerModel
, ComposedModels
>
topLevelContainerWith()
static
topLevelContainerWith<Model
,ComposedModels
>(assistants
,creationClosure
,assertionIds
):SectionDraftAssistant
<Model
,unknown
,ComposedModels
>
Type Parameters
Type Parameter | Default type |
---|---|
Model | any |
ComposedModels extends unknown [] | any [] |
Parameters
Parameter | Type | Default value |
---|---|---|
assistants | AssistantsIn <ComposedModels , Model > | undefined |
creationClosure | CreationClosure <Model , ComposedModels > | undefined |
assertionIds | string [] | [] |
Returns
SectionDraftAssistant
<Model
, unknown
, ComposedModels
>
topLevelModelFromContainer()
static
topLevelModelFromContainer<Model
>():ModelFromContainer
<Model
,unknown
>
Type Parameters
Type Parameter | Default type |
---|---|
Model | any |
Returns
ModelFromContainer
<Model
, unknown
>
A default model getter from a container for the top-level assistant. Since there is no container to get the model from, it throws an error.