@genialis/resolwe
Version:
Resolwe frontend libraries
111 lines (109 loc) • 15.2 kB
JavaScript
var __extends = (this && this.__extends) || (function () {
var extendStatics = function (d, b) {
extendStatics = Object.setPrototypeOf ||
({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
return extendStatics(d, b);
};
return function (d, b) {
extendStatics(d, b);
function __() { this.constructor = d; }
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
};
})();
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
return c > 3 && r && Object.defineProperty(target, key, r), r;
};
Object.defineProperty(exports, "__esModule", { value: true });
var _ = require("lodash");
var base_1 = require("./base");
var component_1 = require("../../tests/component");
component_1.describeComponent('base component', [], function (tester) {
var DummyComponent = /** @class */ (function (_super) {
__extends(DummyComponent, _super);
// @ngInject
DummyComponent.$inject = ["$scope"];
function DummyComponent($scope) {
var _this = _super.call(this, $scope) || this;
_this.array = [];
_this.strObservable = _this.createWatchObservable(function () { return _this.str; });
_this.arrayObservable = _this.createWatchObservable(function () { return _this.array; }, true);
return _this;
}
DummyComponent = __decorate([
base_1.component({
module: tester.module,
directive: 'gen-watch-observable',
})
], DummyComponent);
return DummyComponent;
}(base_1.ComponentBase));
it('should reactively update on shallow component changes', function () {
var dummyComponent = tester.createComponent(DummyComponent.asView().template);
// Test this.str
var strSpy = jasmine.createSpy('strSpy');
dummyComponent.ctrl.strObservable
.distinctUntilChanged()
.subscribe(function (value) { return strSpy(_.cloneDeep(value)); });
dummyComponent.ctrl.str = 'some value';
tester.digest();
expect(strSpy.calls.count()).toBe(2);
expect(strSpy.calls.first().args[0]).toBeUndefined();
expect(strSpy.calls.mostRecent().args[0]).toBe('some value');
});
it('should reactively update on deep component changes', function () {
var dummyComponent = tester.createComponent(DummyComponent.asView().template);
// Test this.array
var arraySpy = jasmine.createSpy('arraySpy');
dummyComponent.ctrl.arrayObservable
.filter(function (value) { return !_.isEmpty(value); })
.subscribe(function (value) { return arraySpy(_.cloneDeep(value)); });
dummyComponent.ctrl.array.push('some value');
tester.digest();
dummyComponent.ctrl.array.push('some other value');
tester.digest();
expect(arraySpy.calls.all()[0].args[0]).toEqual(['some value']);
expect(arraySpy.calls.all()[1].args[0]).toEqual(['some value', 'some other value']);
});
it('should support watch', function () {
var dummyComponent = tester.createComponent(DummyComponent.asView().template);
// No watch should be created if computation is immediately unsubscribed.
var expression = 0;
var executed = 0;
var watchComputation = dummyComponent.ctrl.watch(function () { return expression; }, function (computation) {
executed++;
expect(computation.isDone()).toBeFalsy();
computation.unsubscribe();
});
expect(watchComputation.isDone()).toBeTruthy();
expression = 1;
tester.digest();
expect(executed).toBe(1);
// Check that watching works correctly.
expression = 0;
executed = 0;
watchComputation = dummyComponent.ctrl.watch(function () { return expression; }, function (computation) {
executed++;
if (executed > 2)
computation.unsubscribe();
});
expect(watchComputation.isDone()).toBeFalsy();
expression = 1;
tester.digest();
// Just to check that watch is only evaluated when the expression changes.
tester.digest();
expect(executed).toBe(2);
expression = 2;
tester.digest();
expect(executed).toBe(3);
// Check that unsubscribe actually stops the watch.
expression = 3;
tester.digest();
expect(executed).toBe(3);
});
});
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["../src/core/components/base.spec.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;AAAA,0BAA4B;AAI5B,+BAAgD;AAChD,mDAAwD;AAExD,6BAAiB,CAAC,gBAAgB,EAAE,EAAE,EAAE,UAAC,MAAM;IAK3C;QAA6B,kCAAa;QAOtC,YAAY;QACZ,wBAAY,MAAsB;YAAlC,YACI,kBAAM,MAAM,CAAC,SAIhB;YATM,WAAK,GAAa,EAAE,CAAC;YAOxB,KAAI,CAAC,aAAa,GAAG,KAAI,CAAC,qBAAqB,CAAC,cAAM,OAAA,KAAI,CAAC,GAAG,EAAR,CAAQ,CAAC,CAAC;YAChE,KAAI,CAAC,eAAe,GAAG,KAAI,CAAC,qBAAqB,CAAC,cAAM,OAAA,KAAI,CAAC,KAAK,EAAV,CAAU,EAAE,IAAI,CAAC,CAAC;;QAC9E,CAAC;QAbC,cAAc;YAJnB,gBAAS,CAAC;gBACP,MAAM,EAAE,MAAM,CAAC,MAAM;gBACrB,SAAS,EAAE,sBAAsB;aACpC,CAAC;WACI,cAAc,CAcnB;QAAD,qBAAC;KAdD,AAcC,CAd4B,oBAAa,GAczC;IAED,EAAE,CAAC,uDAAuD,EAAE;QACxD,IAAM,cAAc,GAAG,MAAM,CAAC,eAAe,CACzC,cAAc,CAAC,MAAM,EAAE,CAAC,QAAQ,CACnC,CAAC;QAEF,gBAAgB;QAChB,IAAM,MAAM,GAAG,OAAO,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;QAC3C,cAAc,CAAC,IAAI,CAAC,aAAa;aAC5B,oBAAoB,EAAE;aACtB,SAAS,CAAC,UAAC,KAAK,IAAK,OAAA,MAAM,CAAC,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,EAA1B,CAA0B,CAAC,CAAC;QAEtD,cAAc,CAAC,IAAI,CAAC,GAAG,GAAG,YAAY,CAAC;QACvC,MAAM,CAAC,MAAM,EAAE,CAAC;QAEhB,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACrC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,aAAa,EAAE,CAAC;QACrD,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,UAAU,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IACjE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,oDAAoD,EAAE;QACrD,IAAM,cAAc,GAAG,MAAM,CAAC,eAAe,CACzC,cAAc,CAAC,MAAM,EAAE,CAAC,QAAQ,CACnC,CAAC;QAEF,kBAAkB;QAClB,IAAM,QAAQ,GAAG,OAAO,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;QAC/C,cAAc,CAAC,IAAI,CAAC,eAAe;aAC9B,MAAM,CAAC,UAAC,KAAK,IAAK,OAAA,CAAC,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,EAAjB,CAAiB,CAAC;aACpC,SAAS,CAAC,UAAC,KAAK,IAAK,OAAA,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,EAA5B,CAA4B,CAAC,CAAC;QAExD,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QAC7C,MAAM,CAAC,MAAM,EAAE,CAAC;QAChB,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;QACnD,MAAM,CAAC,MAAM,EAAE,CAAC;QAEhB,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC;QAChE,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,YAAY,EAAE,kBAAkB,CAAC,CAAC,CAAC;IACxF,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,sBAAsB,EAAE;QACvB,IAAM,cAAc,GAAG,MAAM,CAAC,eAAe,CACzC,cAAc,CAAC,MAAM,EAAE,CAAC,QAAQ,CACnC,CAAC;QAEF,yEAAyE;QACzE,IAAI,UAAU,GAAG,CAAC,CAAC;QACnB,IAAI,QAAQ,GAAG,CAAC,CAAC;QACjB,IAAI,gBAAgB,GAAG,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,cAAM,OAAA,UAAU,EAAV,CAAU,EAAE,UAAC,WAAW;YAC3E,QAAQ,EAAE,CAAC;YACX,MAAM,CAAC,WAAW,CAAC,MAAM,EAAE,CAAC,CAAC,SAAS,EAAE,CAAC;YACzC,WAAW,CAAC,WAAW,EAAE,CAAC;QAC9B,CAAC,CAAC,CAAC;QACH,MAAM,CAAC,gBAAgB,CAAC,MAAM,EAAE,CAAC,CAAC,UAAU,EAAE,CAAC;QAE/C,UAAU,GAAG,CAAC,CAAC;QACf,MAAM,CAAC,MAAM,EAAE,CAAC;QAChB,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAEzB,uCAAuC;QACvC,UAAU,GAAG,CAAC,CAAC;QACf,QAAQ,GAAG,CAAC,CAAC;QACb,gBAAgB,GAAG,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,cAAM,OAAA,UAAU,EAAV,CAAU,EAAE,UAAC,WAAW;YACvE,QAAQ,EAAE,CAAC;YACX,IAAI,QAAQ,GAAG,CAAC;gBAAE,WAAW,CAAC,WAAW,EAAE,CAAC;QAChD,CAAC,CAAC,CAAC;QACH,MAAM,CAAC,gBAAgB,CAAC,MAAM,EAAE,CAAC,CAAC,SAAS,EAAE,CAAC;QAE9C,UAAU,GAAG,CAAC,CAAC;QACf,MAAM,CAAC,MAAM,EAAE,CAAC;QAChB,0EAA0E;QAC1E,MAAM,CAAC,MAAM,EAAE,CAAC;QAChB,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAEzB,UAAU,GAAG,CAAC,CAAC;QACf,MAAM,CAAC,MAAM,EAAE,CAAC;QAChB,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAEzB,mDAAmD;QACnD,UAAU,GAAG,CAAC,CAAC;QACf,MAAM,CAAC,MAAM,EAAE,CAAC;QAChB,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAC7B,CAAC,CAAC,CAAC;AACP,CAAC,CAAC,CAAC","file":"core/components/base.spec.js","sourcesContent":["import * as _ from 'lodash';\nimport * as Rx from 'rx';\nimport * as angular from 'angular';\n\nimport {ComponentBase, component} from './base';\nimport {describeComponent} from '../../tests/component';\n\ndescribeComponent('base component', [], (tester) => {\n    @component({\n        module: tester.module,\n        directive: 'gen-watch-observable',\n    })\n    class DummyComponent extends ComponentBase {\n        public str: string;\n        public strObservable: Rx.Observable<string>;\n\n        public array: string[] = [];\n        public arrayObservable: Rx.Observable<string[]>;\n\n        // @ngInject\n        constructor($scope: angular.IScope) {\n            super($scope);\n\n            this.strObservable = this.createWatchObservable(() => this.str);\n            this.arrayObservable = this.createWatchObservable(() => this.array, true);\n        }\n    }\n\n    it('should reactively update on shallow component changes', () => {\n        const dummyComponent = tester.createComponent<DummyComponent>(\n            DummyComponent.asView().template\n        );\n\n        // Test this.str\n        const strSpy = jasmine.createSpy('strSpy');\n        dummyComponent.ctrl.strObservable\n            .distinctUntilChanged()\n            .subscribe((value) => strSpy(_.cloneDeep(value)));\n\n        dummyComponent.ctrl.str = 'some value';\n        tester.digest();\n\n        expect(strSpy.calls.count()).toBe(2);\n        expect(strSpy.calls.first().args[0]).toBeUndefined();\n        expect(strSpy.calls.mostRecent().args[0]).toBe('some value');\n    });\n\n    it('should reactively update on deep component changes', () => {\n        const dummyComponent = tester.createComponent<DummyComponent>(\n            DummyComponent.asView().template\n        );\n\n        // Test this.array\n        const arraySpy = jasmine.createSpy('arraySpy');\n        dummyComponent.ctrl.arrayObservable\n            .filter((value) => !_.isEmpty(value))\n            .subscribe((value) => arraySpy(_.cloneDeep(value)));\n\n        dummyComponent.ctrl.array.push('some value');\n        tester.digest();\n        dummyComponent.ctrl.array.push('some other value');\n        tester.digest();\n\n        expect(arraySpy.calls.all()[0].args[0]).toEqual(['some value']);\n        expect(arraySpy.calls.all()[1].args[0]).toEqual(['some value', 'some other value']);\n    });\n\n    it('should support watch', () => {\n        const dummyComponent = tester.createComponent<DummyComponent>(\n            DummyComponent.asView().template\n        );\n\n        // No watch should be created if computation is immediately unsubscribed.\n        let expression = 0;\n        let executed = 0;\n        let watchComputation = dummyComponent.ctrl.watch(() => expression, (computation) => {\n            executed++;\n            expect(computation.isDone()).toBeFalsy();\n            computation.unsubscribe();\n        });\n        expect(watchComputation.isDone()).toBeTruthy();\n\n        expression = 1;\n        tester.digest();\n        expect(executed).toBe(1);\n\n        // Check that watching works correctly.\n        expression = 0;\n        executed = 0;\n        watchComputation = dummyComponent.ctrl.watch(() => expression, (computation) => {\n            executed++;\n            if (executed > 2) computation.unsubscribe();\n        });\n        expect(watchComputation.isDone()).toBeFalsy();\n\n        expression = 1;\n        tester.digest();\n        // Just to check that watch is only evaluated when the expression changes.\n        tester.digest();\n        expect(executed).toBe(2);\n\n        expression = 2;\n        tester.digest();\n        expect(executed).toBe(3);\n\n        // Check that unsubscribe actually stops the watch.\n        expression = 3;\n        tester.digest();\n        expect(executed).toBe(3);\n    });\n});\n\n\n"]}
;