linear-react-components-ui 1.1.22-beta.12 → 1.1.22-beta.14

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -34,7 +34,7 @@ const returnEventFormattedValue = (props, event) => {
34
34
  const value = props.defaultValue || '';
35
35
  return _objectSpread(_objectSpread({}, event), {}, {
36
36
  target: {
37
- value: (0, _format_number.numberToEnUS)(value),
37
+ value: String((0, _format_number.numberToEnUS)(value)),
38
38
  name
39
39
  }
40
40
  });
@@ -119,10 +119,10 @@ const BaseMask = _ref => {
119
119
  const {
120
120
  ref,
121
121
  setValue,
122
- setTypedValue,
122
+ setUnmaskedValue,
123
123
  maskRef
124
124
  } = (0, _reactImask.useIMask)(_objectSpread({}, maskOptions), {
125
- defaultValue: defaultValue,
125
+ defaultValue,
126
126
  onAccept: (_, r) => {
127
127
  if (!disableCallbacks && onChange) {
128
128
  const event = {
@@ -151,10 +151,13 @@ const BaseMask = _ref => {
151
151
  }
152
152
  });
153
153
  (0, _react.useEffect)(() => {
154
- if (typeof valueProp === 'number') {
155
- if (String(valueProp).trim().length > 0) setTypedValue(valueProp);else setTypedValue(0);
154
+ if (mask === Number || typeof valueProp === 'number') {
155
+ const updatedUnmaskedValue = (0, _format_number.numberToEnUS)(String(valueProp));
156
+ if (!Number.isNaN(updatedUnmaskedValue)) setUnmaskedValue(String(updatedUnmaskedValue));
157
+ return;
156
158
  }
157
- setValue((0, _format_number.numberToPtBR)(valueProp) ?? '');
159
+ const updatedValue = valueProp ? String(valueProp) : '';
160
+ setValue(updatedValue);
158
161
  }, [valueProp]);
159
162
  return /*#__PURE__*/_react.default.createElement(_InputTextBase.default, _extends({
160
163
  inputRef: r => {
@@ -30,7 +30,7 @@ const getMaskOptions = _ref => {
30
30
  pattern = '',
31
31
  radix = ' ',
32
32
  thousandsSeparator = '',
33
- mapToRadix = [],
33
+ mapToRadix = ['.'],
34
34
  scale = 2,
35
35
  normalizeZeros = true,
36
36
  padFractionalZeros = true,
@@ -29,7 +29,7 @@ const returnEventFormattedValue = (props, event) => {
29
29
  } = event.target;
30
30
  return _objectSpread(_objectSpread({}, event), {}, {
31
31
  target: {
32
- value: (0, _format_number.numberToEnUS)(value),
32
+ value: String((0, _format_number.numberToEnUS)(value)),
33
33
  name
34
34
  }
35
35
  });
@@ -67,10 +67,11 @@ const BaseNumber = _ref => {
67
67
  returnFormattedValueOnKeyDown: true
68
68
  });
69
69
  return /*#__PURE__*/_react.default.createElement(_BaseMask.default, _extends({
70
- value: (0, _format_number.numberToPtBR)(value ?? 0),
70
+ mask: Number,
71
+ value: value ?? 0,
71
72
  thousandsSeparator: ".",
72
73
  radix: ",",
73
- mask: Number,
74
+ mapToRadix: ['.'],
74
75
  isNumeric: true
75
76
  }, props, getEventProps(eventProps)));
76
77
  };
@@ -1,5 +1,5 @@
1
1
  declare const numberToPtBR: (value?: string | number) => string | undefined;
2
- declare const numberToEnUS: (value: string) => string | number;
2
+ declare const numberToEnUS: (value: string) => number;
3
3
  declare const formatOnlyNumbers: (value: string) => string;
4
4
 
5
5
  export { formatOnlyNumbers, numberToEnUS, numberToPtBR };
@@ -4,6 +4,7 @@ Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
6
  exports.numberToPtBR = exports.numberToEnUS = exports.formatOnlyNumbers = void 0;
7
+ const ptBRRegex = /\b\d{1,3}(?:\.\d{3})*,\d+\b/;
7
8
  const numberToPtBR = value => {
8
9
  if (value !== undefined && typeof value === 'number') {
9
10
  return value.toLocaleString('pt-BR');
@@ -13,11 +14,12 @@ const numberToPtBR = value => {
13
14
  exports.numberToPtBR = numberToPtBR;
14
15
  const numberToEnUS = value => {
15
16
  let formattedNumber;
16
- if (value) {
17
+ const isPTBR = ptBRRegex.test(value);
18
+ if (isPTBR) {
17
19
  formattedNumber = value.replaceAll('.', '').replaceAll(',', '.');
18
20
  return Number(formattedNumber);
19
21
  }
20
- return value;
22
+ return Number(value);
21
23
  };
22
24
  exports.numberToEnUS = numberToEnUS;
23
25
  const formatOnlyNumbers = value => {
@@ -12,7 +12,7 @@ import '../../@types/Icon.js';
12
12
  import '../../icons/helper.js';
13
13
 
14
14
  interface INumberFieldProps extends IMaskHOCProps {
15
- value?: string;
15
+ value?: string | number;
16
16
  permissionAttr?: PermissionAttr;
17
17
  disabled?: boolean;
18
18
  hint?: string | string[];
@@ -50,7 +50,7 @@ interface IInputHOCProps {
50
50
  }
51
51
  interface IMaskHOCProps {
52
52
  label?: string;
53
- value?: string;
53
+ value?: string | number;
54
54
  unmask?: boolean;
55
55
  name?: string;
56
56
  commit?: () => void;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "linear-react-components-ui",
3
- "version": "1.1.22-beta.12",
3
+ "version": "1.1.22-beta.14",
4
4
  "description": "Linear Sistemas ReactJs Components",
5
5
  "main": "lib/index.js",
6
6
  "module": "lib/index.cjs",