| GET,OPTIONS | /v1/Scheduler/{SchedulerUrl} | ||
|---|---|---|---|
| GET,OPTIONS | /v1/Scheduler/{SchedulerUrl}/{StartDate} | ||
| GET,OPTIONS | /v1/Scheduler/{SchedulerUrl}/{StartDate}/{LocalDate} | ||
| GET,OPTIONS | /v1/SchedulerServices/{SchedulerUrl}/{StartDate}/{ServiceIdsList} |
export class SchedulerRequest
{
public SchedulerUrl: string;
public StartDate: string;
public Session: string[] = [];
public ServiceIdsList: string;
public constructor(init?: Partial<SchedulerRequest>) { (Object as any).assign(this, init); }
}
export class ScheduleConfigTimeBlock
{
public StartTime: string;
public DayStartFriendly: string;
public EndTime: string;
public DayEndFriendly: string;
public constructor(init?: Partial<ScheduleConfigTimeBlock>) { (Object as any).assign(this, init); }
}
export class ScheduleConfigDay
{
public DayName: string;
public DayNumber?: number;
public DayEnabled?: boolean;
public TimeBlocks: ScheduleConfigTimeBlock[] = [];
public constructor(init?: Partial<ScheduleConfigDay>) { (Object as any).assign(this, init); }
}
export class LineImage
{
public ImageId?: string;
public FileName: string;
public ImageTitle: string;
public UploadDate: string;
public constructor(init?: Partial<LineImage>) { (Object as any).assign(this, init); }
}
export class Line
{
public Id: string;
public LocationId: string;
public LocationName: string;
public Name: string;
public Description: string;
public ServiceDurationMinutes: number;
public WaitTime: number;
public Cost: number;
public UpperThreshold?: number;
public LowerThreshold?: number;
public Active: boolean;
public EntDate?: string;
public ModDate?: string;
public SendQuestionnaire: boolean;
public RequireUpload: boolean;
public UploadMessage: string;
public LineImages: LineImage[] = [];
public constructor(init?: Partial<Line>) { (Object as any).assign(this, init); }
}
export class SchedulerConfiguration
{
public ConfigId: number;
public SchedulerUrl: string;
public SchedulerName: string;
public DefaultLocation: string;
public DefaultSummary: string;
public DefaultDescription: string;
public DayStart: string;
public DayStartFriendly: string;
public DayEnd: string;
public DayEndFriendly: string;
public TimeslotDuration: number;
public NumberOfSlots?: number;
public LocationId: string;
public CalendarId: string;
public AgentId: number;
public TimeZone: string;
public AvailableDateTimes: ScheduleConfigDay[] = [];
public AvailableServices: string[] = [];
public AllServices: Line[] = [];
public constructor(init?: Partial<SchedulerConfiguration>) { (Object as any).assign(this, init); }
}
export class Contact
{
public ContactId: number;
public ContactType: number;
public FirstName: string;
public LastName: string;
public Name: string;
public Role: string;
public Title: string;
public EmailWork: string;
public EmailPersonal: string;
public District: string;
public DistrictID: number;
public School: string;
public SchoolID: number;
public State: string;
public StateName: string;
public StateID: number;
public CountyID: number;
public County: string;
public Phone: string;
public Department: string;
public Flow: string;
public LastContact: string;
public DoNotContact: boolean;
public Active: boolean;
public AgentId: number;
public PhoneAlt: string;
public PeraContactId: number;
public RoomNumber: string;
public SourceTypeId: number;
public SourceTypeDesc: string;
public SourceNote: string;
public ContactStatusId: number;
public ContactStatusDesc: string;
public SSN: string;
public DateOfBirth: string;
public Deleted: boolean;
public IsShared: boolean;
public address_line1: string;
public address_city: string;
public address_state: string;
public address_zip: string;
public DeletedBy: string;
public DeletedDateTimeUtc?: string;
public HasNBC: boolean;
public HasFactFinderSheet: boolean;
public MiddleInitial: string;
public Tags: string;
public DateCreated: string;
public PhoneLabel: string;
public AltPhoneLabel: string;
public Carriers: string;
public ContactImage: string;
public CompanyAffiliation: string;
public AdditionalInformation: string;
public HasGiftCard: boolean;
public ContactCategory: number;
public WritingAgentId: number;
public WritingAgentName: string;
public MaritalStatus: string;
public TotalDebtAmount: number;
public NumberOfDebtAccounts: number;
public FactFinderCodeId: number;
public BusinessName: string;
public DBA: string;
public ContactGUID: string;
public ProjectEndDate: string;
public Rate: number;
public JobID: number;
public JobName: string;
public JobCount: number;
public Locked: boolean;
public LockedByAgentId: number;
public LockedTimestamp: string;
public Initials: string;
public ContactCategoryName: string;
public SMSOptIn: boolean;
public constructor(init?: Partial<Contact>) { (Object as any).assign(this, init); }
}
export class SchedulerTimeslot
{
public Day: string;
public Time: string;
public Duration: number;
public StartDateTime: string;
public EndDateTime: string;
public TimeFriendly: string;
public Contact: Contact;
public ServiceIds: string[] = [];
public LocationId: string;
public Unavailable: boolean;
public BookedIds: number[] = [];
public CalendarId: string;
public SchedulerUrl: string;
public constructor(init?: Partial<SchedulerTimeslot>) { (Object as any).assign(this, init); }
}
export class SchedulerDay
{
public Day: string;
public MonthNumber: number;
public DayNumber: number;
public DayOfWeek: string;
public Timeslots: SchedulerTimeslot[] = [];
public constructor(init?: Partial<SchedulerDay>) { (Object as any).assign(this, init); }
}
export class SchedulerWeek
{
public Settings: SchedulerConfiguration;
public Days: SchedulerDay[] = [];
public constructor(init?: Partial<SchedulerWeek>) { (Object as any).assign(this, init); }
}
export class SchedulerResponse
{
public ResponseStatus: ResponseStatus;
public Week: SchedulerWeek;
public Services: Line[] = [];
public constructor(init?: Partial<SchedulerResponse>) { (Object as any).assign(this, init); }
}
TypeScript SchedulerRequest 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.
GET /v1/Scheduler/{SchedulerUrl} 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
}
},
Week:
{
Settings:
{
ConfigId: 0,
SchedulerUrl: String,
SchedulerName: String,
DefaultLocation: String,
DefaultSummary: String,
DefaultDescription: String,
DayStart: PT0S,
DayStartFriendly: "00:00",
DayEnd: PT0S,
DayEndFriendly: "00:00",
TimeslotDuration: 0,
NumberOfSlots: 0,
LocationId: 00000000000000000000000000000000,
CalendarId: 00000000000000000000000000000000,
AgentId: 0,
TimeZone: String,
AvailableDateTimes:
[
{
DayName: String,
DayNumber: 0,
DayEnabled: False,
TimeBlocks:
[
{
StartTime: PT0S,
DayStartFriendly: "00:00",
EndTime: PT0S,
DayEndFriendly: "00:00"
}
]
}
],
AvailableServices:
[
00000000000000000000000000000000
],
AllServices:
[
{
Id: 00000000000000000000000000000000,
LocationId: 00000000000000000000000000000000,
LocationName: String,
Name: String,
Description: String,
ServiceDurationMinutes: 0,
WaitTime: 0,
Cost: 0,
UpperThreshold: 0,
LowerThreshold: 0,
Active: False,
EntDate: 0001-01-01,
ModDate: 0001-01-01,
SendQuestionnaire: False,
RequireUpload: False,
UploadMessage: String,
LineImages:
[
{
ImageId: 00000000000000000000000000000000,
FileName: String,
ImageTitle: String,
UploadDate: 0001-01-01
}
]
}
]
},
Days:
[
{
}
]
},
Services:
[
{
Id: 00000000000000000000000000000000,
LocationId: 00000000000000000000000000000000,
LocationName: String,
Name: String,
Description: String,
ServiceDurationMinutes: 0,
WaitTime: 0,
Cost: 0,
UpperThreshold: 0,
LowerThreshold: 0,
Active: False,
EntDate: 0001-01-01,
ModDate: 0001-01-01,
SendQuestionnaire: False,
RequireUpload: False,
UploadMessage: String,
LineImages:
[
{
ImageId: 00000000000000000000000000000000,
FileName: String,
ImageTitle: String,
UploadDate: 0001-01-01
}
]
}
]
}