| GET,POST,PUT,DELETE,OPTIONS | /v1/Project/Invoice/{ProjectID}/{InvoiceStartDate}/{InvoiceEndDate} |
|---|
"use strict";
export class ProjectInvoice {
/** @param {{CostType?:string,CostName?:string,CostToDate?:number,JobID?:number,Rate?:number,Hours?:number}} [init] */
constructor(init) { Object.assign(this, init) }
/** @type {string} */
CostType;
/** @type {string} */
CostName;
/** @type {number} */
CostToDate;
/** @type {number} */
JobID;
/** @type {number} */
Rate;
/** @type {number} */
Hours;
}
export class ProjectInvoiceResponse {
/** @param {{ResponseStatus?:ResponseStatus,ProjectInvoice?:ProjectInvoice[]}} [init] */
constructor(init) { Object.assign(this, init) }
/** @type {ResponseStatus} */
ResponseStatus;
/** @type {ProjectInvoice[]} */
ProjectInvoice = [];
}
export class ProjectInvoiceRequest {
/** @param {{ProjectID?:number,InvoiceStartDate?:string,InvoiceEndDate?:string}} [init] */
constructor(init) { Object.assign(this, init) }
/** @type {number} */
ProjectID;
/** @type {string} */
InvoiceStartDate;
/** @type {string} */
InvoiceEndDate;
}
JavaScript ProjectInvoiceRequest DTOs
To override the Content-type in your clients, use the HTTP Accept Header, append the .jsv suffix or ?format=jsv
The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.
POST /v1/Project/Invoice/{ProjectID}/{InvoiceStartDate}/{InvoiceEndDate} HTTP/1.1
Host: api.dynamics.trendsic.com
Accept: text/jsv
Content-Type: text/jsv
Content-Length: length
{
ProjectID: 0,
InvoiceStartDate: 0001-01-01,
InvoiceEndDate: 0001-01-01
}
HTTP/1.1 200 OK
Content-Type: text/jsv
Content-Length: length
{
ResponseStatus:
{
ErrorCode: String,
Message: String,
StackTrace: String,
Errors:
[
{
ErrorCode: String,
FieldName: String,
Message: String,
Meta:
{
String: String
}
}
],
Meta:
{
String: String
}
},
ProjectInvoice:
[
{
CostType: String,
CostName: String,
CostToDate: 0,
JobID: 0,
Rate: 0,
Hours: 0
}
]
}