Package and query modules
A package is a collection of query and JS modules that can be versioned and distributed across instances. Inside packages, you can create multiple query and JS modules, allowing you to bundle and organize your application logic efficiently.
You'll create a reusable query module using product inventory data and display that data in a Table widget. By the end of this tutorial, you will learn:
- 🔧 Basics: Learn how to create and configure the query module
- 🔄 Dynamic Data: Learn how to pass data between the app and query module
- ♻️ Reusability: Discover how to reuse the query module within applications
Prerequisites
Before you start, make sure you have the following:
- A self-hosted instance of Appsmith with a paid subscription. Refer to the Appsmith installation guides for detailed instructions on setting up your Appsmith instance.
- If you are new to Appsmith, see Tutorial - Basics.
Create query module
A reusable query module is a query that can be used across multiple applications within the same workspace. They prove beneficial for tasks like fetching details or creating filter queries, eliminating the need to create separate queries for each application.
- 
Click Create New on the top-right corner of your workspace, and then select New Package. 
- 
Rename the package to ProductUtils.
- 
Click the New Module button located at the center of the screen. Choose Query Module and proceed to create a new datasource by selecting PostgreSQL. 
- 
Enter the following details in the connection parameter fields. For this tutorial, we will use a product inventory database as an example to create queries and display data. 
- Connection mode: READ_WRITE
- Host address: aws-0-us-east-1.pooler.supabase.com
- Port: 5432
- Database name: postgres
- Username: postgres.hazwlkzitjmrmqbpkqch
- Password: w9uDFMhmMzOOvPbv
- 
Test and save the datasource. 
- 
Click + New Reusable Query from the top-right corner of the datasource editor. 
- 
Rename the query module to GetProducts.
- 
Configure the query to retrieve product details using the following SQL: 
SELECT * FROM public."product" LIMIT 5 OFFSET 4;
With this, you don't need to create multiple same queries for different pages or applications. You can reuse this same query module in various contexts, such as:
- Displaying the entire inventory data in a Table widget.
- Displaying low stock data (e.g., < 50) in a List widget on a different page.
- Displaying stock data in a chart widget, and more.
- Click on the + Add Inputs button from the right-side property pane. These inputs allow you to pass parameters from your application to query module, facilitating dynamic query adjustments based on user inputs or application requirements.
Create two inputs:
- limit, with a default value of- 5.
- offset, with a default value of- 4.
If dynamic values are not passed, it takes the default value.
- Update the query by using inputsproperty for dynamic adjustments:
SELECT * FROM public."product" LIMIT {{inputs.limit}} OFFSET {{inputs.offset}};
- 
Run the query to ensure it retrieves the data correctly. 
- 
Publish the query module from top-right corner. This allows the changes to reflect on the app side. 
Use query module
Great job on creating a query module! Now, let's see how you can reuse it in different apps.
- 
Open your App or create a new one from the homepage and ensure that both the app and modules share the same workspace. 
- 
From the Queries Tab, click + New query / API. 
- 
Select the Add GetProductsquery module. You can add multiple instances of the same module and pass different parameters to each one.
- 
Run the query module. 
- 
To display query data, drop a Table widget and connect it to the GetProducts1Query module.
- 
From the Queries Tab, open the GetProductsquery module and set the inputs to reference the properties of the Table widget.
This configuration dynamically sets the limit and offset based on the values from the Table widget(Table1).
- 
Limit: {{Table1.pageSize}}
- 
Offset: {{Table1.pageOffset}}
- 
Enable the Server-side pagination property in the Table. 
- 
Set the Table widget's OnPageSizeChange and onPageChange to execute the GetProductsquery.
With this, you have connected the query module to the Table widget and enabled server-side pagination, which allows you to dynamically fetch and display data based on the current page and page size.
You have successfully integrated the query module into your app, displaying its data in the Table widget.