OWL
forms
Float Field
Odoo 19 OWL component — Float Field (views)
Live preview
Interactive
Source excerpt
web/static/src/views/fields/float/float_field.js
import { _t } from "@web/core/l10n/translation";
import { registry } from "@web/core/registry";
import { useInputField } from "../input_field_hook";
import { useNumpadDecimal } from "../numpad_decimal_hook";
import { formatFloat } from "../formatters";
import { parseFloat } from "../parsers";
import { standardFieldProps } from "../standard_field_props";
import { Component, useState } from "@odoo/owl";
export class FloatField extends Component {
static template = "web.FloatField";
static props = {
...standardFieldProps,
formatNumber: { type: Boolean, optional: true },
inputType: { type: String, optional: true },
step: { type: Number, optional: true },
digits: { type: Array, optional: true },
minDigits: {type: Number, optional: true },
humanReadable: { type: Boolean, optional: true },
decimals: { type: Number, optional: true },
trailingZeros: { type: Boolean, optional: true },
};
static defaultProps = {
formatNumber: true,
inputType: "text",
humanReadable: false,
decimals: 0,
trailingZeros: true,
};
setup() {
this.state = useState({
hasFocus: false,
});
this.inputRef = useInputField({
getValue: () => this.formattedValue,
refName: "numpadDecimal",
parse: (v) => this.parse(v),
});
useNumpadDecimal();
}
onFocusIn() {
this.state.hasFocus = true;
}
onFocusOut() {
this.state.hasFocus = false;
}
parse(value) {
return this.props.inputType === "number"
? Number(value)
: parseFloat(value, { allowOperation: true });
}
get formattedValue() {
if (
!this.props.formatNumber ||
(this.props.inputType === "number" && !this.props.readonly && this.value)
) {
return this.value;
}
const options = {
digits: this.props.digits,
minDigits: this.props.minDigits,
field: this.props.record.fields[this.props.name],
trailingZeros: this.props.trailingZeros,
};
if (this.props.humanReadable && !this.state.hasFocus) {
return formatFloat(this.value, {
...options,
humanReadable: true,
decimals: this.props.decimals,
});
} else {
return formatFloat(this.value, { ...options, humanReadable: false });
}
}
get value() {
return this.props.record.data[this.props.name];
}
}
export const floatField = {
component: FloatField,
displayName: _t("Float"),
supportedOptions: [
{
label: _t("Format number"),
name: "enable_formatting",
type: "boolean",
help: _t(
"Format the value according to your language setup - e.g. thousand separators, rounding, etc."
),
default: true,
},
{
label: _t("Digits"),
name: "digits",
type: "digits",
},
{
label: _t("Minimum Digits"),
name: "minDigits",
type: "digits",
},
{
label: _t("Type"),
name: "type",
type: "string",
},
{
label: _t("Step"),
name: "step",
type: "number",
},
{
Registry / API
- Registry name
FloatField- Category
—- Module
web- Slug
float-field- Nav group
forms