2023-09-29 21:01:11 +03:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								---
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								title: Custom API
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								description: Custom Widget Configuration from the API
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								---
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								This widget can show information from custom self-hosted or third party API.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Fields need to be defined in the `mappings`  section YAML object to correlate with the value in the APIs JSON object. Final field definition needs to be the key with the desired value information.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```yaml
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								widget:
							 
						 
					
						
							
								
									
										
										
										
											2023-10-17 23:26:55 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  type: customapi
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  url: http://custom.api.host.or.ip:port/path/to/exact/api/endpoint
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  refreshInterval: 10000 # optional - in milliseconds, defaults to 10s
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  username: username # auth - optional
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  password: password # auth - optional
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  method: GET # optional, e.g. POST
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  headers: # optional, must be object, see below
							 
						 
					
						
							
								
									
										
										
										
											2024-02-16 22:25:31 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  requestBody: # optional, can be string or object, see below
							 
						 
					
						
							
								
									
										
										
										
											2024-02-15 07:18:37 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  display: # optional, default to block, see below
							 
						 
					
						
							
								
									
										
										
										
											2023-10-17 23:26:55 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  mappings:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -  field: key # needs to be YAML string or object
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      label: Field 1
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      format: text # optional - defaults to text
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -  field: # needs to be YAML string or object
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        path:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          to: key2
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      format: number # optional - defaults to text
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      label: Field 2
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -  field: # needs to be YAML string or object
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        path:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          to:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            another: key3
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      label: Field 3
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      format: percent # optional - defaults to text
							 
						 
					
						
							
								
									
										
										
										
											2023-10-24 02:54:04 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    -  field: key # needs to be YAML string or object
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      label: Field 4
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      format: date # optional - defaults to text
							 
						 
					
						
							
								
									
										
										
										
											2024-01-17 18:23:11 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      locale: nl # optional
							 
						 
					
						
							
								
									
										
										
										
											2023-10-24 02:54:04 +03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      dateStyle: long # optional - defaults to "long". Allowed values: `["full", "long", "medium", "short"]` .
							 
						 
					
						
							
								
									
										
										
										
											2023-11-09 21:57:14 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      timeStyle: medium # optional - Allowed values: `["full", "long", "medium", "short"]` .
							 
						 
					
						
							
								
									
										
										
										
											2024-01-17 18:23:11 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    -  field: key # needs to be YAML string or object
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      label: Field 5
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      format: relativeDate # optional - defaults to text
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      locale: nl # optional
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      style: short # optional - defaults to "long". Allowed values: `["long", "short", "narrow"]` .
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      numeric: auto # optional - defaults to "always". Allowed values `["always", "auto"]` .
							 
						 
					
						
							
								
									
										
										
										
											2024-02-15 07:18:37 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    -  field: key
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      label: Field 6
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      format: text
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      additionalField: # optional
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        field:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          hourly:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            time: other key
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        color: theme # optional - defaults to "". Allowed values: `["theme", "adaptive", "black", "white"]` .
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        format: date # optional
							 
						 
					
						
							
								
									
										
										
										
											2024-08-27 16:05:23 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    -  field: key
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      label: Number of things in array
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      format: size
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # This (no field) will take the root of the API response, e.g. when APIs return an array:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -  label: Number of items
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      format: size
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 21:01:11 +03:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-08-27 16:05:23 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Supported formats for the values are `text` , `number` , `float` , `percent` , `bytes` , `bitrate` , `size` , `date`  and `relativeDate` .
							 
						 
					
						
							
								
									
										
										
										
											2024-01-17 18:23:11 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								The `dateStyle`  and `timeStyle`  options of the `date`  format are passed directly to [Intl.DateTimeFormat ](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Intl/DateTimeFormat/DateTimeFormat ) and the `style`  and `numeric`  options of `relativeDate`  are passed to [Intl.RelativeTimeFormat ](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Intl/RelativeTimeFormat/RelativeTimeFormat ).
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 21:01:11 +03:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-08-27 16:05:23 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								The `size`  format will return the length of the array or string, or the number of keys in an object. This is then formatted as `number` .
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 21:01:11 +03:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								## Example
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								For the following JSON object from the API:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```json
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{
							 
						 
					
						
							
								
									
										
										
										
											2023-10-17 23:26:55 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  "id": 1,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  "name": "Rick Sanchez",
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  "status": "Alive",
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  "species": "Human",
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  "gender": "Male",
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  "origin": {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    "name": "Earth (C-137)"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  },
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  "locations": [
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      "name": "Earth (C-137)"
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 21:01:11 +03:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    },
							 
						 
					
						
							
								
									
										
										
										
											2023-10-17 23:26:55 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      "name": "Citadel of Ricks"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  ]
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 21:01:11 +03:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-10-22 00:12:37 +05:30 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Define the `mappings`  section as an array, for example:
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 21:01:11 +03:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```yaml
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								mappings:
							 
						 
					
						
							
								
									
										
										
										
											2023-10-17 23:26:55 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  -  field: name # Rick Sanchez
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    label: Name
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  -  field: status # Alive
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    label: Status
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  -  field:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      origin: name # Earth (C-137)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    label: Origin
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  -  field:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      locations:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        1: name # Citadel of Ricks
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    label: Location
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 21:01:11 +03:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								## Data Transformation
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-02-15 07:18:37 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								You can manipulate data with the following tools `remap` , `scale` , `prefix`  and `suffix` , for example:
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 21:01:11 +03:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```yaml
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  field: key4 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  label: Field 4
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  format: text
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  remap:
							 
						 
					
						
							
								
									
										
										
										
											2023-10-17 23:26:55 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    -  value: 0
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      to: None
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -  value: 1
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      to: Connected
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -  any: true # will map all other values
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      to: Unknown
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 21:01:11 +03:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								-  field: key5 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  label: Power
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  format: float
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  scale: 0.001 # can be number or string e.g. 1/16
							 
						 
					
						
							
								
									
										
										
										
											2024-02-15 07:18:37 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  suffix: "kW"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  field: key6 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  label: Price
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  format: float
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  prefix: "$"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								## List View
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								You can change the default block view to a list view by setting the `display`  option to `list` .
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								The list view can optionally display an additional field next to the primary field.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								`additionalField` : Similar to `field` , but only used in list view. Displays additional information for the mapping object on the right. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								`field` : Defined the same way as other custom api widget fields. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								`color` : Allowed options: `"theme", "adaptive", "black", "white"` . The option `adaptive`  will apply a color using the value of the `additionalField` , green for positive numbers, red for negative numbers. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```yaml
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  field: key 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  label: Field
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  format: text
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  remap:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -  value: 0
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      to: None
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -  value: 1
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      to: Connected
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    -  any: true # will map all other values
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      to: Unknown
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  additionalField:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    field:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      hourly:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        time: key
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    color: theme
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    format: date
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 21:01:11 +03:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								## Custom Headers
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Pass custom headers using the `headers`  option, for example:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```yaml
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								headers:
							 
						 
					
						
							
								
									
										
										
										
											2023-10-17 23:26:55 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  X-API-Token: token
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 21:01:11 +03:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
									
										
										
										
											2024-02-16 22:25:31 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								## Custom Request Body
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Pass custom request body using the `requestBody`  option in either a string or object format. Objects will automatically be converted to a JSON string.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```yaml
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								requestBody:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  foo: bar
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# or
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								requestBody: "{\"foo\":\"bar\"}"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Both formats result in `{"foo":"bar"}`  being sent as the request body. Don't forget to set your `Content-Type`  headers!