mirror of
https://github.com/octoleo/syncthing.git
synced 2024-12-30 13:40:35 +00:00
create db completion service and mock data
This commit is contained in:
parent
bc7d71ee3d
commit
09673ba0c6
@ -20,9 +20,10 @@ export class DeviceChartComponent implements OnInit {
|
|||||||
ngOnInit(): void { }
|
ngOnInit(): void { }
|
||||||
|
|
||||||
ngAfterViewInit(): void {
|
ngAfterViewInit(): void {
|
||||||
// TODO switch to deviceService
|
|
||||||
this.deviceService.getAll().subscribe(
|
this.deviceService.getAll().subscribe(
|
||||||
device => {
|
device => {
|
||||||
|
console.log("device", device);
|
||||||
|
|
||||||
// Get StateType and convert to string
|
// Get StateType and convert to string
|
||||||
const stateType: Device.StateType = Device.getStateType(device);
|
const stateType: Device.StateType = Device.getStateType(device);
|
||||||
const state: string = Device.stateTypeToString(stateType);
|
const state: string = Device.stateTypeToString(stateType);
|
||||||
|
6
src/app/completion.ts
Normal file
6
src/app/completion.ts
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
export interface Completion {
|
||||||
|
completion: number;
|
||||||
|
globalBytes: number;
|
||||||
|
needBytes: number;
|
||||||
|
needDeletes: number;
|
||||||
|
}
|
24
src/app/mocks/mock-db-completion.ts
Normal file
24
src/app/mocks/mock-db-completion.ts
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
export const dbCompletion =
|
||||||
|
[
|
||||||
|
{
|
||||||
|
"device": "YZJBJFX-RDBL7WY-6ZGKJ2D-4MJB4E7-ZATSDUY-LD6Y3L3-MLFUYWE-AEMXJAC",
|
||||||
|
"completion": 100,
|
||||||
|
"globalBytes": 156793013575,
|
||||||
|
"needBytes": 0,
|
||||||
|
"needDeletes": 0
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"completion": 80,
|
||||||
|
"globalBytes": 3013575,
|
||||||
|
"needBytes": 100,
|
||||||
|
"needDeletes": 0
|
||||||
|
}
|
||||||
|
]
|
||||||
|
/*
|
||||||
|
{
|
||||||
|
"completion": 100,
|
||||||
|
"globalBytes": 156793013575,
|
||||||
|
"needBytes": 0,
|
||||||
|
"needDeletes": 0
|
||||||
|
}
|
||||||
|
*/
|
16
src/app/services/db-completion.service.spec.ts
Normal file
16
src/app/services/db-completion.service.spec.ts
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
import { TestBed } from '@angular/core/testing';
|
||||||
|
|
||||||
|
import { DbCompletionService } from './db-completion.service';
|
||||||
|
|
||||||
|
describe('DbCompletionService', () => {
|
||||||
|
let service: DbCompletionService;
|
||||||
|
|
||||||
|
beforeEach(() => {
|
||||||
|
TestBed.configureTestingModule({});
|
||||||
|
service = TestBed.inject(DbCompletionService);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should be created', () => {
|
||||||
|
expect(service).toBeTruthy();
|
||||||
|
});
|
||||||
|
});
|
43
src/app/services/db-completion.service.ts
Normal file
43
src/app/services/db-completion.service.ts
Normal file
@ -0,0 +1,43 @@
|
|||||||
|
import { Injectable } from '@angular/core';
|
||||||
|
import { HttpClient, HttpParams } from '@angular/common/http';
|
||||||
|
import { environment } from 'src/environments/environment';
|
||||||
|
import { apiURL, apiRetry } from '../api-utils';
|
||||||
|
import { Completion } from '../completion';
|
||||||
|
import { retry, map } from 'rxjs/operators';
|
||||||
|
import { Observable } from 'rxjs';
|
||||||
|
|
||||||
|
@Injectable({
|
||||||
|
providedIn: 'root'
|
||||||
|
})
|
||||||
|
export class DbCompletionService {
|
||||||
|
private dbStatusUrl = environment.production ? apiURL + 'rest/db/completion' : 'api/dbCompletion';
|
||||||
|
|
||||||
|
constructor(private http: HttpClient) { }
|
||||||
|
|
||||||
|
getDeviceCompletion(id: string): Observable<Completion> {
|
||||||
|
let httpOptions: { params: HttpParams };
|
||||||
|
if (id) {
|
||||||
|
httpOptions = {
|
||||||
|
params: new HttpParams().set('device', id)
|
||||||
|
};
|
||||||
|
} else { }
|
||||||
|
|
||||||
|
return this.http
|
||||||
|
.get<Completion>(this.dbStatusUrl, httpOptions)
|
||||||
|
.pipe(
|
||||||
|
retry(apiRetry),
|
||||||
|
map(res => {
|
||||||
|
// Remove from array in developement
|
||||||
|
// in-memory-web-api returns arrays
|
||||||
|
if (!environment.production) {
|
||||||
|
const a: any = res as any;
|
||||||
|
if (a.length > 0) {
|
||||||
|
res = res[0];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return res;
|
||||||
|
})
|
||||||
|
);
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
@ -15,7 +15,7 @@ import Folder from '../folder'
|
|||||||
export class DbStatusService {
|
export class DbStatusService {
|
||||||
private dbStatusUrl = environment.production ? apiURL + 'rest/db/status' : 'api/dbStatus';
|
private dbStatusUrl = environment.production ? apiURL + 'rest/db/status' : 'api/dbStatus';
|
||||||
|
|
||||||
constructor(private http: HttpClient, private cookieService: CookieService) { }
|
constructor(private http: HttpClient) { }
|
||||||
|
|
||||||
getFolderStatus(id: string): Observable<Folder.Status> {
|
getFolderStatus(id: string): Observable<Folder.Status> {
|
||||||
let httpOptions: { params: HttpParams };
|
let httpOptions: { params: HttpParams };
|
||||||
|
@ -3,6 +3,7 @@ import Device from '../device';
|
|||||||
import { Observable } from 'rxjs';
|
import { Observable } from 'rxjs';
|
||||||
import { SystemConfigService } from './system-config.service';
|
import { SystemConfigService } from './system-config.service';
|
||||||
import { SystemConnectionsService } from './system-connections.service';
|
import { SystemConnectionsService } from './system-connections.service';
|
||||||
|
import { DbCompletionService } from './db-completion.service';
|
||||||
|
|
||||||
@Injectable({
|
@Injectable({
|
||||||
providedIn: 'root'
|
providedIn: 'root'
|
||||||
@ -11,7 +12,8 @@ export class DeviceService {
|
|||||||
private devices: Device[];
|
private devices: Device[];
|
||||||
constructor(
|
constructor(
|
||||||
private systemConfigService: SystemConfigService,
|
private systemConfigService: SystemConfigService,
|
||||||
private systemConnectionsService: SystemConnectionsService
|
private systemConnectionsService: SystemConnectionsService,
|
||||||
|
private dbCompletionService: DbCompletionService
|
||||||
) { }
|
) { }
|
||||||
|
|
||||||
getAll(): Observable<Device> {
|
getAll(): Observable<Device> {
|
||||||
@ -40,9 +42,16 @@ export class DeviceService {
|
|||||||
connections => {
|
connections => {
|
||||||
// TODO: check connection and request total
|
// TODO: check connection and request total
|
||||||
this.devices.forEach(device => {
|
this.devices.forEach(device => {
|
||||||
|
// TODO make this synchronous
|
||||||
|
this.dbCompletionService.getDeviceCompletion(device.deviceID).subscribe(
|
||||||
|
c => {
|
||||||
|
device.completion = c.completion;
|
||||||
observer.next(device);
|
observer.next(device);
|
||||||
});
|
});
|
||||||
observer.complete();
|
|
||||||
|
//TODO complete observer when finished
|
||||||
|
// observer.complete();
|
||||||
|
});
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
|
||||||
|
@ -2,13 +2,14 @@ import { Injectable } from '@angular/core';
|
|||||||
import { config } from '../mocks/mock-config'
|
import { config } from '../mocks/mock-config'
|
||||||
import { dbStatus } from '../mocks/mock-db-status'
|
import { dbStatus } from '../mocks/mock-db-status'
|
||||||
import { connections } from '../mocks/mock-connections'
|
import { connections } from '../mocks/mock-connections'
|
||||||
|
import { dbCompletion } from '../mocks/mock-db-completion'
|
||||||
|
|
||||||
@Injectable({
|
@Injectable({
|
||||||
providedIn: 'root'
|
providedIn: 'root'
|
||||||
})
|
})
|
||||||
export class InMemoryConfigDataService {
|
export class InMemoryConfigDataService {
|
||||||
createDb() {
|
createDb() {
|
||||||
return { config, dbStatus, connections };
|
return { config, dbStatus, connections, dbCompletion };
|
||||||
}
|
}
|
||||||
|
|
||||||
constructor() { }
|
constructor() { }
|
||||||
|
@ -59,10 +59,9 @@ export class SystemConfigService {
|
|||||||
return folderObservable;
|
return folderObservable;
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO switch to devices
|
|
||||||
getDevices(): Observable<Device[]> {
|
getDevices(): Observable<Device[]> {
|
||||||
const deviceObserverable: Observable<Device[]> = new Observable((observer) => {
|
const deviceObserverable: Observable<Device[]> = new Observable((observer) => {
|
||||||
if (this.folders) {
|
if (this.devices) {
|
||||||
observer.next(this.devices);
|
observer.next(this.devices);
|
||||||
} else {
|
} else {
|
||||||
let t = setInterval(() => {
|
let t = setInterval(() => {
|
||||||
|
Loading…
Reference in New Issue
Block a user