Skip to content
This repository has been archived by the owner on Jul 30, 2018. It is now read-only.

Commit

Permalink
forward compatibility with TS2.4
Browse files Browse the repository at this point in the history
  • Loading branch information
agubler committed Jun 22, 2017
1 parent 17c92a0 commit 5499be0
Show file tree
Hide file tree
Showing 6 changed files with 17 additions and 29 deletions.
8 changes: 4 additions & 4 deletions src/Injector.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import { assign } from '@dojo/core/lang';
import { Evented } from '@dojo/core/Evented';
import { diffProperty, afterRender, WidgetBase, InternalWNode, InternalHNode } from './WidgetBase';
import { diffProperty, afterRender, WidgetBase } from './WidgetBase';
import { decorate, isHNode, isWNode } from './d';
import { DiffType } from './diff';
import {
Expand Down Expand Up @@ -64,7 +64,7 @@ export interface InjectorProperties extends WidgetProperties {
scope: any;
render(): DNode;
getProperties?: GetProperties;
properties: WidgetProperties;
properties: any;
getChildren?: GetChildren;
children: DNode[];
}
Expand Down Expand Up @@ -100,9 +100,9 @@ export function Injector<C extends Evented, T extends Constructor<BaseInjector<C
}

@afterRender()
protected decoratateBind(node: DNode) {
protected decorateBind(node: DNode) {
const { scope } = this.properties;
decorate(node, (node: InternalHNode | InternalWNode) => {
decorate(node, (node: any) => {
const { properties } = node;
properties.bind = scope;
}, (node: DNode) => { return isHNode(node) || isWNode(node); });
Expand Down
20 changes: 4 additions & 16 deletions src/WidgetBase.ts
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,6 @@ import {
PropertiesChangeEvent,
RegistryLabel,
HNode,
WNode,
WidgetMetaConstructor
} from './interfaces';
import MetaBase from './meta/Base';
Expand All @@ -35,17 +34,6 @@ interface WidgetCacheWrapper {
used: boolean;
}

export interface InternalWNode extends WNode {
properties: {
bind: any;
};
}
export interface InternalHNode extends HNode {
properties: {
bind: any;
};
}

enum WidgetRenderState {
IDLE = 1,
PROPERTIES,
Expand Down Expand Up @@ -145,7 +133,7 @@ function isHNodeWithKey(node: DNode): node is HNode {
* Main widget base for all widgets to extend
*/
@diffProperty('bind', DiffType.REFERENCE)
export class WidgetBase<P extends WidgetProperties = WidgetProperties, C extends DNode = DNode> extends Evented implements WidgetBaseInterface<P, C> {
export class WidgetBase<P = WidgetProperties, C extends DNode = DNode> extends Evented implements WidgetBaseInterface<P, C> {

/**
* static identifier
Expand Down Expand Up @@ -175,7 +163,7 @@ export class WidgetBase<P extends WidgetProperties = WidgetProperties, C extends
/**
* internal widget properties
*/
private _properties: P;
private _properties: P & WidgetProperties;

/**
* properties from the previous render
Expand Down Expand Up @@ -309,7 +297,7 @@ export class WidgetBase<P extends WidgetProperties = WidgetProperties, C extends

@afterRender()
protected decorateBind(node: DNode | DNode[]): DNode | DNode[] {
decorate(node, (node: InternalWNode | InternalHNode) => {
decorate(node, (node: any) => {
const { properties = {} }: { properties: { bind?: any } } = node;
if (!properties.bind) {
properties.bind = this;
Expand Down Expand Up @@ -364,7 +352,7 @@ export class WidgetBase<P extends WidgetProperties = WidgetProperties, C extends
this._nodeMap.set(String(properties.key), <HTMLElement> element);
}

public get properties(): Readonly<P> {
public get properties(): Readonly<P> & Readonly<WidgetProperties> {
return this._properties;
}

Expand Down
4 changes: 2 additions & 2 deletions src/interfaces.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -338,13 +338,13 @@ export interface DefaultWidgetBaseInterface extends WidgetBaseInterface<WidgetPr
* The interface for WidgetBase
*/
export interface WidgetBaseInterface<
P extends WidgetProperties = WidgetProperties,
P = WidgetProperties,
C extends DNode = DNode<DefaultWidgetBaseInterface>> extends Evented {

/**
* Widget properties
*/
readonly properties: P;
readonly properties: P & WidgetProperties;

/**
* Returns the widget's children
Expand Down
8 changes: 4 additions & 4 deletions tests/unit/WidgetBase.ts
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,6 @@ import * as registerSuite from 'intern!object';
import * as assert from 'intern/chai!assert';
import { stub, spy, SinonStub } from 'sinon';
import { v, w, registry } from '../../src/d';
import { DNode, WidgetProperties } from '../../src/interfaces';
import {
WidgetBase,
diffProperty,
Expand All @@ -13,9 +12,10 @@ import {
beforeRender,
onPropertiesChanged
} from '../../src/WidgetBase';
import { Constructor, DNode } from '../../src/interfaces';
import WidgetRegistry, { WIDGET_BASE_TYPE } from './../../src/WidgetRegistry';

interface TestProperties extends WidgetProperties {
interface TestProperties {
id: string;
foo: string;
bar?: null | string;
Expand Down Expand Up @@ -859,7 +859,7 @@ widget.__setProperties__({
'async factories only initialise once'() {
let resolveFunction: any;
const loadFunction = () => {
return new Promise((resolve) => {
return new Promise<Constructor<WidgetBase>>((resolve) => {
resolveFunction = resolve;
});
};
Expand Down Expand Up @@ -907,7 +907,7 @@ widget.__setProperties__({
'render with async factory'() {
let resolveFunction: any;
const loadFunction = () => {
return new Promise((resolve) => {
return new Promise<Constructor<WidgetBase>>((resolve) => {
resolveFunction = resolve;
});
};
Expand Down
2 changes: 1 addition & 1 deletion tests/unit/WidgetRegistry.ts
Original file line number Diff line number Diff line change
Expand Up @@ -81,7 +81,7 @@ registerSuite({
const RegistryTestWidget = factoryRegistry.get<TestWidget>('test-widget');
assert.isNotNull(RegistryTestWidget);
const widget = new RegistryTestWidget!();
// demontrates the design time typing
// demonstrates the design time typing
widget.__setProperties__({ foo: 'bar' });
},
'throws an error if factory has not been registered.'() {
Expand Down
4 changes: 2 additions & 2 deletions tests/unit/testIntegration.tsx
Original file line number Diff line number Diff line change
@@ -1,10 +1,10 @@
import * as registerSuite from 'intern!object';
import * as assert from 'intern/chai!assert';
import { WidgetBase } from '../../src/WidgetBase';
import { fromRegistry, registry } from '../../src/d';
import { registry } from '../../src/d';
import { WidgetProperties } from '../../src/interfaces';
import { VNode } from '@dojo/interfaces/vdom';
import * as tsx from './../../src/tsx';
import { fromRegistry } from './../../src/tsx';

registerSuite({
name: 'tsx',
Expand Down

0 comments on commit 5499be0

Please sign in to comment.