Trendsic Platform Service

<back to all web services

RfpPricingRequest

Requires Authentication
Requires any of the roles:Agent, Administrator
The following routes are available for this service:
GET,OPTIONS/v1/Rfp/{RfpDocumentUID}/Pricing

export class CostRange
{
    public Min: number;
    public Max: number;
    public Mid: number;

    public constructor(init?: Partial<CostRange>) { (Object as any).assign(this, init); }
}

export class PricedPosition
{
    public PositionTag: string;
    public Hours: number;
    public HasInternalRate: boolean;
    public RateMin?: number;
    public RateMax?: number;
    public RateAvg?: number;
    public ContactCount: number;
    public Cost: CostRange;
    public MarketRateReference?: number;

    public constructor(init?: Partial<PricedPosition>) { (Object as any).assign(this, init); }
}

export class PricedEquipment
{
    public EquipmentID: number;
    public EquipmentName: string;
    public Quantity: number;
    public DurationDays?: number;
    public RateType: string;
    public BilledRate?: number;
    public CostRate?: number;
    public HasRate: boolean;
    public IsInCatalog: boolean;
    public Cost: number;
    public CompanyCost: number;
    public Margin: number;

    public constructor(init?: Partial<PricedEquipment>) { (Object as any).assign(this, init); }
}

export class PricedMaterial
{
    public MaterialID: number;
    public MaterialName: string;
    public Quantity: number;
    public UnitCost?: number;
    public HasRate: boolean;
    public IsInCatalog: boolean;
    public Cost: number;

    public constructor(init?: Partial<PricedMaterial>) { (Object as any).assign(this, init); }
}

export class PricedTask
{
    public Name: string;
    public Category: string;
    public Positions: PricedPosition[] = [];
    public Equipment: PricedEquipment[] = [];
    public Materials: PricedMaterial[] = [];
    public Subtotal: CostRange;

    public constructor(init?: Partial<PricedTask>) { (Object as any).assign(this, init); }
}

export class PricedProposal
{
    public RfpDocumentID: number;
    public ProjectName: string;
    public Currency: string;
    public Tasks: PricedTask[] = [];
    public Total: CostRange;
    public PositionsNeedingRate: number;
    public EquipmentNotInCatalog: number;
    public MaterialsNotInCatalog: number;
    public PositionsNotInCatalog: number;
    public EquipmentMargin: number;

    public constructor(init?: Partial<PricedProposal>) { (Object as any).assign(this, init); }
}

export class RfpPricingResponse
{
    public ResponseStatus: ResponseStatus;
    public RfpDocumentID: number;
    public Pricing: PricedProposal;

    public constructor(init?: Partial<RfpPricingResponse>) { (Object as any).assign(this, init); }
}

export class RfpPricingRequest
{
    public RfpDocumentUID: string;

    public constructor(init?: Partial<RfpPricingRequest>) { (Object as any).assign(this, init); }
}

TypeScript RfpPricingRequest 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.

GET /v1/Rfp/{RfpDocumentUID}/Pricing HTTP/1.1 
Host: api.dev.dynamics.trendsic.com 
Accept: text/jsv
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
		}
	},
	RfpDocumentID: 0,
	Pricing: 
	{
		RfpDocumentID: 0,
		ProjectName: String,
		Currency: String,
		Tasks: 
		[
			{
				Name: String,
				Category: String,
				Positions: 
				[
					{
						PositionTag: String,
						Hours: 0,
						HasInternalRate: False,
						RateMin: 0,
						RateMax: 0,
						RateAvg: 0,
						ContactCount: 0,
						Cost: 
						{
							Min: 0,
							Max: 0,
							Mid: 0
						},
						MarketRateReference: 0
					}
				],
				Equipment: 
				[
					{
						EquipmentID: 0,
						EquipmentName: String,
						Quantity: 0,
						DurationDays: 0,
						RateType: String,
						BilledRate: 0,
						CostRate: 0,
						HasRate: False,
						IsInCatalog: False,
						Cost: 0,
						CompanyCost: 0,
						Margin: 0
					}
				],
				Materials: 
				[
					{
						MaterialID: 0,
						MaterialName: String,
						Quantity: 0,
						UnitCost: 0,
						HasRate: False,
						IsInCatalog: False,
						Cost: 0
					}
				],
				Subtotal: 
				{
					Min: 0,
					Max: 0,
					Mid: 0
				}
			}
		],
		Total: 
		{
			Min: 0,
			Max: 0,
			Mid: 0
		},
		PositionsNeedingRate: 0,
		EquipmentNotInCatalog: 0,
		MaterialsNotInCatalog: 0,
		PositionsNotInCatalog: 0,
		EquipmentMargin: 0
	}
}