update folder devices array for the "shared with" section in the folder list #CTR-2

This commit is contained in:
Jesse Lucas 2020-04-12 21:56:01 -04:00
parent 7a9f317ee1
commit 8b4a1f52d0

View File

@ -6,6 +6,7 @@ import { DbStatusService } from './db-status.service';
import { ProgressService } from './progress.service'; import { ProgressService } from './progress.service';
import { DbCompletionService } from './db-completion.service'; import { DbCompletionService } from './db-completion.service';
import { StType } from '../type'; import { StType } from '../type';
import { DeviceService } from './device.service';
@Injectable({ @Injectable({
providedIn: 'root' providedIn: 'root'
@ -19,6 +20,7 @@ export class FolderService {
constructor( constructor(
private systemConfigService: SystemConfigService, private systemConfigService: SystemConfigService,
private deviceService: DeviceService,
private dbStatusService: DbStatusService, private dbStatusService: DbStatusService,
private dbCompletionService: DbCompletionService, private dbCompletionService: DbCompletionService,
private progressService: ProgressService, private progressService: ProgressService,
@ -33,6 +35,26 @@ export class FolderService {
} }
const folder: Folder = this.folders[startIndex]; const folder: Folder = this.folders[startIndex];
startIndex = startIndex + 1; startIndex = startIndex + 1;
// Folder devices array only has deviceID
// and we want all the device info
this.systemConfigService.getDevices().subscribe(
devices => {
devices.forEach(device => {
// Update any device this folder
// has reference to
folder.devices.forEach((folderDevice, index) => {
if (folderDevice.deviceID === device.deviceID) {
console.log("find device match?", device.name)
folder.devices[index] = device;
console.log("update?", folder.devices);
}
});
});
// Gather the folder information from the status and
// completion services
this.dbStatusService.getFolderStatus(folder.id).subscribe( this.dbStatusService.getFolderStatus(folder.id).subscribe(
status => { status => {
folder.status = status; folder.status = status;
@ -46,12 +68,16 @@ export class FolderService {
this.folderAddedSource.next(folder); this.folderAddedSource.next(folder);
this.progressService.addToProgress(1); this.progressService.addToProgress(1);
// Now that we have all the folder information
// recursively get the status of the next folder // recursively get the status of the next folder
this.getFolderStatusInOrder(startIndex); this.getFolderStatusInOrder(startIndex);
}); });
} }
); );
} }
)
}
/** /**
* requestFolders() requests each folder and uses db status service to * requestFolders() requests each folder and uses db status service to