36 lines
1.0 KiB
TypeScript
36 lines
1.0 KiB
TypeScript
import { CommonModule } from '@angular/common';
|
|
import { Component, Input } from '@angular/core';
|
|
|
|
import { MissionSnapshot } from '@fog-explorer/api-interfaces';
|
|
|
|
@Component({
|
|
selector: 'fog-survivor-status',
|
|
standalone: true,
|
|
imports: [CommonModule],
|
|
template: `
|
|
<section class="panel-card">
|
|
<h3>Survivor Status</h3>
|
|
<ng-container *ngIf="mission; else idle">
|
|
<p>Mission: {{ mission.id }}</p>
|
|
<p>State: {{ mission.state }}</p>
|
|
<p>Health: {{ mission.stats.health }}</p>
|
|
<p>Stealth: {{ mission.stats.stealth }}</p>
|
|
<p>Teamwork: {{ mission.stats.teamwork }}</p>
|
|
<p>Luck: {{ mission.stats.luck }}</p>
|
|
</ng-container>
|
|
<ng-template #idle>
|
|
<p>No active mission.</p>
|
|
</ng-template>
|
|
</section>
|
|
`,
|
|
styles: [
|
|
`
|
|
.panel-card { padding: 0.75rem; background: #1a1e2a; border-radius: 8px; }
|
|
p { margin: 0 0 0.25rem; font-size: 0.9rem; }
|
|
`
|
|
]
|
|
})
|
|
export class SurvivorStatusComponent {
|
|
@Input() mission: MissionSnapshot | null = null;
|
|
}
|