Appmaker Config Form
Appmaker Form config is used to render the form in the Appmaker Dashboard. The form is rendered based on the JSON schema provided in the attributesSchema
property of the block schema.
Example
{
"properties": [
{
"id": "background_color",
"label": "Theme AccentColor",
"uiType": "ColorPicker",
"type": "string"
},
{
"id": "title",
"label": "Title",
"type": "string",
"description": "Sample Description"
},
{
"id": "slider_type",
"type": "string",
"title": "Slider Type",
"uiType": "RadioGroup",
"options": [
{
"label": "Type 1",
"value": "type-2"
},
{
"label": "Type 2",
"value": "type-2"
}
]
}
]
}
Output
data:image/s3,"s3://crabby-images/6e794/6e794d021b99ce0bc272b5eeda7f59de6e5e5dde" alt="App Screenshot"
Standard attributes
The following attributes are standard for all input settings. However, there might be additional attributes for specific input types.
Attribute | Description | Required |
---|---|---|
uiType | The type of UI component to render. | Yes |
type | The type of input. | Yes |
label | The label of the input. | Yes |
description | The description of the input. | No |
Input types
String
The string
input type is used for text input.
{
"properties": [
{
"id": "name",
"type": "string",
"label": "Sample Name",
"description": "Sample Description"
}
]
}
The above code will generate the following input:
data:image/s3,"s3://crabby-images/9cbe0/9cbe0ad2ba62c40a2e32ff8908a010ae681347e8" alt="App Screenshot"
Text Area
{
"properties": [
{
"id": "details",
"type": "string",
"label": "Details",
"description": "Some description",
"inputType": "textArea",
"rows": 10
}
]
}
The above code will generate the following input:
data:image/s3,"s3://crabby-images/b569d/b569dec27f776c14ebf710f9831c650c51c2cca7" alt="App Screenshot"
JSON
{
"properties": [
{
"id": "config",
"type": "string",
"label": "Config",
"description": "Some description",
"uiType": "json"
}
]
}
The above code will generate the following input:
data:image/s3,"s3://crabby-images/e7d8a/e7d8af6c977c0b84150597bd525444ba2b0484d2" alt="App Screenshot"
Radio Group
You can set the uiType
to RadioGroup
to render the input as a radio group. You can also set the options
attribute to set the options for the radio group.
{
"properties": [
{
"id": "selectBannerDesign",
"type": "string",
"uiType": "RadioGroup",
"title": "Banner Design",
"options": [
{
"label": "Type 1",
"value": "type-1"
},
{
"label": "Type 2",
"value": "type-2"
},
{
"label": "Type 3",
"value": "type-3"
}
]
}
]
}
The above code will generate the following input:
data:image/s3,"s3://crabby-images/26cee/26ceee4219f4666a81fad8f81ee8a9569cdb55b4" alt="App Screenshot"
Color Picker
You can set the uiType
to ColorPicker
to render the input as a color picker.
{
"properties": [
{
"id": "themeFontColor",
"uiType": "ColorPicker",
"type": "string",
"label": "Theme Font Color"
}
]
}
The above code will generate the following input:
data:image/s3,"s3://crabby-images/50a2b/50a2b6d0b7ff63d7377d417e45e7f05ba156e523" alt="App Screenshot"
Switch
You can set the uiType
to Switch
to render the input as a switch.
{
"properties": [
{
"id": "show_banner",
"type": "string",
"uiType": "switch",
"label": "Show banner"
}
]
}
Other supported properties are:
Parameters | Description | value |
---|---|---|
defaultValue | To set the default value of the switch | false |
The above code will generate the following input:
data:image/s3,"s3://crabby-images/86f94/86f9490d24e55bd4951b0e57e7af13408e6c2f5f" alt="App Screenshot"
Media Library
You can set the uiType
to appmaker-media-library
to render the media modal.
{
"properties": [
{
"id": "image",
"type": "string",
"uiType": "appmaker-media-library",
"label": "Product Image"
}
]
}
{
"properties": [
{
"id": "custom_name",
"type": "appmaker-media-library",
"label": "Sample Name",
"description": "Sample Description",
"mediaTypes": ["video", "image"],
"dropzoneHelperText": "PNG, JPG, GIF, MP4 up to 2MB",
"acceptedFile": "image/*"
}
]
}
Parameters | Description | data type | values | required |
---|---|---|---|---|
mediaTypes | To show and upload the media types | Array | ["video","image"] | false |
dropzoneHelperText | override text shown inside media library when uploading | String | any | false |
acceptedFile | override the accepted file while uploading | string | Any MIME type (example: "video/mp4") | false |
disableImageResize | To disable image resize.Default is false | Boolean | true/false | false |
maxWidth | To set max width for the image | String or Integer | Integer Value | false |
maxHeight | To set max height for the image (If maxWidth is set maxHeight is omitted) | String or Integer | Integer Value | false |
Above code will generate the following form:
data:image/s3,"s3://crabby-images/c5d88/c5d885e80910d347c42a9ff4129abfbaec6de569" alt="App Screenshot"
data:image/s3,"s3://crabby-images/1f53d/1f53d216cbcedfe0e46707235aedc0b0c70c559f" alt="App Screenshot"
data:image/s3,"s3://crabby-images/e0010/e0010d785a1c321056c78e6de19c131fa4016953" alt="App Screenshot"
Select
You can set the uiType
to Select
to render the input as a dropdown.
{
"properties": [
{
"id": "filterType",
"type": "string",
"uiType": "select",
"label": "Filter type",
"options": [
{
"label": "Product Type",
"value": "Product Type"
},
{
"label": "Color",
"value": "Color"
}
]
}
]
}
Parameters | Description | data type | values | required |
---|---|---|---|---|
creatable | custom create | boolean | true/false | false |
multi | create multiple input | boolean | true/false | false |
data:image/s3,"s3://crabby-images/34cf3/34cf3b72a6d06d6f7089d70618d24f0734cd9fec" alt="App Screenshot"
Infinite Text
You can set the uiType
to infinite-text
to render the infinite text box.
{
"properties": [
{
"id": "imageTags",
"type": "array",
"uiType": "infinite-text",
"label": "Image tags"
}
]
}
data:image/s3,"s3://crabby-images/cd16a/cd16aed96d15e29fedaad130ab22df6367c3a5e3" alt="App Screenshot"
Infinite Form
{
"properties": [
{
"id": "coupons",
"type": "array",
"uiType": "infinite-form",
"label": "Mobile app coupon list",
"properties": {
"enable": {
"type": "string",
"label": "Enable",
"uiType": "switch"
},
"coupon": {
"type": "string",
"label": "Coupon"
},
"min_amount": {
"type": "string",
"label": "Min Amount"
},
"description": {
"type": "string",
"label": "Description"
}
}
}
]
}
data:image/s3,"s3://crabby-images/4e160/4e1608777c2c1f4ec4dfa4787a9bcb7155f2cba2" alt="App Screenshot"
Example 2
{
"properties": [
{
"id": "filterType",
"type": "string",
"uiType": "select",
"label": "Filter type",
"creatable": true,
"options": [
{
"label": "Product Type",
"value": "Product Type"
},
{
"label": "Color",
"value": "Color"
}
]
},
{
"id": "show_banner",
"type": "string",
"uiType": "Switch",
"label": "Show banner"
},
{
"id": "selectBannerDesign",
"type": "string",
"uiType": "RadioGroup",
"title": "Banner Design",
"options": [
{
"label": "Type 1",
"value": "type-1"
},
{
"label": "Type 2",
"value": "type-2"
},
{
"label": "Type 3",
"value": "type-3"
}
]
}
]
}
Above code will generate the following form:
data:image/s3,"s3://crabby-images/bd1b2/bd1b29e3a2d6dd345c484f08999f0dc2a9a14823" alt="App Screenshot"
Image Radio Group
You can set the uiType
to image-radio
to render the input as a image radio group. You can also set the options
attribute to set the options for the radio group.
{
"properties": [
{
"id": "selectBannerDesign",
"type": "string",
"uiType": "image-radio",
"title": "Banner Design",
"options": [
{
"label": "Sample Name 1",
"description": "Last message sent an hour ago",
"imgSrc": "https://picsum.photos/200?random=1"
},
{
"label": "Sample Name 2",
"description": "Last message sent an hour ago",
"imgSrc": "https://picsum.photos/200?random=2"
},
{
"label": "Sample Name 3",
"description": "Last message sent an hour ago",
"imgSrc": "https://picsum.photos/200?random=3"
}
]
}
]
}
The above code will generate the following input:
data:image/s3,"s3://crabby-images/2eab7/2eab7fa1b4d1087c404dd9aa423c2920b30d3027" alt="App Screenshot"
Range Slider
{
"properties": [
{
"id": "gap",
"type": "string",
"uiType": "RangeSlider",
"label": "Gap",
"default": 50,
"min": 1,
"max": 500
}
]
}
The above code will generate the following input:
data:image/s3,"s3://crabby-images/95826/95826eb6887cc12f5e194c94c22316c50814c98b" alt="App Screenshot"
Parameters | Description |
---|---|
default | To set the default value of the slider |
min | To set the minimum value of the slider |
max | To set the maximum value of the slider |
Date Time Picker
{
"properties": [
{
"id": "chooseTime",
"type": "string",
"uiType": "date-time",
"label": "Time to show",
"title": "choose me",
"minDate": "2024-01-01",
"maxDate": "2028-12-31"
}
]
}
data:image/s3,"s3://crabby-images/a7275/a727524981f8e6afa9c0ce89acfd74589fe0a3ad" alt="App Screenshot"
Parameters | Description | Default Value |
---|---|---|
title | Title of the date picker | |
disableClock | Disable the clock for time selection | true |
minDate | Minimum selectable date (YYY-MM-DD) | |
maxDate | Maximum selectable date (YYY-MM-DD) | |
dayPlaceholder | Placeholder for day input | "dd" |
monthPlaceholder | Placeholder for month input | "mm" |
yearPlaceholder | Placeholder for year input | "yyyy" |
secondPlaceholder | Placeholder for second input | "ss" |
minutePlaceholder | Placeholder for minute input | "mm" |
hourPlaceholder | Placeholder for hour input | "hh" |
className | Additional class for styling |
Conditional
{
"properties": [
{
"id": "conditional-block",
"type": "conditional",
"label": "Label",
"placeholder": "Choose options",
"options": [
{
"id": "option-1",
"label": "Option 1",
"properties": [
{
"id": "option-1-sub",
"type": "string",
"label": "Option 1 sub"
}
]
},
{
"id": "option-2",
"label": "Option 2",
"properties": [
{
"id": "option-2-sub-1",
"type": "string",
"label": "Option 2 sub 1"
},
{
"id": "option-2-sub-2",
"type": "string",
"label": "Option 2 sub 2"
}
]
}
]
}
]
}
data:image/s3,"s3://crabby-images/ed3b3/ed3b33ce6f7d16b2e7278b49eab4f5441fd0a7a8" alt="App Screenshot"
Collections
{
"properties": [
{
"id": "collectionId",
"label": "Select collection",
"type": "collections"
}
]
}
data:image/s3,"s3://crabby-images/e59d9/e59d9f63228e09a63ac7b0c43d50ba4e2f82a172" alt="App Screenshot"
data:image/s3,"s3://crabby-images/3940a/3940a783bf188fc933d5fc807aa11036b1994481" alt="App Screenshot"
Parameters | Description | Default Value |
---|---|---|
isMulti | To select multiple options | false |
In-App Page
Form type for selecting the in-app pages. This will allow you to select the in-app pages from the dashboard.
{
"properties": [
{
"id": "pageId",
"type": "string",
"uiType": "in-app-page",
"label": "Select Page",
"isMulti": false
}
]
}
data:image/s3,"s3://crabby-images/bed52/bed522969bb5048626351b7f0726aaf075f98718" alt="App Screenshot"
Parameters | Description | Default Value |
---|---|---|
isMulti | To select multiple options | false |
Appmaker Action
Form type for selecting the appmaker actions. This will allow you to select the appmaker actions from the dashboard.
{
"properties": {
"name": {
"type": "appmaker-action",
"label": "Appmaker action"
}
}
}
data:image/s3,"s3://crabby-images/238bd/238bd932d9dd0ea6ec7eb98d629491aa3d786dfa" alt="App Screenshot"
Form types for styling
Layout Styles
Form type for styling the layout of the app blocks. Using this form type will allow you to apply styles from the dashboard to the app components. You can apply styles mentioned in view-style-props
{
"properties": [
{
"id": "containerStyles",
"type": "string",
"uiType": "layout-styles",
"label": "Block Container Styles"
}
]
}
Text Styles
Form type for styling the text of the app blocks. Using this form type will allow you to apply styles from the dashboard to the app components. You can apply styles mentioned in text-style-props
{
"properties": [
{
"id": "textStyles",
"type": "string",
"uiType": "text-styles",
"label": "Title Text Styles"
}
]
}
Image Styles
Form type for styling the image of the app blocks. Using this form type will allow you to apply styles from the dashboard to the app components. You can apply styles mentioned in image-style-props
{
"properties": [
{
"id": "imageStyles",
"type": "string",
"uiType": "image-styles",
"label": "Image Styles"
}
]
}
data:image/s3,"s3://crabby-images/fed4c/fed4c3b91e5ad3829f6eb031ef9593e2a097d0a6" alt="App Screenshot"
Additional form types
Group
Form type for grouping multiple properties together. This is useful when you want to group multiple properties together and apply. This will help to organize the properties in the dashboard.
{
"properties": [
{
"id": "blockStyles",
"type": "string",
"uiType": "group",
"label": "Main Styles",
"description": "This will apply styles to the main block of the component.",
"properties": [
{
"id": "containerStyles",
"type": "string",
"uiType": "layout-styles",
"label": "Block Container Styles"
},
{
"id": "textStyles",
"type": "string",
"uiType": "text-styles",
"label": "Title Text Styles"
}
]
}
]
}
data:image/s3,"s3://crabby-images/bb9a9/bb9a9d22bd2608121ac8707ac1d5d28f9258b9c2" alt="App Screenshot"
Title
Form type for adding a title to the form. This is useful when you want to add a title to the form or in between the properties. This will help to organize the properties in the dashboard.
{
"properties": [
{
"id": "title",
"type": "string",
"uiType": "title",
"label": "Title",
"description": "This is the title of the component.",
"size": "h1"
}
]
}
Prop | Type | Description |
---|---|---|
size | string | Size of the title. Possible values are h1 , h2 , h3 |
data:image/s3,"s3://crabby-images/d0385/d03856f73db12e53ea4f2000297dab9019a29944" alt="App Screenshot"