id="insertFood"
[disabled]="edit || !disableByInsertMode()"
(click)="insertFoodAfter()">Einfügen</button>
- <button class="button"
- type="button"
- id="editFood"
- [disabled]="!edit || disableByInsertMode()"
- (click)="saveFood()">Speichern</button>
</form>
<div *ngFor="let title of foodcard.Titles; let i = index">
(click)="addNewFood(title, i)">Speise hinzufügen</button>
<div *ngFor="let food of subtitle.Foods; let i = index"
class="foodmenu grid">
- <div class="food">{{food.Food}}</div>
- <div class="sideDish">{{food.sideDish}}</div>
- <div class="price">{{food.price}}</div>
- <button class="button"
- type="button"
- (click)="editFood(food)">Bearbeiten</button>
+ <app-food [food]="food"></app-food>
<button class="button"
type="button"
(click)="insertFood(title, subtitle, food)">Einfügen</button>
this.formFoodVisible = false;
}
- public saveFood(): void
- {
- this.food = { Food: "", sideDish: "", price: "" };
- this.formFoodVisible = false;
- this.edit = false;
- }
-
- public editFood(food: IFood): void
- {
- this.formFoodVisible = true;
- this.food = food;
- this.edit = true;
- }
-
public insertFoodAfter(): void
{
let title = this.foodcard.Titles[this.insertIndicies[0]];
import { HttpClientModule } from '@angular/common/http';
import { AppComponent } from './app.component';
+import { FoodComponent } from './food/food.component';
@NgModule({
declarations: [
- AppComponent
+ AppComponent,
+ FoodComponent
],
imports: [
BrowserModule,
--- /dev/null
+<div class="food">{{food.Food}}</div>
+<div class="sideDish">{{food.sideDish}}</div>
+<div class="price">{{food.price}}</div>
+<button class="button"
+ type="button"
+ (click)="editFood()">Bearbeiten</button>
+
+<form #formFood="ngForm" *ngIf="formFoodVisible" class="form">
+ <label>Speise</label>
+ <input [(ngModel)]="food.Food" name="food" type="text" />
+ <label>Beilage</label>
+ <input [(ngModel)]="food.sideDish" name="sideDish" type="text" />
+ <label>Preis</label>
+ <input [(ngModel)]="food.price" name="price" type="text" />
+ <button class="button"
+ type="button"
+ id="editFood"
+ (click)="saveFood()">Speichern</button>
+</form>
--- /dev/null
+import { ComponentFixture, TestBed } from '@angular/core/testing';
+
+import { FoodComponent } from './food.component';
+
+describe('FoodComponent', () => {
+ let component: FoodComponent;
+ let fixture: ComponentFixture<FoodComponent>;
+
+ beforeEach(async () => {
+ await TestBed.configureTestingModule({
+ declarations: [ FoodComponent ]
+ })
+ .compileComponents();
+ });
+
+ beforeEach(() => {
+ fixture = TestBed.createComponent(FoodComponent);
+ component = fixture.componentInstance;
+ fixture.detectChanges();
+ });
+
+ it('should create', () => {
+ expect(component).toBeTruthy();
+ });
+});
--- /dev/null
+import { Component, Input } from '@angular/core';
+import { IFood } from '../ifood';
+
+@Component({
+ selector: 'app-food',
+ templateUrl: './food.component.html',
+ styleUrls: ['./food.component.css']
+})
+export class FoodComponent
+{
+ @Input() food: IFood = { Food: "", sideDish: "", price: "" };
+ public formFoodVisible: boolean = false;
+
+ constructor() {}
+
+ public editFood(): void
+ {
+ this.formFoodVisible = true;
+ }
+
+ public saveFood(): void
+ {
+ this.formFoodVisible = false;
+ }
+}