import { FormBuilder, ReactiveFormsModule } from '@angular/forms';
import { MatIconModule, MatTableModule } from '@angular/material';
-import { of } from 'rxjs';
-
import { EICoordinatorComponent } from './ei-coordinator.component';
import { EIJobDataSource } from './ei-job.datasource';
import { EIProducerDataSource } from './ei-producer.datasource';
let fixture: ComponentFixture<EICoordinatorComponent>;
beforeEach(async(() => {
- const jobDataSourceSpy = jasmine.createSpyObj('EIJobDataSource', [ 'connect', 'getJobs', 'disconnect' ]);
- const producerDataSourceSpy = jasmine.createSpyObj('EIProducerDataSource', [ 'connect', 'loadTable', 'loadProducers', 'disconnect' ]);
+ const jobDataSourceSpy = jasmine.createSpyObj('EIJobDataSource', [ 'loadJobs', 'eiJobs' ]);
+ const producerDataSourceSpy = jasmine.createSpyObj('EIProducerDataSource', [ 'loadProducers', 'eiProducers' ]);
+
+ jobDataSourceSpy.eiJobs.and.returnValue([]);
- jobDataSourceSpy.connect.and.returnValue(of([]));
- jobDataSourceSpy.disconnect();
- producerDataSourceSpy.connect.and.returnValue(of([]));
- producerDataSourceSpy.loadProducers.and.returnValue(of([]));
- producerDataSourceSpy.disconnect();
+ producerDataSourceSpy.eiProducers.and.returnValue([]);
TestBed.configureTestingModule({
imports: [
})
export class EICoordinatorComponent implements OnInit {
- producers$: Observable<EIProducer[]>;
@ViewChild(MatSort, { static: true }) sort: MatSort;
@ViewChild('producersTable', { static: true }) table: MatTable<Element>;
}
ngOnInit() {
- this.eiJobsDataSource.getJobs();
- this.producers$ = this.eiProducersDataSource.loadProducers();
- this.jobsDataSource = new MatTableDataSource(this.eiJobsDataSource.eiJobsSubject.value);
- this.producersDataSource = new MatTableDataSource(this.eiProducersDataSource.producerSubject.value)
+ this.eiJobsDataSource.loadJobs();
+ this.eiProducersDataSource.loadProducers();
+ this.jobsDataSource = new MatTableDataSource(this.eiJobsDataSource.eiJobs());
+ this.producersDataSource = new MatTableDataSource(this.eiProducersDataSource.eiProducers());
this.jobsFormControl.valueChanges.subscribe(value => {
const filter = {...value, id: value.id.trim().toLowerCase()} as string;
}
refreshTables() {
- this.eiJobsDataSource.getJobs();
+ this.eiJobsDataSource.loadJobs();
this.eiProducersDataSource.loadProducers();
}
}
* ========================LICENSE_END===================================
*/
import { TestBed } from '@angular/core/testing';
-import { BehaviorSubject, of } from 'rxjs';
+import { of } from 'rxjs';
import { EIJobDataSource } from './ei-job.datasource';
import { EIService } from '../services/ei/ei.service';
});
it('#getJobs', () => {
- dataSource.getJobs();
- const jobsSubject: BehaviorSubject<EIJob[]> = dataSource.eiJobsSubject;
- const value = jobsSubject.getValue();
- expect(value).toEqual([ job, job ]);
+ dataSource.loadJobs();
+ const actualJobs: EIJob[] = dataSource.eiJobs();
+ expect(actualJobs).toEqual([ job, job ]);
expect(dataSource.rowCount).toEqual(2);
});
});
*/
import { Injectable } from '@angular/core';
-import { MatTableDataSource } from '@angular/material';
import { BehaviorSubject } from 'rxjs/BehaviorSubject';
providedIn: 'root'
})
-export class EIJobDataSource extends MatTableDataSource<EIJob> {
+export class EIJobDataSource {
- eiJobsSubject = new BehaviorSubject<EIJob[]>([]);
+ private eiJobsSubject = new BehaviorSubject<EIJob[]>([]);
+
+ public eiJobs(): EIJob[] {
+ return this.eiJobsSubject.value;
+ }
private loadingSubject = new BehaviorSubject<boolean>(false);
constructor(
private eiSvc: EIService) {
- super();
}
- getJobs() {
+ loadJobs() {
this.loadingSubject.next(true);
this.eiSvc.getProducerIds()
.subscribe((producerIds: string[]) => {
const updatedValue = [...currentValue, ...jobs];
this.eiJobsSubject.next(updatedValue);
}
-
- connect(): BehaviorSubject<EIJob[]> {
- return this.eiJobsSubject;
- }
-
- disconnect(): void {
- this.eiJobsSubject.complete();
- this.loadingSubject.complete();
- }
}
* ========================LICENSE_END===================================
*/
import { TestBed } from '@angular/core/testing';
-import { BehaviorSubject, of } from 'rxjs';
+import { of } from 'rxjs';
import { EIService } from '../services/ei/ei.service';
import { ToastrModule } from 'ngx-toastr';
it('#loadProducers', () => {
dataSource.loadProducers();
- const jobsSubject: BehaviorSubject<EIProducer[]> = dataSource.producerSubject;
- const value = jobsSubject.getValue();
- expect(value).toEqual([ expectedProducer1, expectedProducer2 ]);
+ const actualProducers: EIProducer[] = dataSource.eiProducers();
+ expect(actualProducers).toEqual([ expectedProducer1, expectedProducer2 ]);
expect(dataSource.rowCount).toEqual(2);
});
});
*/
import { Injectable } from '@angular/core';
-import { MatTableDataSource } from '@angular/material';
-import { Observable } from 'rxjs/Observable';
import { BehaviorSubject } from 'rxjs/BehaviorSubject';
-import { of } from 'rxjs/observable/of';
import { EIProducer } from '../interfaces/ei.types';
import { EIService } from '../services/ei/ei.service';
providedIn: 'root'
})
-export class EIProducerDataSource extends MatTableDataSource<EIProducer> {
+export class EIProducerDataSource {
- producerSubject = new BehaviorSubject<EIProducer[]>([]);
+ private producerSubject = new BehaviorSubject<EIProducer[]>([]);
+
+ public eiProducers(): EIProducer[] {
+ return this.producerSubject.value;
+ }
private loadingSubject = new BehaviorSubject<boolean>(false);
constructor(
private eiSvc: EIService) {
- super();
}
- loadProducers(): Observable<EIProducer[]> {
+ loadProducers() {
this.loadingSubject.next(true);
let producers: Array<EIProducer> = [];
this.eiSvc.getProducerIds()
});
this.rowCount = this.producerSubject.value.length;
});
- return of(producers);
}
private addProducerToSubject(producer: EIProducer) {
const updatedValue = [...currentValue, producer];
this.producerSubject.next(updatedValue);
}
-
- connect(): BehaviorSubject<EIProducer[]> {
- return this.producerSubject;
- }
-
- disconnect(): void {
- this.producerSubject.complete();
- this.loadingSubject.complete();
- }
}
\ No newline at end of file