Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

User Provided Service Instances #3415

Merged
merged 109 commits into from
Mar 22, 2019
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
109 commits
Select commit Hold shift + click to select a range
4327c40
WIP
richard-cox Feb 15, 2019
f49f7c2
Tidy user service up actions
KlapTrap Feb 19, 2019
787901c
Add base step component route to service instance creation
KlapTrap Feb 20, 2019
818660c
Remove unused component
KlapTrap Feb 20, 2019
5a5c148
Ensure we have the correct cancel URL when editing a space service insta
KlapTrap Feb 20, 2019
32ef3a3
Remove console.log
KlapTrap Feb 20, 2019
367cc3b
Added tile selector
KlapTrap Feb 20, 2019
ea91982
Add help message and tidy up tile selector
KlapTrap Feb 20, 2019
522aa54
Allow a steppers step to hiden next button
KlapTrap Feb 21, 2019
b00cb25
Make app name unique directive generic
KlapTrap Feb 21, 2019
13b4a39
Fixed create user service
KlapTrap Feb 21, 2019
bcafc38
WIP Multi entity/action lists
KlapTrap Feb 21, 2019
5e498f1
Put service instance and user provided in same list
KlapTrap Feb 22, 2019
52c4c7b
Fix delete for multi action lists
KlapTrap Feb 22, 2019
91d72e1
Add updating for user provided services
KlapTrap Feb 22, 2019
8883d3c
Fix edit for local lists
KlapTrap Feb 25, 2019
3ff0b29
Added entity type select to multi action lists
KlapTrap Feb 27, 2019
b14759d
Fix provided service delete
KlapTrap Feb 27, 2019
71da3f1
Added default select text
KlapTrap Feb 28, 2019
d469b3e
Pass schema type into card component
KlapTrap Feb 28, 2019
80066ac
WIP Multiple careds per list
KlapTrap Mar 1, 2019
f5bd70d
Shwo more information on user provided service instance card
KlapTrap Mar 5, 2019
9375693
Fix update user provided action
KlapTrap Mar 5, 2019
34f272c
Relations fixes
richard-cox Mar 5, 2019
9a25288
Fix user service update
KlapTrap Mar 6, 2019
28ae3d6
Multi action can now render multiple cards
KlapTrap Mar 7, 2019
2cb9363
Fix none multi list local list
KlapTrap Mar 7, 2019
f04c2ff
Fix none multi component, multi action lists
KlapTrap Mar 7, 2019
b8d5850
Fix multi list tables
KlapTrap Mar 7, 2019
b8178c1
Fix paginator subscription leak
KlapTrap Mar 7, 2019
8b12b34
Remove the need for pageSubscription in list-data-source
KlapTrap Mar 7, 2019
473f904
Improve isPageReady logic
KlapTrap Mar 7, 2019
37d3009
Provide maxed entity per local page
KlapTrap Mar 7, 2019
d5012b6
Make maxList work with multi action lists
KlapTrap Mar 7, 2019
c7063fd
Revert app wall to single action list
KlapTrap Mar 8, 2019
462611d
Seperate service instance cards
KlapTrap Mar 8, 2019
0ad4736
CC fixes
KlapTrap Mar 8, 2019
8c8c11c
cc fixes
KlapTrap Mar 8, 2019
ed6b222
Revert app wall maxlist
KlapTrap Mar 8, 2019
96cc165
v2-master merge
richard-cox Mar 8, 2019
1d36229
Fix for older cf's with no tags
richard-cox Mar 8, 2019
f14346b
Missing file following merge
richard-cox Mar 8, 2019
e6c65d2
Merge remote-tracking branch 'origin/v2-master' into user-services
richard-cox Mar 8, 2019
ffd5214
Remove junk after merge
richard-cox Mar 8, 2019
2837fef
Fix new lint error
richard-cox Mar 11, 2019
59e0c14
Fix list view switching
KlapTrap Mar 11, 2019
20dc5d8
Pass entity key to the cell component
KlapTrap Mar 11, 2019
c1017ac
Fix table loading issue
KlapTrap Mar 11, 2019
dcfd91c
Fix linting
KlapTrap Mar 11, 2019
b07c07b
Update e2e tests wirth new create service instance flow.
KlapTrap Mar 11, 2019
c0bb399
Fix unit tests
KlapTrap Mar 12, 2019
50ee35b
Lint fix
KlapTrap Mar 12, 2019
8c0443f
More unit test fixes
KlapTrap Mar 12, 2019
014a5dc
Merge branch 'angular7' into user-services
richard-cox Mar 12, 2019
71b772b
Link fixes
richard-cox Mar 12, 2019
a380666
Merge branch 'user-services-temp' into user-services
richard-cox Mar 12, 2019
390178b
Temp remove [appApplicationNameUnique]="appNameChecking"
richard-cox Mar 12, 2019
3a7d36f
Remove depentent attribute
richard-cox Mar 12, 2019
03df97b
Fix cf-org-space selectors
KlapTrap Mar 12, 2019
c467d5c
fix pagination tests
KlapTrap Mar 12, 2019
f3127b6
Fix e2e tests
KlapTrap Mar 12, 2019
7e19158
Fixes for e2e tests
KlapTrap Mar 13, 2019
711d8b0
Merge branch 'v2-master' into user-services
KlapTrap Mar 13, 2019
be43a12
E2e fixes
KlapTrap Mar 13, 2019
adb83ca
e2e test fixes
KlapTrap Mar 13, 2019
39cd390
Fix marketplace test
KlapTrap Mar 13, 2019
cfba715
Fix more e2e tests
KlapTrap Mar 13, 2019
29c90f5
More e2e test fixes
KlapTrap Mar 13, 2019
ad05c0b
Another e2e fix
KlapTrap Mar 14, 2019
87a5b92
Add back in unique name check to user provided ser
KlapTrap Mar 14, 2019
cca53d5
Fix on enter stepper requirement
KlapTrap Mar 14, 2019
0543367
Fix user provided service instance delete
KlapTrap Mar 14, 2019
9e3ce07
Fix new service instance name chacking
KlapTrap Mar 14, 2019
7d235df
Unit test fix
KlapTrap Mar 14, 2019
69393e1
Fix populatePaginationFromParent
richard-cox Mar 14, 2019
0b54211
E2e fixes
KlapTrap Mar 14, 2019
56ac4f1
Merge branch 'v2-master' into user-services
KlapTrap Mar 15, 2019
6f74a24
Unit test fixes
KlapTrap Mar 15, 2019
504bfc3
Fix table cell updaing
KlapTrap Mar 18, 2019
9238e32
Fix linting
KlapTrap Mar 18, 2019
c95ade9
Fix craete service instance e2e tests
KlapTrap Mar 18, 2019
7b3c8ca
Add title to edit instance step.
KlapTrap Mar 18, 2019
4708511
Fix stepper with no onEnter
KlapTrap Mar 18, 2019
4cefbe3
Removing white space.
KlapTrap Mar 18, 2019
46ebfcc
Fix e2e test
KlapTrap Mar 18, 2019
228e8b0
Fix edit service instance test
KlapTrap Mar 18, 2019
ced80ef
Fix service wall e2e tests
KlapTrap Mar 18, 2019
77a721c
Fix menu for variable card
KlapTrap Mar 18, 2019
a0a2faf
Tweaks during review
richard-cox Mar 19, 2019
b7afb46
Fix switching entity types while not on the first page
KlapTrap Mar 20, 2019
321ca65
Fix unit test
richard-cox Mar 20, 2019
543669c
Fix flip flopping of list entities given out of sync pagination and e…
richard-cox Mar 20, 2019
12dc4bc
Fix application upbind
KlapTrap Mar 20, 2019
8b13021
Ensure we refetch applicating service bindings when service instance …
KlapTrap Mar 20, 2019
fabef5a
Tidy ups
richard-cox Mar 20, 2019
7346f3e
Fix app service binding list
richard-cox Mar 20, 2019
d9180e1
Fix issue with previous commit
richard-cox Mar 20, 2019
ec77704
Fix delete app
richard-cox Mar 20, 2019
2c0be97
Fix unit test
richard-cox Mar 20, 2019
12bdcbe
WIP User provided service binding
KlapTrap Mar 20, 2019
d6a79a1
Fix unit tests
richard-cox Mar 21, 2019
8f7ac89
More unit test fixes
richard-cox Mar 21, 2019
0c3364b
Merge branch 'user-provided-binding' into user-services
richard-cox Mar 21, 2019
68bfcb7
Complete create/bind user provided service on apps page
richard-cox Mar 21, 2019
a268a97
Fix prod
richard-cox Mar 21, 2019
80fabec
Another prod/e2e fix
richard-cox Mar 21, 2019
e184f3c
Fix unit test
richard-cox Mar 21, 2019
1fee213
Fix e2e tests
richard-cox Mar 21, 2019
012bd7c
Fix two issues
richard-cox Mar 21, 2019
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Add base step component route to service instance creation
  • Loading branch information
