I want to add validation for the email field in the Contacts app, however, I don't know what libraries should I import in my JS file. Also, how to edit the field validation using OWL.
Odoo is the world's easiest all-in-one management software.
 It includes hundreds of business apps:
- CRM
- e-Commerce
- Comptabilitat
- Inventari
- PoS
- Project
- MRP
This question has been flagged
Hello Khaled,
Here’s an example of how you can add a simple validation for the email field in the Contacts app using OWL. You don’t need any extra libraries; OWL and the web client utilities are already available in Odoo.
/** @odoo-module **/
import { CharField } from "@web/views/fields/char/char_field";
import { patch } from "@web/core/utils/patch";
patch(CharField.prototype, "email_validation_patch", {
async onInput(ev) {
await super.onInput(ev);
if (this.props.name === "email") {
const value = ev.target.value || "";
const emailPattern = /^[^\s@]+@[^\s@]+\.[^\s@]+$/;
const isValid = emailPattern.test(value);
if (!isValid && value) {
this.notification.add("Please enter a valid email address.", { type: "warning" });
ev.target.classList.add("o_invalid_field");
} else {
ev.target.classList.remove("o_invalid_field");
}
}
},
});
Add this file under your custom module path:
/static/src/js/email_validation.js
Then include it in your manifest file:
'assets': {
'web.assets_backend': [
'/your_module/static/src/js/email_validation.js',
],
},
After updating and reloading, the email field will show a warning message when the format is invalid.
Hi,
The error occurs because your pos_data_loader.js is importing @point_of_sale/app/store/pos_global_state, which exists only in Odoo 19, not Odoo 18. In Odoo 18, the equivalent is point_of_sale.models or PosModel, and your code should patch its prototype instead. Additionally, your custom JS must be included in the point_of_sale.assets bundle in your module manifest. Using Odoo 19 import paths in Odoo 18 causes unmet dependency errors, so adapting the imports and ensuring proper asset inclusion will resolve the issue.
Try the following code,
/** @odoo-module **/
import { patch } from "web.utils";
import PosModel from "point_of_sale.models"; // <-- Correct path for v18
console.log("PSMS: Extending POS data models for Odoo 18");
patch(PosModel.prototype, "psms_pos_data_loader", {
async _load_data() {
console.log("PSMS: _load_data running...");
await super._load_data();
const orm = this.env.services.orm;
if (!orm) return;
const configs = await orm.searchRead("pos.config", [], [
"id", "name", "display_stock", "nozzle_ids", "pump_ids", "tanks_ids"
]);
const currentConfigId = this.config_id;
const currentConfig = configs.find(c => c.id === currentConfigId);
if (!currentConfig) return;
this.display_stock = currentConfig.display_stock;
this.nozzle_ids = currentConfig.nozzle_ids || [];
this.pump_ids = currentConfig.pump_ids || [];
this.tanks_ids = currentConfig.tanks_ids || [];
console.log(" POS CONFIG", this);
// Load nozzle data if any
if (this.nozzle_ids.length) {
const nozzles = await orm.searchRead("petrol.nozzle", [["id", "in", this.nozzle_ids]], [
"id", "name", "pump_id", "tank_id", "product_id"
]);
this.db.nozzle_by_id = {};
for (const nozzle of nozzles) this.db.nozzle_by_id[nozzle.id] = nozzle;
console.log(` PSMS: Loaded ${nozzles.length} nozzles for this POS`);
}
}
});
Hope it helps
Enjoying the discussion? Don't just read, join in!
Create an account today to enjoy exclusive features and engage with our awesome community!
Registrar-se| Related Posts | Respostes | Vistes | Activitat | |
|---|---|---|---|---|
|  | 0 de gen. 25  | 1646 | ||
|  | 0 de set. 23  | 3576 | ||
|  | 2 d’ag. 23  | 12184 | ||
|  | 0 d’ag. 23  | 194 | ||
|  | 1 de maig 23  | 2780 | 
