Hacking dependent values
Jump to navigation
Jump to search
The following article is subject to change during 2020: The functions lookupBuilderShowAll and lookupBuilderFilter will probably become a part of the standard TS javascript library.
Example: Show all sub categories for a distinct main value
In the following the field CAT2 will display all possible categories, if the field CAT has the value "alle"
$("#DATA_CAT1").on('change', function() { if( getValue("CAT1") == "alle" ) lookupBuilderShowAll("DATA_CAT2"); });
/* remove function after next update after 2020-01-08 */ function lookupBuilderShowAll(dependantField) { var selectTo = document.getElementById(dependantField); var selectToValue = selectTo[selectTo.selectedIndex].value; var optionList = masterOptionContainer[dependantField]; var optionListLength = optionList.length; var optionCount = 0; selectTo.options[0] = new Option( "", "" ); for( var i=0; i < optionListLength; i++ ) { var optionItem = optionList[i]; var dependID = optionItem["dependID"]; optionCount++; selectTo.options[optionCount] = new Option( optionItem["itemValue"], optionItem["itemID"]); if( selectToValue == optionItem["itemID"] ) { selectTo.options[optionCount].selected = true; } } }
Example: Filter categories based on value in another field
In the following the field CAT2 will filter out values containing ":", where the value of the field NAVN cannot be found in the category name.
$("#DATA_CAT1").on('change', function() { if( getValue("CAT1") == "andet" ) lookupBuilderFilter("DATA_CAT2",getValue("NAVN"),':'); });
/* remove function after next update after 2020-01-08 */ function lookupBuilderFilter(dependantField,lookForValue,lookForMarker) { var selectTo = document.getElementById(dependantField); var selectToOptions = selectTo.options; var optionListLength = selectToOptions.length; for( var i=0; i < selectToOptions.length; i++ ) { var itemValue = selectToOptions[i].text; if( itemValue.indexOf(lookForValue) == -1 && itemValue.indexOf(lookForMarker) > -1 ) { console.log("Removing element: " + itemValue ); console.log("Removing element: " + selectToOptions[i].value ); selectTo.remove(i); } } }