DropDownList
The new control is an alternative to the Control "ComboBox". The values of the control "DropDownList" can be provided as static datasource (data formatted as JSON Array inside your Template) or by an external datasource e.g. by referencing a HFSqlServer list by linking to the URL or by providing an oData source as known of the ComboBox control.
static datasource:
<div
id="technician"
data-hf-control="DropDownList"
data-hf-options="{
label: 'Technician',
required: true,
optionLabel: 'Please select the responsible technician',
dataSource: [
{ name: 'Bauer, F', code: 'Bauer, F' },
{ name: 'Gruber, P', code: 'Gruber, P' },
{ name: 'Lanner, G', code: 'Lanner, G' },
{ name: 'Simon, R', code: '3521' },
{ name: 'Herbert, W', code: '123456789012' }
],
dataTextField: 'name',
dataValueField: 'code'
}"
></div>
external datasource (URL):
<div
id="tab1_dropdownlist"
data-hf-control="DropDownList"
data-hf-options="{
label: 'DropDownList (HFSql Catalogs)',
list: true,
minLength: 3,
url: '/api/catalogs/Items?$select=Title,KatalogText,Streetname&%24orderby=Title,PLZ&%24top=1000',
defaultValue: 'Title1',
dataTextField: 'KatalogText',
dataValueField: 'Title',
template: '\#: Streetname # <small>(#: PLZ # #: Postort #)</small>',
valueTemplate: '\<strong>#: Streetname #</strong> <small>(#: PLZ # #: Postort #)</small>',
}"
></div>
multilingual external datasource (URL):
<div
id="tab1_dropdownlist"
data-hf-control="DropDownList"
data-hf-options="{
label: 'DropDownList (HFSql Catalogs)',
list: true,
minLength: 3,
url: '/api/catalogs/Items?$select=Title,KatalogText,Streetname,Strassenname&%24orderby=Title,PLZ&%24top=1000',
i18nDataTextField: {
en: 'Streetname',
de: 'Strassenname',
default: 'Streetname'
},
dataValueField: 'Title',
template: '\#: Streetname # <small>(#: PLZ # #: Postort #)</small>',
valueTemplate: '\<strong>#: Streetname #</strong> <small>(#: PLZ # #: Postort #)</small>',
}"
></div>
external datasource (OData):
<div
id="liveOdataSource"
data-hf-control="DropDownList"
data-hf-options="{
label: 'DropDownList with live OData source',
required: true,
dataTextField: 'KatalogText',
dataValueField: 'Title',
autoBind: false,
dataSource: {
type: 'odata',
transport: {
read: {
url:'https://example.com/liveOdataSource/?select=Title,KatalogText&orderby=KatalogText',
dataType: 'json',
headers: {
'Accept': 'application/json;odata=verbose'
}
}
}
}
}"
></div>
FormControl Optionsβ
Options of the kendo component are also available. read more
dataTextField - requiredβ
dataTextField: 'name'
string
dataValueField - requiredβ
dataValueField: 'code'
string
autoBindβ
autoBind: false
boolean
true
checkValueInitiallyβ
checkValueInitially: true
boolean
true
dataSourceβ
dataSource: [{name: 'Bauer, F', code: 'Bauer, F'}, {name: 'Gruber, P', code: 'Gruber,P'}]
json pseudo array
defaultValueβ
defaultValue: 'Title1',
string | function
function() => string
disabledβ
disabled: true
boolean
doNotCopyβ
doNotCopy: true
boolean
filterItemsβ
contains
. More infos[{ field: 'name', operator: 'contains' }, { field: 'address' }]
{ field: string; operator?: string; }[]
formControlMappingβ
{ example_id: 'example_key' }
IFormControlMapping
highlightTemplateβ
highlight
as default placeholder for the highlighted text.highlightTemplate: '<strong>#: highlight #</strong>'
string
i18nDataTextFieldβ
{ en: 'Streetname', de: 'Strassenname', default: βStreetname' }
{ default: string, [langCode: string]: string }
itemTemplateβ
template
option, itemTemplate
keeps the original filter highlighting.itemTemplate: '<span>#: entry1 # - #: entry2 #</span>'
string | function
function(item: any) => string
listβ
list: true
boolean
listOptionsβ
{ dialogText: string, dialogHide: boolean }
minLengthβ
minLength: 3
number
onChangedβ
onChanged: HFFormdefinition.Namespace.Method
function
function(data: { value: string, text: string }) => void
optionLabelβ
optionLabel: 'Please select ...'
string
optionTemplateβ
optionTemplate: 'label'
string
persistentβ
persistent: 'user'
'user'
tooltipβ
tooltip: 'Please indicate at least one cause of damage.'
string
tooltipTemplateβ
tooltipTemplate: 'example_control_tooltip'
string
typeAheadβ
typeAhead: false,
boolean
true
urlβ
url: '/api/catalogs/Items?$select=Title,KatalogText&$orderby=Title'
string
valueMapperDelayβ
valueMapperDelay: true
boolean
valueTemplateβ
valueTemplate: '#: Streetname # (#: PLZ # #: Postort #)'
string
visitingβ
visiting: true
boolean
listOptions Objectβ
dialogTextβ
dialogText: 'Display Text'
string
Please follow the conventions to build an oData Source Link by considering the following documentations:
formControlMapping
βThe mapping objects consists of keys which are the Form control ID's to copy to and the value which can be a data source key or an object with the data source key and a format function.
By every value change the specified data source entries are copied to the given Form controls.
<div
id="exmaple_mapping"
data-hf-control="DropDownList"
data-hf-options="{
label: 'Example',
url: '/api/catalogs/Example?$select=Text,Value,Description,Date',
dataTextField: 'Text',
dataValueField: 'Value',
formControlMapping: {
description: 'Description',
date_picker: {
key: 'Date',
callback: HFFormdefinition.ExampleNamespace.formatDateFunc
}
}
}"
></div>
type FormControlMappingType = {
key: string;
callback: (dataItem: any, dataKey: string) => any;
};
interface IFormControlMapping {
[id: string]: string | FormControlMappingType;
}
Stored data
β<div
id="technician"
data-hf-control="DropDownList"
data-hf-options="{
label: 'Technician',
dataSource: [
{ name: 'Bauer, F', code: '1' },
{ name: 'Gruber, P', code: '2' },
{ name: 'Lanner, G', code: '3' },
{ name: 'Simon, R', code: '4' },
{ name: 'Herbert, W', code: '5' }
],
dataTextField: 'name',
dataValueField: 'code',
required: true
}"
></div>
For each DropDownList inside your Forms there are two value pairs of stored data:
First the information for the DropDownList itself...
{
"id": "technician",
"value": "3521"
}
...and second for the selected value:
{
"id": "technician_HFDropDownListText",
"value": "Simon, R"
}