Filter SimpleTransition by StateLabel
All checks were successful
E2E Testing / test (push) Successful in 1m36s
All checks were successful
E2E Testing / test (push) Successful in 1m36s
This commit is contained in:
parent
02d9fcbbba
commit
41452f0b9d
@ -1,2 +1,4 @@
|
||||
<app-simple-state-editor [states]="simpleGamesystem!.states" [gamesystem]="simpleGamesystem"></app-simple-state-editor>
|
||||
<app-simple-transition-editor class="transition-editor" [gamesystem]="simpleGamesystem"></app-simple-transition-editor>
|
||||
<div id="transition-editor">
|
||||
<app-simple-transition-editor [gamesystem]="simpleGamesystem"></app-simple-transition-editor>
|
||||
</div>
|
||||
|
@ -1,3 +1,4 @@
|
||||
.transition-editor {
|
||||
margin-top: 15px;
|
||||
#transition-editor {
|
||||
margin-top: 20px !important;
|
||||
|
||||
}
|
||||
|
@ -1,3 +1,5 @@
|
||||
<mat-card>
|
||||
<mat-card-content>
|
||||
<table mat-table [dataSource]="dataSource" class="mat-elevation-z8" multiTemplateDataRows>
|
||||
<ng-container matColumnDef="name">
|
||||
<th mat-header-cell *matHeaderCellDef>Label</th>
|
||||
@ -75,3 +77,6 @@
|
||||
</tr>
|
||||
<tr mat-row *matRowDef="let row; columns: ['expandedDetail']" class="example-detail-row"></tr>
|
||||
</table>
|
||||
|
||||
</mat-card-content>
|
||||
</mat-card>
|
||||
|
@ -1,3 +1,10 @@
|
||||
<mat-card>
|
||||
<mat-card-content>
|
||||
<mat-form-field class="long-form">
|
||||
<mat-label>Filter</mat-label>
|
||||
<input matInput (keyup)="applyFilter($event)" placeholder="Filter" #input>
|
||||
</mat-form-field>
|
||||
|
||||
<table mat-table [dataSource]="dataSource" class="mat-elevation-z8" multiTemplateDataRows>
|
||||
<ng-container matColumnDef="starting-state">
|
||||
<th mat-header-cell *matHeaderCellDef>Starting State</th>
|
||||
@ -79,3 +86,6 @@
|
||||
</tr>
|
||||
<tr mat-row *matRowDef="let row; columns: ['expandedDetail']" class="example-detail-row"></tr>
|
||||
</table>
|
||||
|
||||
</mat-card-content>
|
||||
</mat-card>
|
||||
|
@ -13,6 +13,8 @@ import {
|
||||
import {SimpleTransition} from "../../../../game-model/gamesystems/SimpleTransition";
|
||||
import {animate, state, style, transition, trigger} from "@angular/animations";
|
||||
import {SimpleState} from "../../../../game-model/gamesystems/SimpleState";
|
||||
import {ProductTransition} from "../../../../game-model/gamesystems/ProductTransition";
|
||||
import {LeafGamesystemCalculator} from "../../product-gamesystem-editor/LeafGamesystemCalculator";
|
||||
|
||||
@Component({
|
||||
selector: 'app-simple-transition-editor',
|
||||
@ -44,6 +46,9 @@ export class SimpleTransitionEditorComponent implements OnInit {
|
||||
transitionEndingStateError = true;
|
||||
ngOnInit() {
|
||||
this.dataSource.data = this.gamesystem!.transitions;
|
||||
this.dataSource.filterPredicate = (data: SimpleTransition, filter: string) => {
|
||||
return [data.startingState, data.endingState].some((state) => state.stateLabel.toLowerCase().includes(filter))
|
||||
}
|
||||
}
|
||||
|
||||
addTransition() {
|
||||
@ -83,4 +88,9 @@ export class SimpleTransitionEditorComponent implements OnInit {
|
||||
this.dataSource.data = this.gamesystem!.transitions;
|
||||
}
|
||||
}
|
||||
|
||||
applyFilter(event: KeyboardEvent) {
|
||||
const filterValue = (event.target as HTMLInputElement).value;
|
||||
this.dataSource.filter = filterValue.trim().toLowerCase();
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user