ComboBox
The values of the control "ComboBox" can be provided as static datasource (data formatted like a Json Array inside your template) or in case of a external datasource e.g. by referencing a SharePoint list by linking to the URL or by providing a oData source.
static datasource:
<div id="technician"
data-win-control="HFWinJSCtrl.ComboBox"
data-win-options="{
label: 'Technician',
required: true,
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_combobox_liste"
data-win-control="HFWinJSCtrl.ComboBox"
data-win-options="{
label: 'ComboBox (HFSql Catalogs)',
list: true,
minLength: 3,
url: '/api/catalogs/CatalogName?$select=Title,KatalogText,PLZ,Postort&%24orderby=Title,PLZ&%24top=1000',
template: HFFormdefinition.Namespace.setStreetTemplate,
dataTextField: 'KatalogText',
dataValueField: 'Title'
}"></div>
multilingual external datasource (URL):
<div id="tab1_combobox_liste"
data-win-control="HFWinJSCtrl.ComboBox"
data-win-options="{
label: 'ComboBox (HFSql Catalogs)',
list: true,
minLength: 3,
template: HFFormdefinition.Namespace.setStreetTemplate,
url: '/api/catalogs/Items?$select=Title,KatalogText,Streetname,Strassenname&%24orderby=Title,PLZ&%24top=1000',
i18nDataTextField: {
en: 'Streetname',
de: 'Strassenname',
default: 'Streetname'
},
dataValueField: 'Title'
}"></div>
external datasource (oData):
<div id="liveOdataSource"
data-win-control="HFWinJSCtrl.ComboBox"
data-win-options="{
label: 'Combobox 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
anytextβ
anytext: 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
formControlMappingβ
{ example_id: 'example_key' }
IFormControlMapping
i18nDataTextFieldβ
{ en: 'Streetname', de: 'PLZ', default: βStreetname' }
{ default: string, [langCode: string]: 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
persistentβ
persistent: 'user'
'user'
placeholderβ
placeholder: 'Please select ...'
string
templateβ
template: HFFormdefinition.Namespace.setStreetTemplate
function
function() => string
tooltipβ
tooltip: 'Please indicate at least one cause of damage.'
string
tooltipTemplateβ
tooltipTemplate: 'example_control_tooltip'
string
urlβ
url: '/_api/web/lists/getbytitle('SP')/Items?$select=Title&$orderby=Title'
string
valueMapperDelayβ
valueMapperDelay: true
boolean
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.
Every value change the specified data source entries are copied to the given form controls.
<div id="exmaple_mapping"
data-win-control="HFWinJSCtrl.ComboBox"
data-win-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-win-control="HFWinJSCtrl.ComboBox"
data-win-options="{
label: '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',
required: true
}"></div>
For each ComboBox inside your forms there are two value pairs of stored data:
First the information for the ComboBox itself
{
"id": "technician",
"value": "3521"
}
and second for the selected value:
{
"id": "technician_HFComboText",
"value": "Simon, R"
}