Как вставить данные с обещанием в Angular7, используя ng-crud-table - PullRequest
0 голосов
/ 22 апреля 2019

Я пытаюсь выполнить операцию Crud, используя ng-crud-table после демонстрационного проекта, но застрял на запросах POST, DELETE и PUT, как использовать их с сервисом, который предоставляется в примере кода. Я перехожу по ссылке для создания CRUD в Angular7, в служебном файле

 import {Injectable} from '@angular/core';
       import {HttpClient} from '@angular/common/http';
       import {DataSource, RequestMetadata, PagedResult} 
       from'../../lib/ngcrud- table';
       import {DataSort, DataFilter} from '../../lib/ng-data-table/base';
       import {arrayPaginate} from '../../lib/common/utils';

       @Injectable({
       providedIn: 'root'
       })
      export class DemoService implements DataSource {

     // url: string = 'assets/players.json';
        url:string = 'http://localhost:22387/api/Yarn/YarnColors';
    // url_create : string ='http://localhost:22387/api/Yarn/YarnColors';
    // primaryKeys: string[] = ['id'];
       primaryKeys: string[] = ['YarnColorID'];

      private dataFilter: DataFilter;
      private dataSort: DataSort;

     constructor(private http: HttpClient) {
     this.dataFilter = new DataFilter();
     this.dataSort = new DataSort();
    }

   getItems(requestMeta: RequestMetadata): Promise<PagedResult> {
   const page = requestMeta.pageMeta.currentPage;
   this.dataFilter.filters = requestMeta.filters;
   this.dataFilter.globalFilterValue = requestMeta.globalFilterValue;
   this.dataSort.sortMeta = requestMeta.sortMeta;
   const perPage = requestMeta.pageMeta.perPage;

    return this.http.get<PagedResult>(this.url)
   .toPromise()
   .then(function (res) {
    const rows: any[] = res || [];
    const filteredData = this.dataFilter.filterRows(rows);
    const sortedData = this.dataSort.sortRows(filteredData);
    const pageData = arrayPaginate(sortedData, page, perPage);
    const totalCount = sortedData.length;
    const pageCount = pageData.length;
    const result = <PagedResult>{
      'items': pageData,
      '_meta': {
        'totalCount': totalCount,
        'pageCount': pageCount,
        'currentPage': page,
        'perPage': perPage
      }
     };
    return result;
    }.bind(this))
    .catch(this.handleError);
   }

  getItem(row: any): Promise<any> {
  const filters = {};
  for (const key of this.primaryKeys) {
  filters[key] = {value: row[key]};
 }
 const requestMeta = <RequestMetadata> {
  pageMeta: {currentPage: 1},
  filters: filters,
 };
 return this.getItems(requestMeta)
  .then(data => data.items[0]);
 }

         post(item: any): Promise<any> {
        //this.url_create='http://localhost:22387/api/Yarn/CreateYarn';
        // this.data.items.push(item); // exist in component
        return new Promise((resolve) => {
          setTimeout(() => resolve(item), 250);
        });
         }

          put(item: any): Promise<any> {
        // this.data.items[this.findSelectedItemIndex(item)] = item; // exist in 
           component
        return new Promise((resolve) => {
          setTimeout(() => resolve(item), 250);
        });
        }

        delete(item: any): Promise<any> {
        // this.data.items.splice(this.findSelectedItemIndex(item), 1); // exist 
        in component
        return new Promise((resolve) => {
          setTimeout(() => resolve(item), 250);
        });
        }

        getOptions(url: string, parentId: any): Promise<any> {
        return this.http.get(url)
          .toPromise()
          .then((response: any) => {
            const result = response.filter((value: any) => {
              return value['parentId'] === parentId;
            });
            return new Promise((resolve) => {
              setTimeout(() => resolve(result), 1000);
            });
          })
          .catch(this.handleError);
        }

         private handleError(error: any) {
        let errorMessage = '';
        if (error.error instanceof ErrorEvent) {
          // client-side error
          errorMessage = `Error: ${error.error.message}`;
        } else {
          // server-side error
          errorMessage = `Error Code: ${error.status}\nMessage: ${error.message}`;
        }
        return Promise.reject(errorMessage);
        }

         }
     create the Table component
    ```Table.ts file
        import { Component, OnInit } from '@angular/core';
        import {HttpClient} from '@angular/common/http';
        import {Column, Settings} from '../../lib/ng-data-table';
        import {CdtSettings, DataTable, DataManager} from '../../lib/ng-crud- 
        table';
        import {DemoService} from '../demo/demo.service';
        import {getColumnsPlayers} from '../demo/columns';
        import {Yarncolorname} from '../yarncolorname';

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

      table: DataTable;
      columns: Column[];
      dataManager: DataManager;

      settings: Settings = <Settings>{
        virtualScroll: true,
        rowHeightProp: '$$height',
       };

       serverSideSettings: CdtSettings = <CdtSettings>{
        virtualScroll: true,
        crud:true,
       };

        constructor(private service: DemoService, private http: HttpClient) {
        this.columns = getColumnsPlayers();
        for (const column of this.columns) {
          column.editable = false;
        }
        this.table = new DataTable(this.columns, this.settings);
        this.dataManager = new DataManager(this.columns, this.serverSideSettings, 
        this.service);
        }
        ngOnInit() {
        this.table.events.onLoading(true);
        // this.http.get<any[]>('assets/players.json').subscribe(data => {
          this.http.get<any[]> 
         ('http://localhost:22387/api/Yarn/YarnColors').subscribe(data => {
          for (const row of data) {
            row.$$height = (row.exp > 1000000) ? 40 : 25;
          }
          this.table.rows = data;
          console.log(data);
          this.table.events.onLoading(false);
         });

         }
        // post(item: any): Promise<any> {
        //   



      //this.http.post<Promise<any>='http://localhost:22387/api/Yarn/CreateYarn';
      //   // this.data.items.push(item); // exist in component
      //   return new Promise((resolve) => {
      //     setTimeout(() => resolve(item), 250);
      //   });
       }

    ```Fetch Data from database using get request with service.ts file
         this.table.events.onLoading(true);
        // this.http.get<any[]>('assets/players.json').subscribe(data => {
          this.http.get<any[]> 
         ('http://localhost:22387/api/Yarn/YarnColors').subscribe(data => {
          for (const row of data) {
            row.$$height = (row.exp > 1000000) ? 40 : 25;
          }
          this.table.rows = data;
          console.log(data);
          this.table.events.onLoading(false);
          });
    ```
    But i havent any idea how can i utilize this other function POST,PUT DELETE 
    ``` 
         post(item: any): Promise<any> {
         //this.url_create='http://localhost:22387/api/Yarn/CreateYarn';
         // this.data.items.push(item); // exist in component
         return new Promise((resolve) => {
          setTimeout(() => resolve(item), 250);
         });
         }

         put(item: any): Promise<any> {
        // this.data.items[this.findSelectedItemIndex(item)] = item; // exist in 
         component
         return new Promise((resolve) => {
          setTimeout(() => resolve(item), 250);
          });
          }

         delete(item: any): Promise<any> {
        // this.data.items.splice(this.findSelectedItemIndex(item), 1); // exist 
          in component
          return new Promise((resolve) => {
          setTimeout(() => resolve(item), 250);
        });
         }

как использовать функции POST, DELETE и PUT, используя сервис, который я написал?

...