Я использую angular-svg-round-progressbar для создания динамического загрузчика.У меня есть функция остановки загрузчика, но мне нужно создать диалоговое окно подтверждения, которое дает вам возможность либо остановить загрузчик, либо продолжить.для этой цели я использую диалоговое окно углового материала, но проблема в том, что когда диалоговое окно всплывает, загрузчик продолжает загрузку, и нажимаю ли я кнопку «да» или «нет» (в диалоговом окне), загрузка заканчивается.
это мое завершениефункция:
finish() {
this.current = this.max;
this.dialogService.openConfirmDialog('On hold.Do you want to cancel this
Sprint ? ')
.afterClosed().subscribe((result: boolean) => {
if (result) {
alert('gonna submit it!');
}
});
}
и это мой загрузчик HTML:
<main class="content">
<h1>Here's your timer !</h1>
<div class="progress-wrapper" *ngIf="maxVal">
<div class="text" *ngIf="!isFinished">
{{ max - current | number: '1.1-1' }}
</div>
<div class="text" *ngIf="isFinished">
ding!
<audio src="assets/chime.mp3" autoplay></audio>
</div>
<round-progress [max]="maxVal" [current]="currentVal" [radius]="100" [stroke]="25">
</round-progress>
</div>
<div class="controls-wrapper">
<div>
<label>Focus on yout task :) ! </label>
<br> <br>
<input class="input" placeholder="number of seconds" type="text" [(ngModel)]="max" (keydown)="reset()">
</div>
<button class="button is-danger" *ngIf="!isFinished" (click)="finish()">Finish</button>
</div>
</main>
и это служба диалога:
export class DialogService {
constructor( private dialog: MatDialog) { }
openConfirmDialog(msg){
return this.dialog.open(MatConfirmDialogComponent, {
width :'350px',
position: { top : "10px"},
panelClass: 'confirm-dialog-container',
disableClose : true,
data : {
message : msg
}
});
}
}
это мой полный компонент:
import { Component, OnInit, Input } from '@angular/core';
import { SprintService } from '../services/sprint.service';
import { NotificationService } from '../services/notification.service';
import { Sprint } from '../../../sprint';
import { ProgressCircleComponent } from '../progress-circle/progress-circle.component';
import { InteractionService } from '../services/interaction.service';
import { DialogService } from '../shared/dialog.service';
import { Observable } from 'rxjs';
import { resetComponentState } from '@angular/core/src/render3/instructions';
import { MatDialog, MatSnackBar } from '@angular/material';
@Component({
selector: 'sprint-card',
templateUrl: './sprintCard.component.html',
styleUrls: ['./sprintCard.component.css'],
providers: [SprintService, NotificationService]
})
export class SprintCardComponent implements OnInit {
@Input()
sprints: Sprint[];
durationSec: number;
duration: string;
public selectedSprint: any;
constructor(private sprintService: SprintService, private notificationService: NotificationService,
private interactionService: InteractionService, private dialogService: DialogService,
private dialog: MatDialog,
private snackBar: MatSnackBar) {
this.sprintService.getSprints()
.subscribe(sprints => {
this.sprints = sprints;
});
}
ngOnInit() {
this.interactionService.sprintData$
.subscribe(selectedSprint => {
this.selectedSprint = selectedSprint;
console.log(selectedSprint)
});
}
startLoader() {
this.max = this.selectedSprint.duration;
const interval = Observable.interval(this.selectedSprint.duration);
interval
.takeWhile(_ => !this.isFinished)
.do(i => this.current += 1)
.subscribe();
}
max = 1;
current = 0;
stopLoader() {
this.current = this.max;
this.dialogService.openConfirmDialog('On hold.Do you want to cancel this Sprint ? ')
.afterClosed().subscribe((result: boolean) => {
if (result) {
alert('you stoppped the loader at x ');
}
});
}
/// reset timer
reset() {
this.current = 0;
}
/// Getters to prevent NaN errors
get maxVal() {
return isNaN(this.max) || this.max < 0.1 ? 0.1 : this.max;
}
get currentVal() {
return isNaN(this.current) || this.current < 0 ? 0 : this.current;
}
get isFinished() {
return this.currentVal >= this.maxVal;
}
}