@@ -1,35 +1,35 | |||||
1 | { |
|
1 | { | |
2 | "name": "@implab/djx", |
|
2 | "name": "@implab/djx", | |
3 | "version": "0.0.1-dev", |
|
3 | "version": "0.0.1-dev", | |
4 | "description": "Supports using dojo version 1 with typescript and .tsx files", |
|
4 | "description": "Supports using dojo version 1 with typescript and .tsx files", | |
5 | "keywords": [ |
|
5 | "keywords": [ | |
6 | "dojo", |
|
6 | "dojo", | |
7 | "tsx", |
|
7 | "tsx", | |
8 | "typescript", |
|
8 | "typescript", | |
9 | "widgets" |
|
9 | "widgets" | |
10 | ], |
|
10 | ], | |
11 | "author": "Implab team", |
|
11 | "author": "Implab team", | |
12 | "license": "BSD-2-Clause", |
|
12 | "license": "BSD-2-Clause", | |
13 | "repository": "https://code.implab.org/implab/implabjs-djx", |
|
13 | "repository": "https://code.implab.org/implab/implabjs-djx", | |
14 | "publishConfig": { |
|
14 | "publishConfig": { | |
15 | "access": "public" |
|
15 | "access": "public" | |
16 | }, |
|
16 | }, | |
17 | "peerDependencies": { |
|
17 | "peerDependencies": { | |
18 | "@implab/core-amd": "^1.4.0", |
|
18 | "@implab/core-amd": "^1.4.0", | |
19 | "dojo": "^1.10.0" |
|
19 | "dojo": "^1.10.0" | |
20 | }, |
|
20 | }, | |
21 | "devDependencies": { |
|
21 | "devDependencies": { | |
22 | "@implab/core-amd": "^1.4.0", |
|
22 | "@implab/core-amd": "^1.4.0", | |
23 | "@types/chai": "4.1.3", |
|
23 | "@types/chai": "4.1.3", | |
24 | "@types/requirejs": "2.1.31", |
|
24 | "@types/requirejs": "2.1.31", | |
25 | "@types/yaml": "1.2.0", |
|
25 | "@types/yaml": "1.2.0", | |
26 | "chai": "4.2.0", |
|
26 | "chai": "4.2.0", | |
27 | "dojo": "1.16.0", |
|
27 | "dojo": "1.16.0", | |
28 | "dojo-typings": "~1.11.9", |
|
28 | "dojo-typings": "~1.11.9", | |
29 | "eslint": "6.8.0", |
|
29 | "eslint": "6.8.0", | |
30 | "requirejs": "2.3.6", |
|
30 | "requirejs": "2.3.6", | |
31 | "tslint": "^6.1.3", |
|
31 | "tslint": "^6.1.3", | |
32 |
"typescript": "4. |
|
32 | "typescript": "4.2.4", | |
33 | "yaml": "~1.7.2" |
|
33 | "yaml": "~1.7.2" | |
34 | } |
|
34 | } | |
35 | } |
|
35 | } |
@@ -1,29 +1,32 | |||||
1 | import { argumentNotNull } from "@implab/core-amd/safe"; |
|
1 | import { argumentNotNull } from "@implab/core-amd/safe"; | |
2 | import { RenditionBase } from "./RenditionBase"; |
|
2 | import { RenditionBase } from "./RenditionBase"; | |
3 |
|
3 | |||
4 | export class FunctionRendition extends RenditionBase<Node> { |
|
4 | export class FunctionRendition extends RenditionBase<Node> { | |
5 |
private _component: ( |
|
5 | private _component: (...args: any[]) => any; | |
6 |
|
6 | |||
7 | private _node: Node | undefined; |
|
7 | private _node: Node | undefined; | |
8 |
|
8 | |||
9 |
constructor(component: ( |
|
9 | constructor(component: (...args: any[]) => any) { | |
10 | super(); |
|
10 | super(); | |
11 | argumentNotNull(component, "component"); |
|
11 | argumentNotNull(component, "component"); | |
12 |
|
12 | |||
13 | this._component = component; |
|
13 | this._component = component; | |
14 | } |
|
14 | } | |
15 |
|
15 | |||
16 | _create(attrs: object, children: any[]) { |
|
16 | protected _create(attrs: object, children: any[]) { | |
17 | const _attrs: any = attrs || {}; |
|
17 | const _attrs: any = attrs || {}; | |
18 |
|
|
18 | const _children = children.map(x => this.getItemDom(x)); | |
19 |
|
19 | this._node = this.getItemDom( | ||
20 | this._node = this.getItemDom(this._component.call(null, _attrs)); |
|
20 | this._component.length === 2 ? | |
|
21 | this._component.call(null, { ..._attrs }, _children) : | |||
|
22 | this._component.call(null, { ..._attrs, children: _children }) | |||
|
23 | ); | |||
21 | } |
|
24 | } | |
22 |
|
25 | |||
23 | _getDomNode() { |
|
26 | protected _getDomNode() { | |
24 | if (!this._node) |
|
27 | if (!this._node) | |
25 | throw new Error("The instance of the widget isn't created"); |
|
28 | throw new Error("The instance of the widget isn't created"); | |
26 | return this._node; |
|
29 | return this._node; | |
27 | } |
|
30 | } | |
28 |
|
31 | |||
29 | } |
|
32 | } |
General Comments 0
You need to be logged in to leave comments.
Login now