Requires any of the roles: | bookingsupplier-administrator-write, superadmin |
PUT | /homepage/scheduler/settings | Update homepage scheduler settings | Update homepage scheduler settings on the company of the currently logged in user, only administrators are allowed to update homepage menu. |
---|
export class HomepageSchedulerServiceResponse
{
/** @description The service id. */
// @ApiMember(Description="The service id.")
public Id: number;
/** @description The service name. */
// @ApiMember(Description="The service name.")
public Name: string;
/** @description The service description. */
// @ApiMember(Description="The service description.")
public Description: string;
/** @description The service image url. */
// @ApiMember(Description="The service image url.")
public ImageUrl: string;
public constructor(init?: Partial<HomepageSchedulerServiceResponse>) { (Object as any).assign(this, init); }
}
export class HomepageSchedulerResourceResponse
{
/** @description The resource id. */
// @ApiMember(Description="The resource id.")
public Id: number;
/** @description The resource name. */
// @ApiMember(Description="The resource name.")
public Name: string;
/** @description The resource description. */
// @ApiMember(Description="The resource description.")
public Description: string;
/** @description The resource image url. */
// @ApiMember(Description="The resource image url.")
public ImageUrl: string;
public constructor(init?: Partial<HomepageSchedulerResourceResponse>) { (Object as any).assign(this, init); }
}
export class HomepageSchedulerFieldResponse
{
/** @description The field id. */
// @ApiMember(Description="The field id.")
public Id: number;
/** @description If the field should be shown on booking. */
// @ApiMember(Description="If the field should be shown on booking.")
public ShowOnBooking: boolean;
/** @description If the field should be shown on tooltip. */
// @ApiMember(Description="If the field should be shown on tooltip.")
public ShowOnTooltip: boolean;
public constructor(init?: Partial<HomepageSchedulerFieldResponse>) { (Object as any).assign(this, init); }
}
export class HomepageSchedulerFieldOptionsResponse
{
/** @description The field id. */
// @ApiMember(Description="The field id.")
public Id: number;
/** @description The field name. */
// @ApiMember(Description="The field name.")
public Name: string;
/** @description The field description. */
// @ApiMember(Description="The field description.")
public Description: string;
/** @description The field sort order when listing. */
// @ApiMember(Description="The field sort order when listing.")
public SortOrder: number;
public constructor(init?: Partial<HomepageSchedulerFieldOptionsResponse>) { (Object as any).assign(this, init); }
}
export class ScheduleViewResponse
{
public Id: number;
public Name: string;
public constructor(init?: Partial<ScheduleViewResponse>) { (Object as any).assign(this, init); }
}
export class HomepageSchedulerSettingsQueryResponse
{
/** @description The company id. */
// @ApiMember(Description="The company id.")
public CompanyId: string;
/** @description If the user schedule is activated. */
// @ApiMember(Description="If the user schedule is activated.")
public Active: boolean;
/** @description If the user schedule views id. */
// @ApiMember(Description="If the user schedule views id.")
public ScheduleViewId: number;
/** @description If the user schedule time slots in minutes. */
// @ApiMember(Description="If the user schedule time slots in minutes.")
public ScheduleTimeSlotMinutes: number;
/** @description If the user schedule time start time. */
// @ApiMember(Description="If the user schedule time start time.")
public StartTime?: string;
/** @description If the user schedule time end time. */
// @ApiMember(Description="If the user schedule time end time.")
public EndTime?: string;
/** @description If the user schedule should contain time exceptions. */
// @ApiMember(Description="If the user schedule should contain time exceptions.")
public ShowTimeExceptions: boolean;
/** @description If allow booking in the scheduler. */
// @ApiMember(Description="If allow booking in the scheduler.")
public EnableBooking: boolean;
/** @description The homepage schedule services that are selected */
// @ApiMember(Description="The homepage schedule services that are selected")
public Services: HomepageSchedulerServiceResponse[];
/** @description The homepage schedule resources that are selected */
// @ApiMember(Description="The homepage schedule resources that are selected")
public Resources: HomepageSchedulerResourceResponse[];
/** @description The homepage schedule fields that are selected */
// @ApiMember(Description="The homepage schedule fields that are selected")
public Fields: HomepageSchedulerFieldResponse[];
/** @description The homepage schedule fields select from */
// @ApiMember(Description="The homepage schedule fields select from")
public FieldOptions: HomepageSchedulerFieldOptionsResponse[];
/** @description The available schedule view options to choose from */
// @ApiMember(Description="The available schedule view options to choose from")
public ScheduleViewOptions: ScheduleViewResponse[];
public constructor(init?: Partial<HomepageSchedulerSettingsQueryResponse>) { (Object as any).assign(this, init); }
}
export class HomepageSchedulerResource
{
/** @description The resource id. */
// @ApiMember(Description="The resource id.")
public Id: number;
public constructor(init?: Partial<HomepageSchedulerResource>) { (Object as any).assign(this, init); }
}
export class HomepageSchedulerService
{
/** @description The service id. */
// @ApiMember(Description="The service id.")
public Id: number;
public constructor(init?: Partial<HomepageSchedulerService>) { (Object as any).assign(this, init); }
}
export class HomepageScheduleField
{
/** @description The field id. */
// @ApiMember(Description="The field id.", IsRequired=true)
public Id: number;
/** @description If the field showed on the booking. */
// @ApiMember(Description="If the field showed on the booking.", IsRequired=true)
public ShowOnBooking: boolean;
/** @description If the field showed on the bookings tooltip. */
// @ApiMember(Description="If the field showed on the bookings tooltip.", IsRequired=true)
public ShowOnTooltip: boolean;
public constructor(init?: Partial<HomepageScheduleField>) { (Object as any).assign(this, init); }
}
// @ValidateRequest(Validator="IsAuthenticated")
export class UpdateHomepageSchedulerSettings implements ICompany
{
/** @description The company id, if empty will use the company id for the user you are logged in with. */
// @ApiMember(Description="The company id, if empty will use the company id for the user you are logged in with.")
public CompanyId?: string;
/** @description If the user schedule is activated. */
// @ApiMember(Description="If the user schedule is activated.")
public Active?: boolean;
/** @description If the user schedule views id. */
// @ApiMember(Description="If the user schedule views id.")
public ScheduleViewId?: number;
/** @description If the user schedule time slots in minutes. */
// @ApiMember(Description="If the user schedule time slots in minutes.")
public ScheduleTimeSlotMinutes?: number;
/** @description If the user schedule time start time. */
// @ApiMember(Description="If the user schedule time start time.")
public StartTime?: string;
/** @description If the user schedule time end time. */
// @ApiMember(Description="If the user schedule time end time.")
public EndTime?: string;
/** @description If the user schedule should contain time exceptions. */
// @ApiMember(Description="If the user schedule should contain time exceptions.")
public ShowTimeExceptions?: boolean;
/** @description If allow booking in the scheduler. */
// @ApiMember(Description="If allow booking in the scheduler.")
public EnableBooking?: boolean;
/** @description What resources you want to be shown in scheduler. */
// @ApiMember(Description="What resources you want to be shown in scheduler.")
public Resources: HomepageSchedulerResource[];
/** @description What services you want to be shown in scheduler. */
// @ApiMember(Description="What services you want to be shown in scheduler.")
public Services: HomepageSchedulerService[];
/** @description What fields you want to be shown in scheduler. */
// @ApiMember(Description="What fields you want to be shown in scheduler.")
public Fields: HomepageScheduleField[];
public constructor(init?: Partial<UpdateHomepageSchedulerSettings>) { (Object as any).assign(this, init); }
}
TypeScript UpdateHomepageSchedulerSettings 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.
PUT /homepage/scheduler/settings HTTP/1.1
Host: api.bokamera.se
Accept: text/jsv
Content-Type: text/jsv
Content-Length: length
{
CompanyId: 00000000-0000-0000-0000-000000000000,
Active: False,
ScheduleViewId: 0,
ScheduleTimeSlotMinutes: 0,
StartTime: PT0S,
EndTime: PT0S,
ShowTimeExceptions: False,
EnableBooking: False,
Resources:
[
{
Id: 0
}
],
Services:
[
{
Id: 0
}
],
Fields:
[
{
Id: 0,
ShowOnBooking: False,
ShowOnTooltip: False
}
]
}
HTTP/1.1 200 OK Content-Type: text/jsv Content-Length: length { Active: False, ScheduleViewId: 0, ScheduleTimeSlotMinutes: 0, StartTime: PT0S, EndTime: PT0S, ShowTimeExceptions: False, EnableBooking: False, Services: [ { Id: 0, Name: String, Description: String } ], Resources: [ { Id: 0, Name: String, Description: String } ], Fields: [ { Id: 0, ShowOnBooking: False, ShowOnTooltip: False } ], FieldOptions: [ { Id: 0, Name: String, Description: String, SortOrder: 0 } ], ScheduleViewOptions: [ { Id: 0, Name: String } ] }