D365 Business Central : Page OnLookup Trigger
data:image/s3,"s3://crabby-images/40f64/40f642e935de2e3708bdf15edda70fde7167aacc" alt=""
There are multiple ways in BC to create a Lookup button for a variable in a page or report. Generally speaking, I have seen three following methods being done to achieve the lookup button.
1. Using Table Relation
field(fieldItemCode1; ItemCode)
{
ApplicationArea = All;
Caption = 'Item Code 1';
TableRelation = Item."No.";
trigger OnValidate()
begin
Message(ItemCode);
end;
}
This is the method that works best. The validation is triggered and you also get the native drop-down list which is nice.
However, there is limitation on filtering, so you will not be able to use this method every time.
data:image/s3,"s3://crabby-images/55505/55505e977815187cd6331a20451431cf46efc36e" alt=""
2. Using OnLookup trigger and assigning the code directly to the variable.
field(fieldItemCode2; ItemCode)
{
ApplicationArea = All;
Caption = 'Item Code 2';
trigger OnLookup(var Text: Text): Boolean
begin
If Page.RunModal(Page::"Item Lookup", Item) = Action::LookupOK then
ItemCode := Item."No.";
end;
trigger OnValidate()
begin
Message(ItemCode);
end;
}
This method is also common, but have issue on related triggers. As you can see, native trigger, such as OnValidate is not triggered when you do it this way.
data:image/s3,"s3://crabby-images/5533c/5533ca00e0f544bc19700877c80f94013c635fb4" alt=""
3. Using OnLookup trigger and assigning the code to the Text and exit TRUE.
field(fieldItemCode3; ItemCode) { ApplicationArea = All; Caption = 'Item Code 3'; trigger OnLookup(var Text: Text): Boolean begin If Page.RunModal(Page::"Item Lookup", Item) = Action::LookupOK then begin Text := Item."No."; exit(true); end; end; trigger OnValidate() begin Message(ItemCode); end; }
This method give you the lookup function, but also trigger the validation when you call exit(true). The downside is that it does not give you dropdown list on method 1 (using Table Relation).
data:image/s3,"s3://crabby-images/cef40/cef403a89db3d41053214b8ce852f0b5b726b0f8" alt=""
I would recommend to use method 1 as much as possible. Only when it is not possible, we should be using method 3.
1 Response
[…] Page OnLookup Trigger […]