Now we need to run that insert_item
function from the web app. Let’s build an ‘add’ widget into the Data Grid.
Add a column to your Data Grid. Clear its Title and Key. Set its width to 80. This will hold our ‘add’ button later.
data:image/s3,"s3://crabby-images/b31a6/b31a6b8768cfc086783f92bf659df820c260cf05" alt=""
Add a Data Row Panel to the bottom of your Data Grid.
data:image/s3,"s3://crabby-images/275b2/275b2d383c8c834c2b4838763a6fc60a384cd22c" alt=""
Drop a TextBox into each of the Name and Quantity columns. Rename them text_box_name
and text_box_quantity
. Set the Quantity TextBox’s type
to number
.
data:image/s3,"s3://crabby-images/44b94/44b949aca35193e175e886058b1b1279cd55556a" alt=""
Drop a Button into the end column. Rename it button_add
. Clear the Button’s text
and set its icon
to fa:plus
.
data:image/s3,"s3://crabby-images/7693d/7693d8c6f05f6a0897c84fbeb090c1ea1ad5b229" alt=""
Create a click
handler by clicking the blue arrows to the right of ‘click’ in the Events section:
data:image/s3,"s3://crabby-images/05aa4/05aa4e9221abbd8e633eaa1044438845ada9d1bb" alt=""
def button_add_click(self, **event_args):
anvil.server.call(
'insert_item',
self.text_box_name.text,
self.text_box_quantity.text
)
# Refresh the open Form to load the new item into the UI
get_open_form().raise_event('x-refresh')
# Clear the input boxes
self.text_box_name.text = ''
self.text_box_quantity.text = ''
Now you can add items to your database from your web app!
data:image/s3,"s3://crabby-images/0ef2a/0ef2afbac9ff7b31a70db1173ec35c5589a474e7" alt=""