We want to be able to refresh the table at any time, so we can show the user what happens when they create or update rows.
Here’s the line we’ve been using to fetch the inventory items from the database:
self.repeating_panel_1.items = anvil.server.call('get_items')
Remove this line from __init__
and put it in a method of its own:
def refresh(self, **event_args):
self.repeating_panel_inventory.items = anvil.server.call('get_items')
Now call your new method from __init__
:
def __init__(self, **properties):
# Set Form properties and Data Bindings.
self.init_components(**properties)
# Any code you write here will run before the form opens.
self.refresh()
Let’s also create an event to trigger a refresh. That makes it easier to trigger a refresh from outside this Form.
At the end of __init__
, add the following line to bind an event that triggers a refresh:
# At the end of __init__:
self.set_event_handler('x-refresh', self.refresh)
Re-run your app: you should still see your database rows displayed in the table.