Example: Add a form and actions
This example shows how to make a form that has text fields which display input from a user.
Making the form's user interface
Begin by creating an application, adding a visual part to it, and opening a Composition Editor on the visual part. Then, in the Composition Editor, create the form:
1. Delete the window.
2. Select
data:image/s3,"s3://crabby-images/2df2a/2df2a74601ccacb607fb6e9ede347752c3b07164" alt="Canvas category icon Canvas category icon"
(Canvas category) and then
data:image/s3,"s3://crabby-images/b6b4a/b6b4a6dda813b773b35af001137345ed8e9caccd" alt="Form icon Form icon"
( part).
3. Click on the free-form surface.
Next, add one
data:image/s3,"s3://crabby-images/5ceda/5cedae6ce7a5eb6585afc85df674f304be9c204b" alt="Text icon Text icon"
(Text part) and one
data:image/s3,"s3://crabby-images/1c430/1c43031c2df29c193589544ff5565681f9f87b72" alt="Multi-line Edit icon Multi-line Edit icon"
(Multi-line Edit part). Both of these are in
data:image/s3,"s3://crabby-images/3e919/3e91976a224329516965587b8ddd4a513c93210b" alt="Data Entry category icon Data Entry category icon"
(Data Entry category). Arrange the parts so the form looks like the following:
data:image/s3,"s3://crabby-images/6a07b/6a07b08ea07f1f13c2a683dc556729cc113b6ae7" alt="Parts on form Parts on form"
Adding actions
So other parts can display data in the text fields, add scripts that provide a public interface for the text fields:
1. Select
data:image/s3,"s3://crabby-images/5b252/5b252b1625d24a16a378a748fe46489c4f659e82" alt="Public Interface Editor Public Interface Editor"
in the lower-right corner of the Composition Editor to open a Public Interface Editor for the visual part.
2. Select the Action tab.
3. Type the following into the Action name field:
setName:
Then, select Add with defaults.
4. Repeat step 3, except add
setAddress:
5. From the File menu, select Generate Default Scripts.
6. In the window that opens, highlight setName: and setAddress: in the Selectors field. Then, select Generate selected. VA Smalltalk generates code for the two scripts.
Defining code for the actions
Now, select
data:image/s3,"s3://crabby-images/cf11f/cf11f2b0ce1514a90d8148e24c72ddb6517b208d" alt="Script Editor Script Editor"
to go to the
Script Editor. In the Script Editor, change the scripts generated so they set values for the text fields:
1. Toggle the Instance/Class button so the category Not Categorized appears in the upper left pane.
2. Select Not categorized and then setName: in the upper-right pane.
3. Add a blank line after the code displayed in the lower pane for setName:.
4. Click on the
data:image/s3,"s3://crabby-images/863a0/863a07a7581895f030c8e09dc3382bdafc87aa7b" alt="Subpart Features Syntax icon Subpart Features Syntax icon"
icon in the upper-left of the editor.
5. In the
displayed window, select the Text part in the
Subparts field and
object in the
Attributes field. Next, press mouse button 2 on the
Attributes field and select
Paste 'set' from the pop-up menu.
6. Replace <your expression here> with parm1. parm1 represents the value that the user gives. After you change the code, it resembles the following:
setName: parm1
"Perform the setName: action."
(self subpartNamed: 'Text1') object: parm1
7. Save the script.
Repeat the previous steps for setAddress, only paste the setter for the object attribute of the Multi-line Edit subpart. After you change the code, it resembles:
setAddress: parm1
"Perform the setAddress: action."
(self subpartNamed: 'Multi-line Edit1') object: parm1
Finally, save the part. You can now
use the form in other applications.
Last modified date: 08/14/2019