KlapTrap committed Feb 20, 2019
commit 787901c7a7a14f6e7728603f27b363ea35a011aa
7 changes: 7 additions & 0 deletions src/frontend/app/features/services/services.routing.ts
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,9 @@ import {
} from '../../shared/components/add-service-instance/add-service-instance/add-service-instance.component';
import { ServicesWallComponent } from './services-wall/services-wall.component';
import { DetachServiceInstanceComponent } from './detach-service-instance/detach-service-instance.component';
import {
AddServiceInstanceBaseStepComponent
} from '../../shared/components/add-service-instance/add-service-instance-base-step/add-service-instance-base-step.component';

const services: Routes = [
{
Expand All @@ -14,6 +17,10 @@ const services: Routes = [
},
{
path: 'new',
component: AddServiceInstanceBaseStepComponent
},
{
path: 'new/:type',
component: AddServiceInstanceComponent
},
{
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
<app-page-header>
Create Service Instance
</app-page-header>
<app-steppers [cancel]="'/s'">
<app-step [onNext]="next" finishButtonText="Next" title="Service Type">
<app-tile-selector [options]="tileSelectorConfig" (selection)="selectedTile = $event"></app-tile-selector>
</app-step>
</app-steppers>
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
import { async, ComponentFixture, TestBed } from '@angular/core/testing';

import { AddServiceInstanceBaseStepComponent } from './add-service-instance-base-step.component';

describe('AddServiceInstanceBaseStepComponent', () => {
let component: AddServiceInstanceBaseStepComponent;
let fixture: ComponentFixture<AddServiceInstanceBaseStepComponent>;

beforeEach(async(() => {
TestBed.configureTestingModule({
declarations: [ AddServiceInstanceBaseStepComponent ]
})
.compileComponents();
}));

beforeEach(() => {
fixture = TestBed.createComponent(AddServiceInstanceBaseStepComponent);
component = fixture.componentInstance;
fixture.detectChanges();
});

it('should create', () => {
expect(component).toBeTruthy();
});
});
Original file line number Diff line number Diff line change
@@ -0,0 +1,47 @@
import { ITileConfig, ITileData } from './../../tile/tile-selector.types';
import { Component } from '@angular/core';
import { TileConfigManager } from '../../tile/tile-selector.helpers';
import { of, Observable } from 'rxjs';
import { StepOnNextResult } from '../../stepper/step/step.component';
import { SERVICE_INSTANCE_TYPES } from './add-service-instance.types';
interface ICreateServiceTilesData extends ITileData {
type: string;
}

@Component({
selector: 'app-add-service-instance-base-step',
templateUrl: './add-service-instance-base-step.component.html',
styleUrls: ['./add-service-instance-base-step.component.scss']
})
export class AddServiceInstanceBaseStepComponent {
private tileManager = new TileConfigManager();
public serviceType: string;

public tileSelectorConfig = [
this.tileManager.getNextTileConfig<ICreateServiceTilesData>(
'Service',
{ type: SERVICE_INSTANCE_TYPES.SERVICE }
),
this.tileManager.getNextTileConfig<ICreateServiceTilesData>(
'User Provided Service',
{ type: SERVICE_INSTANCE_TYPES.USER_SERVICE }
)
];

public _selectedTile: ITileConfig<ICreateServiceTilesData>;
set selectedTile(tile: ITileConfig<ICreateServiceTilesData>) {
this.serviceType = tile.data.type;
this._selectedTile = tile;
}

public next = (): Observable<StepOnNextResult> => {
return of({
success: true,
redirect: true,
redirectPayload: {
path: `/services/new/${this.serviceType}`
}
});
}
constructor() { }
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
export enum SERVICE_INSTANCE_TYPES {
SERVICE = 'service',
USER_SERVICE = 'user-service'
}
Original file line number Diff line number Diff line change
Expand Up @@ -2,41 +2,42 @@
{{ title$ | async }}
</app-page-header>
<div class="add-service-instance">
<ng-container *ngIf="tileSelected === null || tileSelected === tileSelectorConfig[0].key">
<ng-container *ngIf="serviceType === serviceTypes.SERVICE">
<app-steppers [cancel]="modeService.cancelUrl">
<app-step title="Service Type">
<app-tile-selector [options]="tileSelectorConfig" [initialSelection]="tileSelectorConfig[0].key" (selection)="tileSelected = $event"></app-tile-selector>
</app-step>
<app-step *ngIf="modeService.viewDetail.showSelectCf && !isSpaceScoped()" title="Cloud Foundry" [onEnter]="resetStoreData"
[valid]="selectCF.validate | async" [onNext]="onNext" [blocked]="cfOrgSpaceService.isLoading$ | async">
<app-create-application-step1 [stepperText]="stepperText" [isMarketplaceMode]="inMarketplaceMode" #selectCF></app-create-application-step1>
</app-step>
<app-step title="Select Service" *ngIf="modeService.viewDetail.showSelectService" [valid]="selectService.validate | async"
[onNext]="selectService.onNext" [blocked]="selectService.isFetching$ | async">
<app-step *ngIf="modeService.viewDetail.showSelectCf && !isSpaceScoped()" title="Cloud Foundry"
[onEnter]="resetStoreData" [valid]="selectCF.validate | async" [onNext]="onNext"
[blocked]="cfOrgSpaceService.isLoading$ | async">
<app-create-application-step1 [stepperText]="stepperText" [isMarketplaceMode]="inMarketplaceMode" #selectCF>
</app-create-application-step1>
</app-step>
<app-step title="Select Service" *ngIf="modeService.viewDetail.showSelectService"
[valid]="selectService.validate | async" [onNext]="selectService.onNext"
[blocked]="selectService.isFetching$ | async">
<app-select-service #selectService></app-select-service>
</app-step>
<app-step title="Select Plan" [onNext]="selectPlan.onNext" [blocked]="initialisedService$ | async" [onEnter]="selectPlan.onEnter"
[valid]="selectPlan.validate | async" cancelButtonText="Cancel">
<app-step title="Select Plan" [onNext]="selectPlan.onNext" [blocked]="initialisedService$ | async"
[onEnter]="selectPlan.onEnter" [valid]="selectPlan.validate | async" cancelButtonText="Cancel">
<app-select-plan-step #selectPlan></app-select-plan-step>
</app-step>
<app-step [title]="bindAppStepperText" *ngIf="modeService.viewDetail.showBindApp" [skip]="skipApps$ | async"
[onEnter]="bindApp.onEnter" [onNext]="bindApp.submit " [valid]="bindApp.validate | async" cancelButtonText="Cancel">
[onEnter]="bindApp.onEnter" [onNext]="bindApp.submit " [valid]="bindApp.validate | async"
cancelButtonText="Cancel">
<app-bind-apps-step #bindApp [boundAppId]="appId"></app-bind-apps-step>
</app-step>
<app-step title="Service Instance" [onNext]="specifyDetails.onNext" [onEnter]="specifyDetails.onEnter" [blocked]="!!(specifyDetails.serviceInstancesInit$ | async)"
[valid]="specifyDetails.validate | async " cancelButtonText="Cancel " nextButtonText="Create ">
<app-specify-details-step [appId]="appId" #specifyDetails [showModeSelection]="!!appId "></app-specify-details-step>
<app-step title="Service Instance" [onNext]="specifyDetails.onNext" [onEnter]="specifyDetails.onEnter"
[blocked]="!!(specifyDetails.serviceInstancesInit$ | async)" [valid]="specifyDetails.validate | async "
cancelButtonText="Cancel " nextButtonText="Create ">
<app-specify-details-step [appId]="appId" #specifyDetails [showModeSelection]="!!appId ">
</app-specify-details-step>
</app-step>
</app-steppers>
</ng-container>
<ng-container *ngIf="tileSelected === tileSelectorConfig[1].key">
<ng-container *ngIf="serviceType === serviceTypes.USER_SERVICE">
<app-steppers [cancel]="modeService.cancelUrl">
<app-step title="Service Type">
<app-tile-selector [options]="tileSelectorConfig" [initialSelection]="tileSelectorConfig[1].key" (selection)="tileSelected = $event"></app-tile-selector>
</app-step>
<app-step *ngIf="modeService.viewDetail.showSelectCf" title="Cloud Foundry" [onEnter]="resetStoreData" [valid]="selectCF.validate | async"
[onNext]="onNext" [blocked]="cfOrgSpaceService.isLoading$ | async">
<app-create-application-step1 [stepperText]="stepperText" [isMarketplaceMode]="inMarketplaceMode" #selectCF></app-create-application-step1>
<app-step *ngIf="modeService.viewDetail.showSelectCf" title="Cloud Foundry" [onEnter]="resetStoreData"
[valid]="selectCF.validate | async" [onNext]="onNext" [blocked]="cfOrgSpaceService.isLoading$ | async">
<app-create-application-step1 [stepperText]="stepperText" [isMarketplaceMode]="inMarketplaceMode" #selectCF>
</app-create-application-step1>
</app-step>
<!-- // TODO: RC add blocked on loading list of existing user provided services -->
<!-- [blocked]="!!(specifyDetails.serviceInstancesInit$ | async)" -->
Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import { TitleCasePipe } from '@angular/common';
import { AfterContentInit, Component, OnDestroy } from '@angular/core';
import { ActivatedRoute } from '@angular/router';
import { ActivatedRoute, Router } from '@angular/router';
import { Store } from '@ngrx/store';
import { Observable, of as observableOf } from 'rxjs';
import { filter, first, map, switchMap, take, tap } from 'rxjs/operators';
Expand Down Expand Up @@ -42,6 +42,7 @@ import { CreateServiceInstanceHelperServiceFactory } from '../create-service-ins
import { CreateServiceInstanceHelper } from '../create-service-instance-helper.service';
import { CsiGuidsService } from '../csi-guids.service';
import { CsiModeService } from '../csi-mode.service';
import { SERVICE_INSTANCE_TYPES } from '../add-service-instance-base-step/add-service-instance.types';

@Component({
selector: 'app-add-service-instance',
Expand Down Expand Up @@ -69,15 +70,8 @@ export class AddServiceInstanceComponent implements OnDestroy, AfterContentInit
bindAppStepperText = 'Bind App (Optional)';
appId: string;
public inMarketplaceMode: boolean;
public tileSelected: number = null;
public tileSelectorConfig = [{
key: 0,
label: 'Service'
}, {
key: 1,
label: 'User Provided Service'
}];

public serviceType: SERVICE_INSTANCE_TYPES;
public serviceTypes = SERVICE_INSTANCE_TYPES;
constructor(
private cSIHelperServiceFactory: CreateServiceInstanceHelperServiceFactory,
private activatedRoute: ActivatedRoute,
Expand All @@ -86,9 +80,11 @@ export class AddServiceInstanceComponent implements OnDestroy, AfterContentInit
private csiGuidsService: CsiGuidsService,
private entityServiceFactory: EntityServiceFactory,
public modeService: CsiModeService,
private paginationMonitorFactory: PaginationMonitorFactory
private paginationMonitorFactory: PaginationMonitorFactory,
route: ActivatedRoute
) {
this.inMarketplaceMode = this.modeService.isMarketplaceMode();
this.serviceType = route.snapshot.params.type || SERVICE_INSTANCE_TYPES.SERVICE;
}
ngAfterContentInit(): void {
// Check if wizard has been initiated from the Services Marketplace
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -12,21 +12,27 @@ import { selectCreateServiceInstance } from '../../../../store/selectors/create-
import { CloudFoundryUserProvidedServicesService } from '../../../services/cloud-foundry-user-provided-services.service';
import { isValidJsonValidator } from '../../schema-form/schema-form.component';
import { StepOnNextResult } from '../../stepper/step/step.component';
import {
CreateUserProvidedServiceInstance,
IUserProvidedServiceInstanceData
} from '../../../../store/actions/user-provided-service.actions';
import { EntityMonitor } from '../../../monitors/entity-monitor';
import {
entityFactory,
userProvidedServiceInstanceSchemaKey
} from '../../../../store/helpers/entity-factory';

@Component({
selector: 'app-specify-user-provided-details',
templateUrl: './specify-user-provided-details.component.html',
styleUrls: ['./specify-user-provided-details.component.scss']
})
export class SpecifyUserProvidedDetailsComponent implements OnInit, OnDestroy {



formGroup: FormGroup;
tags: { label: string }[] = [];
separatorKeysCodes = [ENTER, COMMA, SPACE];
allServiceInstanceNames: string[];
subs: Subscription[] = [];
public formGroup: FormGroup;
public tags: { label: string }[] = [];
public separatorKeysCodes = [ENTER, COMMA, SPACE];
public allServiceInstanceNames: string[];
public subs: Subscription[] = [];

constructor(
private store: Store<AppState>,
Expand Down Expand Up @@ -54,18 +60,16 @@ export class SpecifyUserProvidedDetailsComponent implements OnInit, OnDestroy {
}

onNext = (): Observable<StepOnNextResult> => {
return this.store.select(selectCreateServiceInstance).pipe(
filter(p => !!p),
switchMap(csi => {
// TODO: RC editing
return this.userProvidedServicesService.createUserProvidedService();
}),
map(request => {
return {
success: !request.error,
message: `Failed to create user provided service instance: ${request.message}`
};
}),
const data = this.formGroup.value as IUserProvidedServiceInstanceData;
const action = new CreateUserProvidedServiceInstance('cfGuid', 'dasd', data);
this.store.dispatch(action);
return new EntityMonitor(
this.store, 'a', 'a', entityFactory(userProvidedServiceInstanceSchemaKey)
).entityRequest$.pipe(
filter(er => er.creating),
map(er => ({
success: !er.error
}))
);
}

Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,7 @@
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, TemplateRef, ViewChild } from '@angular/core';
import { Observable, of as observableOf } from 'rxjs';
import { IRouterNavPayload } from '../../../../store/actions/router.actions';


export interface IStepperStep {
validate: Observable<boolean>;
Expand All @@ -12,6 +14,7 @@ export interface StepOnNextResult {
message?: string;
// Should we redirect to the store previous state?
redirect?: boolean;
redirectPayload?: IRouterNavPayload;
// Ignore the result of a successful `onNext` call. Handy when sometimes you want to avoid navigation/step change
ignoreSuccess?: boolean;
data?: any;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -2,14 +2,17 @@
<div class="steppers" *ngIf="steps && steps.length">
<div class="steppers__inner">
<div class="steppers__headers" *ngIf="steps.length > 1">
<div *ngFor="let step of steps; let i = index" [ngClass]="{'steppers__header--active': step.active, 'steppers__header--busy': step.blocked}" class="steppers__header">
<div *ngFor="let step of steps; let i = index"
[ngClass]="{'steppers__header--active': step.active, 'steppers__header--busy': step.blocked}"
class="steppers__header">
<div class="steppers__header-inner" *ngIf="steps.length !== 1">
<!-- Blocked -->
<mat-spinner *ngIf="step.blocked; else notBlocked" diameter="20"></mat-spinner>
<!-- Not Blocked -->
<ng-template #notBlocked>
<app-dot-content [disabled]="step.skip">
<mat-icon class="steppers__header-complete" *ngIf="step.complete">{{ this.getIconLigature() }}</mat-icon>
<mat-icon class="steppers__header-complete" *ngIf="step.complete">{{ this.getIconLigature() }}
</mat-icon>
<div *ngIf="!step.complete ">{{ i + 1 }}</div>
</app-dot-content>
</ng-template>
Expand All @@ -22,17 +25,25 @@
</div>
<div class="steppers__navigation">
<div class="steppers__navigation-left">
<button id="stepper_previous" *ngIf="steps.length !== 1" color="accent" mat-button mat-raised-button (click)="setActive(currentIndex - 1)" [disabled]="!canGoto(currentIndex - 1)">Previous</button>
<button id="stepper_previous" *ngIf="steps.length !== 1" color="accent" mat-button mat-raised-button
(click)="setActive(currentIndex - 1)" [disabled]="!canGoto(currentIndex - 1)">Previous</button>
</div>
<div class="steppers__navigation-right">
<button id="stepper_cancel" color="primary" mat-button [routerLink]="cancel$ | async" [queryParams]="cancelQueryParams$ | async" [disabled]="!canCancel(currentIndex)" *ngIf="cancel" (click)="steps[currentIndex].onLeave(false)">{{ this.getCancelButtonText(currentIndex) }}</button>
<button id="stepper_next" class="steppers__navigation-right__next" [color]="steps[currentIndex].destructiveStep ? 'warn' : 'primary'" type="submit" mat-button mat-raised-button (click)="goNext(currentIndex)" [disabled]="steps[currentIndex].busy || steps[currentIndex].blocked || !canGoNext(currentIndex)">
<mat-progress-spinner *ngIf="showNextButtonProgress; else nextButtonText" diameter="20" mode="indeterminate" color="accent"></mat-progress-spinner>&nbsp;
<button id="stepper_cancel" color="primary" mat-button [routerLink]="cancel$ | async"
[queryParams]="cancelQueryParams$ | async" [disabled]="!canCancel(currentIndex)" *ngIf="cancel"
(click)="steps[currentIndex].onLeave(false)">{{ this.getCancelButtonText(currentIndex) }}</button>
<button id="stepper_next" class="steppers__navigation-right__next"
[color]="steps[currentIndex].destructiveStep ? 'warn' : 'primary'" type="submit" mat-button
mat-raised-button (click)="goNext(currentIndex)"
[disabled]="steps[currentIndex].busy || steps[currentIndex].blocked || !canGoNext(currentIndex)">
<mat-progress-spinner *ngIf="showNextButtonProgress; else nextButtonText" diameter="20" mode="indeterminate"
color="accent"></mat-progress-spinner>&nbsp;
<!--white space added to ensure line height is applied (important for situations where there's no cancel)-->
<ng-template #nextButtonText>{{ this.getNextButtonText(currentIndex) }}</ng-template>
{{this.steps[currentIndex].finishButtonText}}
</button>
</div>
</div>
</div>
</div>
</div>
</div>
Loading