_LookupCustom
Last updated 19/12/2024
Overview
This documentation will demonstrate how to use Five's display type _LookupCustom. _LookupCustom enables you to populate lookup custom values using code. You can write a function and attach it to an event to execute. When executed the values supplied in your function will be available in the field that has the _LookupCustom display type.
For this scenario, the Catergory table in the Soul Food application, will have a new field added called AllergyNotice which will have its lookup populated by code. The following steps will be perfomed:
- Add a function with the custom values
- Add the field to the form and attach the _LookupCustom display type
- Attach the function to an event
The Ingredient table has a field called AllergyNotice.
data:image/s3,"s3://crabby-images/0dd53/0dd53932e6127b1547c0aaf8a536dd3d5c6ee44b" alt="Database model"
Add a Function
The function needs to clear the options in the lookup using the
You can add your function in the Functions view or Five's Code Editor.
data:image/s3,"s3://crabby-images/2968f/2968f66c32433f22632656b4e36bd4003b92bf97" alt="PopulateAllergies function"
function PopulateAllergies(five, context, result) {
const sender = five.sender();
const allergyNoticeField = sender.tabs[0].dataManager.getFormFieldTypeByID('AllergyNotice');
allergyNoticeField.clearOptions();
allergyNoticeField.addOption('milk', 'Milk');
allergyNoticeField.addOption('fish', '(e.g., bass, flounder, cod)');
allergyNoticeField.addOption('crus', 'Crustacean shellfish (e.g., crab, lobster, shrimp)');
allergyNoticeField.addOption('tree', 'Tree nuts (e.g., almonds, walnuts, pecans)');
allergyNoticeField.addOption('pean', 'Peanuts');
allergyNoticeField.addOption('whet', 'Wheat');
allergyNoticeField.addOption('soy', 'Soybeans');
allergyNoticeField.addOption('ses', 'Sesame');
return five.success(result);
}
Add a _LookupCustom Display Type
The Ingredients form was added into Five in the _Lookup documentation, this form is going to be edited to add a new field with a display type of _LookupCustom, and to attach the above function to the On Show event for the form. When the Ingredients form is shown in the Soul Food application either by adding a new record or selecting a saved record, the custom values added in the function will be available in the form field lookup.
1. Select Visual in the menu.2. Select Forms in the sub-menu.
data:image/s3,"s3://crabby-images/84c18/84c1865ae79fd66119b606b253f9f1d616a46238" alt="Forms menu item"
3. Select the form record in the list.
4. Click the Events tab.
data:image/s3,"s3://crabby-images/3c5c8/3c5c868be166f9f05ec3fb486de755c52a68111e" alt="Events tab"
5. Either click the Edit button in the form app bar or click directly in the On Show field.
data:image/s3,"s3://crabby-images/83310/833100ae90ed983fa0c3e94e9f0192bcd52099d0" alt="Edit button"
6. Click the lookup in the On Show field and select your function.
data:image/s3,"s3://crabby-images/121f0/121f0fb6638c34d28c7cc2d96c4b2526cd3e9883" alt="On Show field"
7. Click the Pages tab.
data:image/s3,"s3://crabby-images/05f93/05f9315b286b383230694414700dd64323d40433" alt="Pages tab"
8. Select the Page record.
data:image/s3,"s3://crabby-images/7889d/7889df87f21fdb4ccc15fdbdadc8e40c8a2c65ec" alt="Pages record"
9. Click the Fields tab.
data:image/s3,"s3://crabby-images/46937/46937f4c455f06b2ddc3d744033af720492f2e38" alt="Fields tab"
10. Click the Add Fields button.
data:image/s3,"s3://crabby-images/64e7c/64e7c6b66bccfb0b88c0476d976fa47570ac004b" alt="Add Fields button"
11. Click the lookup icon in the Field field and select the field.
12. Click the lookup icon in the Display Type field and select _LookupCustom.
data:image/s3,"s3://crabby-images/14831/14831b8da9ebafd76e9370447e098fa9fee8074b" alt="Add a field with a _LookupCustom display type"
13. Click the Save button in the form app bar.
data:image/s3,"s3://crabby-images/df746/df7463aca4802660c067863b4d0665e8e8210309" alt="Save button"
14. Click the Save button in the form app bar above the list.
data:image/s3,"s3://crabby-images/ffd11/ffd117c9612df72731fd37f69c4e8022aa1d16d7" alt="Save button"
In the application, the lookup for the field will now hold the custom values that were added in the function using the
data:image/s3,"s3://crabby-images/0ad03/0ad03a3f520e86cc1a78293656be98f2b02f5221" alt="_LookupCustom in app"
_LookupCustom in the Form Wizard
If you know you want to use the display type _LookupCustom on creation of your form while using the Form Wizard, select _LookupCustom in the Display Type field.
You will need to edit the form record to attach your function.
data:image/s3,"s3://crabby-images/fc32a/fc32a5c52b4501e66da5f8e6edb333f2bded539a" alt="Display Type field"