| Requires any of the roles: | bookingsupplier-administrator-write, superadmin |
| PUT | /homepage/widget/settings | Update homepage widget settings | Update homepage widget settings on the company of the currently logged in user, only administrators are allowed to update homepage menu. |
|---|
import Foundation
import ServiceStack
// @ValidateRequest(Validator="IsAuthenticated")
public class UpdateHomepageWidgetSettings : ICompany, Codable
{
/**
* 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 var companyId:String?
/**
* Serivce Layout.
*/
// @ApiMember(Description="Serivce Layout.")
public var serviceLayoutId:Int?
/**
* Time Layout.
*/
// @ApiMember(Description="Time Layout.")
public var timeLayoutId:Int?
/**
* Booking Layout.
*/
// @ApiMember(Description="Booking Layout.")
public var bookingLayoutId:Int?
/**
* The primary color of the booking widget.
*/
// @ApiMember(Description="The primary color of the booking widget.")
public var primaryColor:String
/**
* If the site should have dark theme or not.
*/
// @ApiMember(Description="If the site should have dark theme or not.")
public var darkTheme:Bool?
/**
* If you should show the service image in the booking widget.
*/
// @ApiMember(Description="If you should show the service image in the booking widget.")
public var showServiceImage:Bool?
/**
* If you should show the rebate code field in the booking widget.
*/
// @ApiMember(Description="If you should show the rebate code field in the booking widget.")
public var showRebateCodeField:Bool?
/**
* If you should show the next available time in the booking widget.
*/
// @ApiMember(Description="If you should show the next available time in the booking widget.")
public var showNextAvailableTime:Bool?
/**
* If you should show the end time in the booking widget.
*/
// @ApiMember(Description="If you should show the end time in the booking widget.")
public var showEndTime:Bool?
/**
* Show subscribe to newsletter checkbox on the page
*/
// @ApiMember(Description="Show subscribe to newsletter checkbox on the page")
public var showSubscribeToNewsletter:Bool?
/**
* What text to show on booked time slots. Default text is Booked
*/
// @ApiMember(Description="What text to show on booked time slots. Default text is Booked")
public var bookedTimeSlotText:String
/**
* If you should show the create account option.
*/
// @ApiMember(Description="If you should show the create account option.")
public var enableCreateAccount:Bool?
/**
* If you should show the login to account option.
*/
// @ApiMember(Description="If you should show the login to account option.")
public var enableLogin:Bool?
/**
* If you should show the facebook login to account option.
*/
// @ApiMember(Description="If you should show the facebook login to account option.")
public var enableFacebookLogin:Bool?
/**
* If you should show the direct booking option. This enables customer to book with entering contact information.
*/
// @ApiMember(Description="If you should show the direct booking option. This enables customer to book with entering contact information.")
public var enableDirectBooking:Bool?
required public init(){}
}
public class HomepageWidgetSettingsQueryResponse : Codable
{
/**
* The company id.
*/
// @ApiMember(Description="The company id.")
public var companyId:String
/**
* The service layouts id.
*/
// @ApiMember(Description="The service layouts id.")
public var serviceLayoutId:Int
/**
* The time layouts id.
*/
// @ApiMember(Description="The time layouts id.")
public var timeLayoutId:Int
/**
* The booking layouts id.
*/
// @ApiMember(Description="The booking layouts id.")
public var bookingLayoutId:Int
/**
* The primary color of the booking widget.
*/
// @ApiMember(Description="The primary color of the booking widget.")
public var primaryColor:String
/**
* If you should show the service image in the booking widget.
*/
// @ApiMember(Description="If you should show the service image in the booking widget.")
public var showServiceImage:Bool
/**
* If you should show the rebate code field in the booking widget.
*/
// @ApiMember(Description="If you should show the rebate code field in the booking widget.")
public var showRebateCodeField:Bool
/**
* If you should show the next available time in the booking widget.
*/
// @ApiMember(Description="If you should show the next available time in the booking widget.")
public var showNextAvailableTime:Bool
/**
* If you should show the subscribe to newsletter checkbox in the booking widget.
*/
// @ApiMember(Description="If you should show the subscribe to newsletter checkbox in the booking widget.")
public var showSubscribeToNewsletter:Bool
/**
* If you should show the create account option.
*/
// @ApiMember(Description="If you should show the create account option.")
public var enableCreateAccount:Bool
/**
* If you should show the login to account option.
*/
// @ApiMember(Description="If you should show the login to account option.")
public var enableLogin:Bool
/**
* If you should show the facebook login to account option.
*/
// @ApiMember(Description="If you should show the facebook login to account option.")
public var enableFacebookLogin:Bool
/**
* If you should show the direct booking option. This enables customer to book with entering contact information.
*/
// @ApiMember(Description="If you should show the direct booking option. This enables customer to book with entering contact information.")
public var enableDirectBooking:Bool
/**
* If the site should have dark theme or not.
*/
// @ApiMember(Description="If the site should have dark theme or not.")
public var darkTheme:Bool
/**
* If you should show the end time in the booking widget.
*/
// @ApiMember(Description="If you should show the end time in the booking widget.")
public var showEndTime:Bool
/**
* What text to show on booked time slots. Default text is Booked
*/
// @ApiMember(Description="What text to show on booked time slots. Default text is Booked")
public var bookedTimeSlotText:String
public var serviceLayoutOptions:[HomepageWidgetServiceLayoutsResponse] = []
public var timeLayoutOptions:[HomepageWidgetTimeLayoutsResponse] = []
public var bookingLayoutOptions:[HomepageWidgetBookingLayoutsResponse] = []
public var bookingMethodOptions:[HomepageWidgetBookingMethodsResponse] = []
required public init(){}
}
public class HomepageWidgetServiceLayoutsResponse : Codable
{
/**
* The layout id.
*/
// @ApiMember(Description="The layout id.")
public var id:Int
/**
* The layout name.
*/
// @ApiMember(Description="The layout name.")
public var name:String
/**
* The layout description.
*/
// @ApiMember(Description="The layout description.")
public var Description:String
/**
* The layout code.
*/
// @ApiMember(Description="The layout code.")
public var code:String
required public init(){}
}
public class HomepageWidgetTimeLayoutsResponse : Codable
{
/**
* The layout id.
*/
// @ApiMember(Description="The layout id.")
public var id:Int
/**
* The layout name.
*/
// @ApiMember(Description="The layout name.")
public var name:String
/**
* The layout description.
*/
// @ApiMember(Description="The layout description.")
public var Description:String
/**
* The layout code.
*/
// @ApiMember(Description="The layout code.")
public var code:String
required public init(){}
}
public class HomepageWidgetBookingLayoutsResponse : Codable
{
/**
* The layout id.
*/
// @ApiMember(Description="The layout id.")
public var id:Int
/**
* The layout name.
*/
// @ApiMember(Description="The layout name.")
public var name:String
/**
* The layout description.
*/
// @ApiMember(Description="The layout description.")
public var Description:String
/**
* The layout code.
*/
// @ApiMember(Description="The layout code.")
public var code:String
required public init(){}
}
public class HomepageWidgetBookingMethodsResponse : Codable
{
/**
* The layout id.
*/
// @ApiMember(Description="The layout id.")
public var id:Int
/**
* The layout name.
*/
// @ApiMember(Description="The layout name.")
public var name:String
/**
* The layout description.
*/
// @ApiMember(Description="The layout description.")
public var Description:String
/**
* The layout code.
*/
// @ApiMember(Description="The layout code.")
public var code:String
required public init(){}
}
Swift UpdateHomepageWidgetSettings 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/widget/settings HTTP/1.1
Host: api.bokamera.se
Accept: text/jsv
Content-Type: text/jsv
Content-Length: length
{
CompanyId: 00000000-0000-0000-0000-000000000000,
ServiceLayoutId: 0,
TimeLayoutId: 0,
BookingLayoutId: 0,
PrimaryColor: String,
DarkTheme: False,
ShowServiceImage: False,
ShowRebateCodeField: False,
ShowNextAvailableTime: False,
ShowEndTime: False,
ShowSubscribeToNewsletter: False,
BookedTimeSlotText: String,
EnableCreateAccount: False,
EnableLogin: False,
EnableFacebookLogin: False,
EnableDirectBooking: False
}
HTTP/1.1 200 OK
Content-Type: text/jsv
Content-Length: length
{
ServiceLayoutId: 0,
TimeLayoutId: 0,
BookingLayoutId: 0,
PrimaryColor: String,
ShowServiceImage: False,
ShowRebateCodeField: False,
ShowNextAvailableTime: False,
ShowSubscribeToNewsletter: False,
EnableCreateAccount: False,
EnableLogin: False,
EnableFacebookLogin: False,
EnableDirectBooking: False,
DarkTheme: False,
ShowEndTime: False,
BookedTimeSlotText: String,
ServiceLayoutOptions:
[
{
Id: 0,
Name: String,
Description: String,
Code: String
}
],
TimeLayoutOptions:
[
{
Id: 0,
Name: String,
Description: String,
Code: String
}
],
BookingLayoutOptions:
[
{
Id: 0,
Name: String,
Description: String,
Code: String
}
],
BookingMethodOptions:
[
{
Id: 0,
Name: String,
Description: String,
Code: String
}
]
}