JS Modules
A JavaScript module serves as a reusable code unit, encapsulating specific functionalities to promote an organized code structure.
You'll learn how to reuse JavaScript code to format dates within your applications. By the end of this tutorial, you will learn:
- 🔧 Basics: Learn how to create and configure the JS module
- 🔄 Dynamic Data: Learn how to pass data between the app and JS module
- ♻️ Reusability: Discover how to reuse the JS 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 JS modules
- 
Open an existing package or create a new one from the top-right corner of your workspace. 
- 
Click the + icon in the top-left corner and select JS Module. 
- 
Rename the module to formatDate. 
- 
In the Main JS Object, delete the auto-generated code and add the below code to it: 
To pass data from the app to JS modules, you can pass it by calling the respective function with the necessary parameters, like formatDDMMYYYY('2023-03-08T09:45:15Z').
The following code takes a parameter dateString and uses the toLocalString() method of the date object to convert the given date into the DD/MM/YYYY format.
export default {
  // Function to format a date string as 'DD/MM/YYYY'
  formatDDMMYYYY: (dateString = '2023-03-08T09:45:15Z') => {
    const date = new Date(dateString);
    const options = {
      day: '2-digit',
      month: '2-digit',
      year: 'numeric',
    };
    return date.toLocaleString('en-GB', options);
  },
};
- Publish the JS module from top-right corner. This allows the changes to reflect on the app side.
If the package is git-connected, you also need to release a new version for the changes to be available. For more details, refer to Package Version Control.
Use JS module
Great job on creating a JS 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. 
- 
Select the JS tab on the Entity Explorer. 
- 
Click the + New JS object and add the formatDate JS module. 
- 
To use this JS module, from the UI tabs, drop a Table widget onto the canvas. 
- 
Connect the Table widget to the sample userdata.
- 
In the Table widget, open the created_atcolumn by clicking ⚙️ gear icon.
- 
In the Computed value property, add: 
{{formatDate1.formatDDMMYYYY(currentRow["created_at"])}}
The formatDate1 represents the module instance, and the number corresponds to the order in which the module was added.
This code formats all created_at column data into the DD/MM/YYYY format for each row in the data array.
With this, you can format dates using the JS module in multiple places throughout your application for consistent date formatting.
When you update and publish a package, these modifications automatically apply in the edit mode of the app. However, the live (deployed) version of the app remains unchanged until you redeploy the app.
If the package is git-connected, it continues to use the previous version until it is changed directly while editing the app.