import 'rxjs/add/operator/map'; import { HttpClient, HttpHeaders } from '@angular/common/http'; import { Injectable } from '@angular/core'; import { HostConfiguration } from './../../app.constants'; import { BaseHttpService } from '../../utilities/cite-http-service-module/base-http.service'; import { Observable } from 'rxjs/Observable'; import { DataTableRequest } from '../../models/data-table/DataTableRequest'; import { DataTableData } from '../../models/data-table/DataTableData'; import { ProjectListingModel } from '../../models/projects/ProjectListingModel'; import { ProjectModel } from '../../models/projects/ProjectModel'; import { BaseHttpResponseModel } from '../../models/http/BaseHttpResponseModel'; @Injectable() export class ProjectService { private actionUrl: string; private headers: HttpHeaders; constructor(private http: BaseHttpService) { this.actionUrl = HostConfiguration.Server + 'projects/'; this.headers = new HttpHeaders(); this.headers = this.headers.set('Content-Type', 'application/json'); this.headers = this.headers.set('Accept', 'application/json'); } getPaged(dataTableRequest: DataTableRequest): Observable> { return this.http.post>>(this.actionUrl + 'getPaged', dataTableRequest, { headers: this.headers }) .map(item => this.http.handleResponse>(item)); } getSingle(id: string): Observable { return this.http.get>(this.actionUrl + 'getSingle/' + id, { headers: this.headers }) .map(item => this.http.handleResponse(item)); } createProject(projectModel: ProjectModel): Observable { return this.http.post>(this.actionUrl + 'createOrUpdate', projectModel, { headers: this.headers }) .map(item => this.http.handleResponse(item));; } }