import React from "react"; import styles from "./index.less"; import { Input, Tooltip } from "antd"; function formatNumber(value) { value += ""; const list = value.split("."); const prefix = list[0].charAt(0) === "-" ? "-" : ""; let num = prefix ? list[0].slice(1) : list[0]; let result = ""; while (num.length > 3) { result = `,${num.slice(-3)}${result}`; num = num.slice(0, num.length - 3); } if (num) { result = num + result; } return `${prefix}${result}${list[1] ? `.${list[1]}` : ""}`; } class NumericInput extends React.Component { onChange = e => { const { value } = e.target; const reg = /^-?[0-9]*(\.[0-9]*)?$/; if ((!isNaN(value) && reg.test(value)) || value === "" || value === "-") { this.props.onChange(value); } }; // '.' at the end or only '-' in the input box. onBlur = () => { const { value, onBlur, onChange } = this.props; let valueTemp = value; if (value.charAt(value.length - 1) === "." || value === "-") { valueTemp = value.slice(0, -1); } onChange(valueTemp.replace(/0*(\d+)/, "$1")); if (onBlur) { onBlur(); } }; render() { const { value } = this.props; const title = value ? ( {value !== "-" ? formatNumber(value) : "-"} ) : ( "Input a number" ); return ( ); } } class NumericInputDemo extends React.Component { constructor(props) { super(props); this.state = { value: "" }; } onChange = value => { this.setState({ value }); }; render() { return ( ); } } export default () => (
);