##// END OF EJS Templates
Added tag v1.0.2 for changeset ed3c20c09b00
Added tag v1.0.2 for changeset ed3c20c09b00

File last commit:

r38:5c6c7e16919c v1.0.0-rc18 default
r47:5b7c733ef63d default
Show More
WidgetContext.ts
95 lines | 2.9 KiB | video/mp2t | TypeScriptLexer
/ src / main / ts / tsx / WidgetContext.ts
cin
sync
r7 import dom = require("dojo/dom-construct");
import { argumentNotNull } from "@implab/core-amd/safe";
import { BuildContextBase } from "./BuildContextBase";
cin
Fixes in WidgetContex, added _Container.addChild support
r38 import { DojoNodePosition, isWidget } from "./traits";
cin
sync
r7
cin
Added DjxFragment...
r19 // tslint:disable-next-line: class-name
export interface _Widget {
domNode: Node;
cin
Fixes in WidgetContex, added _Container.addChild support
r38 containerNode?: Node;
cin
Added DjxFragment...
r19
cin
Fixes in WidgetContex, added _Container.addChild support
r38 placeAt?(refNode: string | Node, position?: DojoNodePosition): void;
startup?(): void;
cin
Added DjxFragment...
r19
cin
Fixes in WidgetContex, added _Container.addChild support
r38 addChild?(widget: any, index?: number): void;
cin
Added DjxFragment...
r19 }
export type _WidgetCtor = new (attrs: any, srcNode?: string | Node) => _Widget;
cin
sync
r7
cin
Switched to dojo-typings...
r22 export class WidgetContext extends BuildContextBase<Node> {
cin
Fixes in WidgetContex, added _Container.addChild support
r38 readonly widgetClass: _WidgetCtor;
cin
sync
r7
cin
Added DjxFragment...
r19 _instance: _Widget | undefined;
cin
sync
r7
cin
Added DjxFragment...
r19 constructor(widgetClass: _WidgetCtor) {
cin
sync
r7 super();
argumentNotNull(widgetClass, "widgetClass");
this.widgetClass = widgetClass;
}
_addChild(child: any): void {
cin
Fixes in WidgetContex, added _Container.addChild support
r38 const instance = this._getInstance();
cin
sync
r7
cin
Fixes in WidgetContex, added _Container.addChild support
r38 if (instance.addChild) {
if (child instanceof WidgetContext)
// layout containers add custom logic to addChild methods
instance.addChild(child.getWidgetInstance());
else if (isWidget(child))
instance.addChild(child);
else
instance.addChild(this.getChildDom(child));
} else {
if (!instance.containerNode)
throw new Error("The widget doesn't have neither addChild nor containerNode");
// the current widget isn't started, it's children shouldn't start too
dom.place(this.getChildDom(child), instance.containerNode);
}
cin
sync
r7 }
_create(attrs: object, children: any[]) {
cin
Support for Function Components...
r34 this._instance = new this.widgetClass(attrs);
cin
sync
r7 if (children)
children.forEach(x => this._addChild(x));
}
cin
Fixes in WidgetContex, added _Container.addChild support
r38 private _getInstance() {
if (!this._instance)
throw new Error("The instance of the widget isn't created");
return this._instance;
}
cin
Added DjxFragment...
r19 _getDomNode() {
cin
sync
r7 if (!this._instance)
throw new Error("The instance of the widget isn't created");
return this._instance.domNode;
}
cin
Fixes in WidgetContex, added _Container.addChild support
r38 /** Overrides default placeAt implementation. Calls placeAt of the
* widget and then starts it.
*
* @param refNode A node or id of the node where the widget should be placed.
* @param position A position relative to refNode.
*/
placeAt(refNode: string | Node, position?: DojoNodePosition) {
this.ensureCreated();
const instance = this._getInstance();
if (typeof instance.placeAt === "function") {
instance.placeAt(refNode, position);
// do we need to force widget startup?
if (typeof instance.startup === "function")
instance.startup();
} else {
super.placeAt(refNode, position);
}
}
getWidgetInstance() {
this.ensureCreated();
return this._getInstance();
}
cin
sync
r7 }