Systray is the top navbar of Odoo interface. The main objective of systray is to give quick access to important functionalities with a single click. In Odoo, the default icons include a drop-down list linked to the installed username and the app launcher icon. However, the systray can be customized.
The marked space shown in the below screenshot is the systray.
data:image/s3,"s3://crabby-images/00a7a/00a7ac844fb816030335930668c260b960804fe4" alt="how-to-add-an-icon-in-systray-in-odoo-15"
Let’s look at how we can add an icon to the systray.
First, let’s make the view for the icon to show in the systray.
<?xml version="1.0" encoding="UTF-8" ?>
<templates>
<t t-name="SaleOrderSystray">
<div class="new_icon">
<div class="icon_div">
<div class="toggle-icon" role="button">
<i id='create_so' class="fa fa-plus-square-o" role="img" aria-label="Create Sale Order"/>
</div>
</div>
</div>
</t>
</templates>
The above template will add a square plus button to the systray. While clicking on the square plus button you will get a popup wizard to create a new sale order.
After adding the template to show the icon in the systray menu we also need to add some javascript code.
/** @odoo-module **/
import SystrayMenu from 'web.SystrayMenu';
import Widget from 'web.Widget';
var ExampleWidget = Widget.extend({
template: 'SaleOrderSystray',
events: {
'click #create_so': '_onClick',
},
_onClick: function(){
this.do_action({
type: 'ir.actions.act_window',
name: 'Sale Order',
res_model: 'sale.order',
view_mode: 'form',
views: [[false, 'form']],
target: 'new'
});
},
});
SystrayMenu.Items.push(ExampleWidget);
export default ExampleWidget;
First import the Widget and SystrayMenu classes. Then we need to extend the Widget class to create a new widget for our systray icon. Widgets are the most important tools to build a user interface in Odoo. Then we can specify the template or user interface of the widget. We can add events like click change etc… Here I have added a click event for the square plus icon which has an id of create_so. On that event, I gave a do_action to call the sale order.form.
After creating the javascript and XML templates we need to add them in the manifest file like below.
'assets': {
'web.assets_backend': {
'/systray_blog/static/src/js/systray.js',
},
'web.assets_qweb': {
'/systray_blog/static/src/xml/systray.xml',
},
},
After installing the module you can see the square plus button on the systray menu.
data:image/s3,"s3://crabby-images/2710a/2710a3e086d27b533575a6299c309946dc20bd2d" alt="how-to-add-an-icon-in-systray-in-odoo-15"
On clicking on the square plus icon the sale form will open as a popup.
data:image/s3,"s3://crabby-images/59893/598939fd5db86e1ce8252614a4fb29451ab90ffb" alt="how-to-add-an-icon-in-systray-in-odoo-15"
After the sale order form popups, you can fill the fields and you can save, discard, confirm or send the sale order by email from there.
data:image/s3,"s3://crabby-images/9d3a7/9d3a76e1cdd2d2d149eb9467d175a3bf89d7f2f6" alt="how-to-add-an-icon-in-systray-in-odoo-15"
After saving the sale order you can confirm or do anything that you can do on normal sale order in Odoo.