Trendsic Platform Service

<back to all web services

CreateQuoteRequest

Requires Authentication
The following routes are available for this service:
POST,OPTIONS/v1/quote
import java.math.*
import java.util.*
import java.io.InputStream
import net.servicestack.client.*


open class CreateQuoteRequest
{
    open var Quote:Quote? = null
}

open class Quote
{
    open var QuoteID:Int? = null
    open var QuoteUID:UUID? = null
    open var TenantId:UUID? = null
    open var BranchId:UUID? = null
    open var ProjectID:Int? = null
    open var ProjectUID:UUID? = null
    open var ProjectName:String? = null
    open var Name:String? = null
    open var Status:String? = null
    open var Total:BigDecimal? = null
    open var Notes:String? = null
    open var Currency:String? = null
    open var FromName:String? = null
    open var FromPhone:String? = null
    open var FromEmail:String? = null
    open var FromAddress:String? = null
    open var ToName:String? = null
    open var ToPhone:String? = null
    open var ToEmail:String? = null
    open var ToAddress:String? = null
    open var ExpiresAt:Date? = null
    open var IsLocked:Boolean? = null
    open var FinalPriceAfterCompletion:Boolean? = null
    open var ApprovedByName:String? = null
    open var ApprovedAt:Date? = null
    open var DeclinedByName:String? = null
    open var DeclinedAt:Date? = null
    open var DeclineReason:String? = null
    open var CreatedBy:String? = null
    open var CreatedAt:Date? = null
    open var UpdatedBy:String? = null
    open var UpdatedAt:Date? = null
    open var Items:ArrayList<QuoteItem> = ArrayList<QuoteItem>()
}

open class QuoteItem
{
    open var QuoteItemID:Int? = null
    open var QuoteID:Int? = null
    open var ItemType:String? = null
    open var SourceRefId:Int? = null
    open var JobID:Int? = null
    open var Name:String? = null
    open var Description:String? = null
    open var Quantity:BigDecimal? = null
    open var UnitPrice:BigDecimal? = null
    open var IsTaxable:Boolean? = null
    open var DisplayOrder:Int? = null
    open var IsDeleted:Boolean? = null
}

open class QuoteResponse
{
    open var ResponseStatus:ResponseStatus? = null
    open var Quote:Quote? = null
}

Kotlin CreateQuoteRequest DTOs

To override the Content-type in your clients, use the HTTP Accept Header, append the .jsv suffix or ?format=jsv

HTTP + JSV

The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.

POST /v1/quote HTTP/1.1 
Host: api.dev.dynamics.trendsic.com 
Accept: text/jsv
Content-Type: text/jsv
Content-Length: length

{
	Quote: 
	{
		QuoteID: 0,
		QuoteUID: 00000000000000000000000000000000,
		TenantId: 00000000000000000000000000000000,
		BranchId: 00000000000000000000000000000000,
		ProjectID: 0,
		ProjectUID: 00000000000000000000000000000000,
		ProjectName: String,
		Name: String,
		Status: String,
		Total: 0,
		Notes: String,
		Currency: String,
		FromName: String,
		FromPhone: String,
		FromEmail: String,
		FromAddress: String,
		ToName: String,
		ToPhone: String,
		ToEmail: String,
		ToAddress: String,
		ExpiresAt: 0001-01-01,
		IsLocked: False,
		FinalPriceAfterCompletion: False,
		ApprovedByName: String,
		ApprovedAt: 0001-01-01,
		DeclinedByName: String,
		DeclinedAt: 0001-01-01,
		DeclineReason: String,
		CreatedBy: String,
		CreatedAt: 0001-01-01,
		UpdatedBy: String,
		UpdatedAt: 0001-01-01,
		Items: 
		[
			{
				QuoteItemID: 0,
				QuoteID: 0,
				ItemType: String,
				SourceRefId: 0,
				JobID: 0,
				Name: String,
				Description: String,
				Quantity: 0,
				UnitPrice: 0,
				IsTaxable: False,
				DisplayOrder: 0,
				IsDeleted: False
			}
		]
	}
}
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
		}
	},
	Quote: 
	{
		QuoteID: 0,
		QuoteUID: 00000000000000000000000000000000,
		TenantId: 00000000000000000000000000000000,
		BranchId: 00000000000000000000000000000000,
		ProjectID: 0,
		ProjectUID: 00000000000000000000000000000000,
		ProjectName: String,
		Name: String,
		Status: String,
		Total: 0,
		Notes: String,
		Currency: String,
		FromName: String,
		FromPhone: String,
		FromEmail: String,
		FromAddress: String,
		ToName: String,
		ToPhone: String,
		ToEmail: String,
		ToAddress: String,
		ExpiresAt: 0001-01-01,
		IsLocked: False,
		FinalPriceAfterCompletion: False,
		ApprovedByName: String,
		ApprovedAt: 0001-01-01,
		DeclinedByName: String,
		DeclinedAt: 0001-01-01,
		DeclineReason: String,
		CreatedBy: String,
		CreatedAt: 0001-01-01,
		UpdatedBy: String,
		UpdatedAt: 0001-01-01,
		Items: 
		[
			{
				QuoteItemID: 0,
				QuoteID: 0,
				ItemType: String,
				SourceRefId: 0,
				JobID: 0,
				Name: String,
				Description: String,
				Quantity: 0,
				UnitPrice: 0,
				IsTaxable: False,
				DisplayOrder: 0,
				IsDeleted: False
			}
		]
	}
}