Using Vanilla JS
This guide shows how to create a simple Custom widget using vanilla JavaScript.
While Appsmith provides an extensive array of built-in widgets for application development, there are instances where your project demands a widget tailored to specific requirements. Appsmith's Custom widget allows you to integrate unique functionalities with your HTML, CSS, and JavaScript code, whether it's a personalized calendar, accordion, or social media widget.
Configure Custom Widget
- 
Drop a Custom widget on the canvas. 
- 
Click the Edit Source button to configure the code for the Custom widget. Within the Custom widget builder, you can add JS, CSS, and HTML code, and the Custom widget is displayed automatically on Appsmith. 
- 
In the Custom widget builder import the required libraries. 
To import a third-party library, you have two options: UMD and ESM. Use trusted CDN providers like jsDelivr or UNPKG for library imports.
- 
For UMD, include the library with a script tag in the HTML file: <script src="link-to-the-UMD-file"></script>
- 
For ESM, use an import statement at the top of the JavaScript file: import ThirdPartyComponent from "link-to-the-ESM-file";
- Add the code for the Custom widget within the relevant tabs based on your library requirements.
- 
Wait for the parent application to be ready before accessing the model or triggering events in the custom widget. Use appsmith.onReady and pass a handler function, which is triggered when the parent application is ready, initiating the rendering of your component from this function. 
- 
For dynamic updates in response to model changes, such as new data from a query, use appsmith.onModelChange. Pass a handler to this function, and it gets invoked each time the model undergoes a modification. 
In Vanilla JavaScript, you directly manipulate the DOM using methods like document.getElementById, document.createElement, etc.
Example: To build a simple calendar widget using the FullCalendar library, import the library and add the necessary code inside the onReady method.
- HTML
- JS
<div id="calendar"></div>
<!-- This serves as a container for the FullCalendar. -->
<!-- FullCalendar Library Script: -->
<script src="https://cdn.jsdelivr.net/npm/fullcalendar@6.1.10/index.global.min.js"></script>
<!-- Include the FullCalendar library from the specified CDN. -->
// Wait for the Appsmith platform to be ready before initiating the component
appsmith.onReady(() => {
  // Get the HTML element with the id 'calendar'
  const calendarEl = document.getElementById('calendar');
  // Create a new instance of FullCalendar and configure it
  const calendar = new FullCalendar.Calendar(calendarEl, {
    // Customize the header toolbar with navigation buttons and title
    headerToolbar: {
      left: 'prev,next today',
      center: 'title',
      right: ''
    }
  });
  // Render the calendar on the specified HTML element
  calendar.render();
});
Pass data from Appsmith to Custom widget
Follow these steps to pass parameters from Appsmith to the Custom widget:
- To pass data from Appsmith to the Custom widget, use the Default model property of Custom widget. You can bind data from queries or widgets using mustache bindings {{}}.
Example: For the calendar widget, you can pass relevant event data, like:
{
  "events": [
    {
      "title": "Custom widget review",
      "start": "2024-01-12",
      "id": "1"
    },
    {
      "title": "Weekly meeting",
      "start": "2024-01-13",
      "id": "2"
    }
]}
To bind data from a query or Table widget, you can add code like:
events: [
  { title: tbl_user.event, start: tbl_user.date },
  // Add more entries as needed
]
- 
To retrieve the data provided to the Default model property, use appsmith.model.propertyNamewithin the JavaScript section of the Custom widget builder.
Example: For the calendar widget, you can access the Default model data as follows:
appsmith.onReady(() => {
	const calendarEl = document.getElementById('calendar');
  const calendar = new FullCalendar.Calendar(calendarEl, {
    headerToolbar: {
      left: 'prev,next today',
      center: 'title',
      right: ''
    },
	events: appsmith.model.events   
  });
  calendar.render();
});
Pass data from Custom widget to Appsmith
Follow these steps to pass parameters from the Custom widget to Appsmith:
- To pass data from the Custom widget to Appsmith, use the updateModelproperty within your JS code to save or update data. Once the model is updated, you can retrieve the value using{{Custom.model.propertyname}}within any widget or query.
Example: To update the model with the selected date once an event has been clicked, add:
// JS
appsmith.onReady(() => {
  const calendarEl = document.getElementById('calendar');
  const calendar = new FullCalendar.Calendar(calendarEl, {
    headerToolbar: {
      left: 'prev,next today',
      center: 'title',
      right: ''
    },
    events: appsmith.model.events,
    eventClick: (e) => {
      appsmith.updateModel({
        selectedEvent: appsmith.model.events.find(d => d.id === e.event.id)
      });
    },
  });
  calendar.render();
});
To display data in a Text widget, set its Text property to:
{{Custom_cal.model.selectedEvent}}
//Custom_cal, name of the custom widget 
- For widget interaction, you can create events using the Add Event button on the Custom widget and use the triggerEventproperty inside the Custom widget builder.
Example: To show an alert when an event is clicked on the calendar widget, use the following code:
eventClick: (e) => {        
	 appsmith.triggerEvent("onSelected");
	appsmith.updateModel({                                  
		selectedEvent: appsmith.model.events.find(d => {    
			return d.id == e.event._def.publicId;              
		})                                                  
	})                                                      
}, 
In the Custom widget, create a new event with the same name as defined in the function, and configure it to execute an action.