Передача данных в угловой материал для редактирования - PullRequest
0 голосов
/ 05 февраля 2019

Для моего приложения todo я не хочу редактировать существующие задачи.Для этого я создал диалоговое окно материала и также могу передать существующие данные в диалоговое окно, которое будет использоваться в качестве заполнителя.Моя проблема состоит в том, чтобы передать отредактированные данные обратно на сервер.

Диалог редактирования HTML:

<h1 mat-dialog-title>Edit Todo</h1>

<div mat-dialog-content>
    <mat-form-field>
        <input matInput type="text" placeholder="{{data.todoUpdate.taskName}}" [(ngModel)]="toDoData.taskName" required>
    </mat-form-field>


    <mat-form-field>
        <input matInput type="date" placeholder="{{data.todoUpdate.dueDate}}" [(ngModel)]="toDoData.dueDate" required>
    </mat-form-field>
</div>

<div>
    <mat-form-field class="full-width">
        <input matInput type="text" placeholder="{{data.todoUpdate.extraNote}}" [(ngModel)]="toDoData.extraNote">
    </mat-form-field>
</div>

<div mat-dialog-actions>
    <button mat-button>Cancel</button>
    <button mat-button (click)="updateToDo(data.toDoData.extra, data.toDoData)">Update</button>
</div>

Диалог редактирования TS:

import {Component, Inject, Input, OnInit} from '@angular/core';
import {MAT_DIALOG_DATA, MatDialogRef} from '@angular/material';
import {TodoService} from '../shared/todo.service';

@Component({
    selector: 'app-edit-to-do-dialog',
    templateUrl: './edit-to-do-dialog.component.html',
    styleUrls: ['./edit-to-do-dialog.component.css']
})
export class EditToDoDialogComponent implements OnInit {

    @Input() toDoData = {taskName: '', extraNote: '', taskCompleted: false, dueDate: Date};

    constructor(
        public dialogRef: MatDialogRef<EditToDoDialogComponent>,
        @Inject(MAT_DIALOG_DATA) public data: any, private todoService: TodoService) {
    }




    ngOnInit() {
    }

    updateToDo(id, todo) {
        this.dialogRef.close();
        this.toDoData.taskName = this.data.taskName;
        this.toDoData.extraNote = this.data.extraNote;
        this.toDoData.dueDate = this.data.dueData;


        console.log(id);
        console.log(todo);

        this.todoService.updateToDo(id, todo).subscribe((res) => {

        }, (err) => {
            console.log(err);
        });
    }
}

Элемент todo, которыйдолжен быть отредактирован происходит от todo-list-component.Надеюсь, этот код поможет понять, каков был мой план.HTML:

import {Component, Inject, Input, OnInit} from '@angular/core';
import {MAT_DIALOG_DATA, MatDialogRef} from '@angular/material';
import {TodoService} from '../shared/todo.service';

@Component({
    selector: 'app-edit-to-do-dialog',
    templateUrl: './edit-to-do-dialog.component.html',
    styleUrls: ['./edit-to-do-dialog.component.css']
})
export class EditToDoDialogComponent implements OnInit {

    @Input() toDoData = {taskName: '', extraNote: '', taskCompleted: false, dueDate: Date};

    constructor(
        public dialogRef: MatDialogRef<EditToDoDialogComponent>,
        @Inject(MAT_DIALOG_DATA) public data: any, private todoService: TodoService) {
    }




    ngOnInit() {
    }

    updateToDo(id, todo) {
        this.dialogRef.close();
        this.toDoData.taskName = this.data.taskName;
        this.toDoData.extraNote = this.data.extraNote;
        this.toDoData.dueDate = this.data.dueData;


        console.log(id);
        console.log(todo);

        this.todoService.updateToDo(id, todo).subscribe((res) => {

        }, (err) => {
            console.log(err);
        });
    }
}

TS:

import {Component, Input, OnInit} from '@angular/core';
import {TodoService} from '../shared/todo.service';
import {MatDialog} from '@angular/material';
import {EditToDoDialogComponent} from '../edit-to-do-dialog/edit-to-do-dialog.component';

@Component({
    selector: 'app-todo-list',
    templateUrl: './todo-list.component.html',
    styleUrls: ['./todo-list.component.css']
})
export class TodoListComponent implements OnInit {

    todoList: Array<any>;

    constructor(private todoService: TodoService, private dialog: MatDialog) {
    }

    @Input() toDoData = {taskName: '', taskCompleted: false, date: Date};


    ngOnInit() {
        this.getToDos();
    }

    getToDos() {
        this.todoList = [];
        this.todoService.getToDos().subscribe((data: []) => {
            console.log(data);
            this.todoList = data;
        });
    }

    delete(id) {
        this.todoService.deleteToDo(id)
            .subscribe(res => {
                    this.getToDos();
                }, (err) => {
                    console.log(err);
                }
            );
    }

    completed(id, todo) {
        todo.taskCompleted = !todo.taskCompleted;
        this.todoService.updateToDo(id, todo)
            .subscribe(res => {
                this.getToDos();
            }, (err) => {
                console.log(err);
            });
    }

    openDialog(todo): void {
        const dialogRef = this.dialog.open(EditToDoDialogComponent, {
            data: {
                todoUpdate: todo,
            }
        });

        dialogRef.afterClosed().subscribe(result => {
            console.log('The dialog was closed');
        });
    }
}

И, наконец, служба, которая подключается к моему бэкэнду:

import {Injectable} from '@angular/core';
import {HttpClient, HttpHeaders} from '@angular/common/http';
import {Observable, of} from 'rxjs';
import {map, catchError, tap} from 'rxjs/operators';

@Injectable({providedIn: 'root'})
export class TodoService {
    public API = 'http://localhost:8080/';

    httpOptions = {
        headers: new HttpHeaders({
            'Content-Type': 'application/json'
        })
    };


    constructor(private http: HttpClient) {
    }

    private extractData(res: Response) {
        const body = res;
        return body || {};
    }

    getToDos(): Observable<any> {
        return this.http.get(this.API + 'todos').pipe(
            map(this.extractData));
    }

    getToDo(id): Observable<any> {
        return this.http.get(this.API + 'todos/' + id).pipe(
            map(this.extractData));
    }

    addToDo(todo): Observable<any> {
        return this.http.post<any>(this.API + 'todos', JSON.stringify(todo), this.httpOptions).pipe(
            tap((todo) => console.log(`added todo w/ id=${todo.id}`)),
            catchError(this.handleError<any>('addTodo'))
        );
    }

    updateToDo(id, todo): Observable<any> {
        return this.http.put(this.API + 'todos/' + id, JSON.stringify(todo), this.httpOptions).pipe(
            tap(_ => console.log(`updated todo id=${id}`)),
            catchError(this.handleError<any>('updateTodo'))
        );
    }

    deleteToDo(id): Observable<any> {
        return this.http.delete<any>(this.API + 'todos/' + id, this.httpOptions).pipe(
            tap(_ => console.log(`deleted todo id=${id}`)),
            catchError(this.handleError<any>('deleteToDo'))
        );
    }

    private handleError<T>(operation = 'operation', result?: T) {
        return (error: any): Observable<T> => {
            // TODO: send the error to remote logging infrastructure
            console.error(error); // log to console instead
            // TODO: better job of transforming error for user consumption
            console.log(`${operation} failed: ${error.message}`);
            // Let the app keep running by returning an empty result.
            return of(result as T);
        };
    }
}

Возможно, я неправильно понял, как мне поступитьОбновление заданий ...

Спасибо за любую помощь!

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...