7 - Validate Transaction Dates
Last updated 3/04/2023
This documentation is to demonstrate how we can use metadata provided in the Buy field to validate the purchase of shares to a specific date.Add the CheckBuyQuantity Function
1. Select Logic in the menu.2. Select Code Editor in the menu.
data:image/s3,"s3://crabby-images/38380/38380a0f8571285646e2d174ddb7f85cf1c68d38" alt="Code Editor Menu Item"
Figure 1 - Code Editor menu item
3. Click the Add New Code Button.
data:image/s3,"s3://crabby-images/c4cd9/c4cd9133cee2e4e8755b2248771f2d559690235d" alt="Add New Code Button"
Figure 2 - Add New Code button
4. Type CheckBuyQuantity in the Function ID field.
5. Click the lookup icon in the Language field and select TypeScript.
6. Click the OKAY button
data:image/s3,"s3://crabby-images/19037/1903774a472f4d2087238eb263898c8ad123e6bd" alt="Add the CheckBuyQuantity Function"
Figure 3 - Add the CheckBuyQuantity function
7. Click the Copy button on the below code block.
CheckBuyQuantity
function CheckBuyQuantity(five: Five, context: any, result: FiveError) : FiveError {
const qty: number = parseInt(five.field.Quantity);
if (qty > five.form.Sells.Quantity) {
return five.createError(result, 'Stock quantity exceeds quantity in this sale');
}
if (qty > five.getMetadata('Allocations', 'BuyKey', 'Holding')) {
return five.createError(result, 'Stock quantity exceeds remaining stock in this buy');
}
return five.success(result, '');
}
8. Paste the code block over the template in the Code Editor.
9. Click the Save Current Tab button.
data:image/s3,"s3://crabby-images/6c192/6c192fb9a1f60246467ef15385205849f82420c6" alt="Save the CheckBuyQuantity Function"
Figure 4 - Save the CheckBuyQuantity function
Attach the CheckBuyQuantity Function
Path: Allocations form > General page > Quantity field > On Validate event1. Select Visual in the menu.
2. Select Forms in the sub-menu.
data:image/s3,"s3://crabby-images/3a4cb/3a4cb349aae31edfc09d07d4fd9cd5dcf4ae7ed5" alt="Forms Menu Item"
Figure 5 - Forms menu item
3. Select the Allocations record in the list.
4. Click the Pages tab.
data:image/s3,"s3://crabby-images/585ff/585ffa35c21d1a96ab52523f238f59d7ff9d8771" alt="Pages Tab"
Figure 6 - Pages tab
5. Select the General record.
data:image/s3,"s3://crabby-images/0efe4/0efe40a5a6558d5086094342bc56b818b2cbd288" alt="General Record"
Figure 7 - General record
6. Click the Fields tab.
data:image/s3,"s3://crabby-images/a00a1/a00a1086191841cf1e91ae20b7813e84d4406135" alt="Fields Tab"
Figure 8 - Fields tab
7. Select the Quantity record.
data:image/s3,"s3://crabby-images/62d07/62d079398e2370a7e36eeda81e1b05f7cc7241c4" alt="Quantity Field"
Figure 9 - Quantity field
8. Click the Events tab.
data:image/s3,"s3://crabby-images/f897a/f897a895dedcd74d29bf89965200cfc82bfac296" alt="Events Tab"
Figure 10 - Events tab
9. Click the lookup icon in the On Validate field and select CheckBuyQuantity.
data:image/s3,"s3://crabby-images/321f8/321f8fb3ecef42f2ff79791f5ec02e013b6c46e9" alt="Attach the CheckBuyQuantity Function"
Figure 11 - Attach the CheckBuyQuantity function
10. Click the Save button in the form app bar.
data:image/s3,"s3://crabby-images/ecb6e/ecb6eeefb0497ea55ba244b2ba674f9fd2be9f66" alt="Save the CheckBuyQuantity Event"
Figure 12 - Save the CheckBuyQuantity event
11. Click the Save button in the form app bar above the list.
data:image/s3,"s3://crabby-images/db921/db9211f0afb3326b7d749eb21b05d8ca29dbceb6" alt="Save the Allocations Form"
Figure 13 - Save the Allocations form
Run the Portfolio Application
1. Click the Run button in Five's toolbar.data:image/s3,"s3://crabby-images/206ff/206ffa28fd014657672d5fd7d2ffa908c603d84d" alt="Run Button"
Figure 14 - Run button
2. Select the Growth Portfolio record.
3. Click the Down button in the form app bar.
data:image/s3,"s3://crabby-images/b58b9/b58b98ffdc4da5d320bed77c1d1b140a793bf2d5" alt="Down Button"
Figure 15 - Down button
Test the CheckBuyQuantity Function
1. Select Sells in the menu.2. Click the Add Item button.
3. Click the lookup icon in the Stock field and select AEI.
4. Click the calendar icon in the Transaction Date field, select the current date, and click the OK button.
5. Type 1100 in the Quantity field.
6. Type 1.00 in the Price field.
7. Type 10.00 in the Fees field, press tab.
data:image/s3,"s3://crabby-images/22f7a/22f7a62cdef85fc792e8d242eca1cc2354b39e3a" alt="Add an AEI Sells Record"
Figure 16 - Add an AEI sells record
8. Click the Add Allocations button.
data:image/s3,"s3://crabby-images/db814/db8144f2d94637fe4013ef4a5e5cfcb1486576c1" alt="Add Allocations Button"
Figure 17 - Add Allocations button
9. Click the lookup icon in the Buy field and select your yesterday date.
10. Type 1100 in the Quantity field.
11. Click the Save button in the form app bar.
data:image/s3,"s3://crabby-images/a3c07/a3c07be845ead8bdba93ec583b73c09bd6c3fe5c" alt="Add an Allocations Record"
Figure 18 - Add an Allocations record
info
An error is returned letting as know that the Stock quantity exceeds remaining stock in this buy. This is because even though we have a total of 1120 AEI shares, we only purchased 1000 AEI shares on the transaction date 2023-03-27.
12. Click the OK button.
data:image/s3,"s3://crabby-images/a84b1/a84b1a5b313e3f6e54e38475d9373b22dc02259d" alt="Stock Exceeds Quantity Remaining Error"
Figure 19 - Stock exceeds quantity remaining error
13. Type 1000 in the Quantity field.
14. Click the Save button in the form app bar.
data:image/s3,"s3://crabby-images/c3f13/c3f13d5e840ef14a8636b8293519984fac65c604" alt="Validates Shares to Transaction Dates"
Figure 20 - Validates shares to transaction dates
Problem
If you take a look at the image below, we are able to save at this point as we have 1000 AEI shares purchased on the 2023-03-27. If we were to click the Save button on the Sells form, the sale would be submitted even though the Quantity fields on the Sells and Allocations forms do not match. In Five, we can create a backend function to ensure the values in the Quantity fields match on the Sells and Allocations form.
data:image/s3,"s3://crabby-images/b2aeb/b2aeb903caad90908c262fe9fdd0b4a601604ebf" alt="Unmatched Quantity Fields"
Figure 21 - Unmatched Quantity fields
15. Click the Cancel button in the form app bar.
data:image/s3,"s3://crabby-images/bcd8d/bcd8dcc1940510a360d6d325ce5fe48de503a880" alt="Cancel Button"
Figure 22 - Cancel button
16. Close the browser tab and return to Five.