@data-driven-forms/mui-component-mapper 3.20.1 → 3.20.2

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.
@@ -10,7 +10,7 @@ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (O
10
10
 
11
11
  function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
12
12
 
13
- import React from 'react';
13
+ import React, { useMemo } from 'react';
14
14
  import PropTypes from 'prop-types';
15
15
  import FormFieldGrid from '../form-field-grid/form-field-grid';
16
16
  import { validationError } from '../validation-error/validation-error';
@@ -103,8 +103,12 @@ var InternalSelect = function InternalSelect(_ref2) {
103
103
  isDisabled = _ref2.isDisabled,
104
104
  rest = _objectWithoutProperties(_ref2, _excluded2);
105
105
 
106
- var invalid = validationError(meta, validateOnMount);
107
- var internalValue = parseInternalValue(value, isMulti);
106
+ var invalid = validationError(meta, validateOnMount); // When isMulti is true, the "parseInternalValue" always creates new value array, we need to memoize it to not create new array instance
107
+ // Memo is required to fix https://github.com/data-driven-forms/react-forms/issues/1366
108
+
109
+ var internalValue = useMemo(function () {
110
+ return parseInternalValue(value, isMulti);
111
+ }, [value, isMulti]);
108
112
  return /*#__PURE__*/React.createElement(FormFieldGrid, FormFieldGridProps, /*#__PURE__*/React.createElement(Autocomplete, _extends({
109
113
  filterSelectedOptions: hideSelectedOptions,
110
114
  disabled: isDisabled,
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@data-driven-forms/mui-component-mapper",
3
- "version": "3.20.1",
3
+ "version": "3.20.2",
4
4
  "description": "Component mapper for Material ui component mapper form data-driven-forms.",
5
5
  "main": "index.js",
6
6
  "module": "esm/index.js",
@@ -29,7 +29,7 @@
29
29
  "@mui/material": "^5.10.4"
30
30
  },
31
31
  "peerDependencies": {
32
- "@data-driven-forms/react-form-renderer": "^3.20.1",
32
+ "@data-driven-forms/react-form-renderer": "^3.20.2",
33
33
  "@mui/icons-material": "^5.10.3",
34
34
  "@mui/material": "^5.10.4",
35
35
  "prop-types": ">=15.7.2",
@@ -37,7 +37,7 @@
37
37
  "react-dom": "^17.0.2 || ^18.0.0"
38
38
  },
39
39
  "dependencies": {
40
- "@data-driven-forms/common": "^3.20.1",
40
+ "@data-driven-forms/common": "^3.20.2",
41
41
  "@emotion/react": "^11.10.4",
42
42
  "@emotion/styled": "^11.10.4",
43
43
  "@mui/system": "^5.10.4",
package/select/select.js CHANGED
@@ -2,6 +2,8 @@
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
4
 
5
+ var _typeof3 = require("@babel/runtime/helpers/typeof");
6
+
5
7
  Object.defineProperty(exports, "__esModule", {
6
8
  value: true
7
9
  });
@@ -15,7 +17,7 @@ var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/h
15
17
 
16
18
  var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
17
19
 
18
- var _react = _interopRequireDefault(require("react"));
20
+ var _react = _interopRequireWildcard(require("react"));
19
21
 
20
22
  var _propTypes = _interopRequireDefault(require("prop-types"));
21
23
 
@@ -43,6 +45,10 @@ var _excluded = ["inputProps"],
43
45
  _excluded2 = ["value", "options", "label", "helperText", "validateOnMount", "meta", "isSearchable", "description", "classNamePrefix", "isMulti", "placeholder", "onInputChange", "isFetching", "noOptionsMessage", "hideSelectedOptions", "closeMenuOnSelect", "required", "onChange", "onFocus", "onBlur", "FormFieldGridProps", "TextFieldProps", "inputProps", "isClearable", "isDisabled"],
44
46
  _excluded3 = ["input", "isRequired", "isDisabled", "isReadOnly", "disabled", "multiple", "isMulti", "isClearable", "disableClearable", "loadingMessage", "loadingText", "noOptionsMessage", "noOptionsText", "closeMenuOnSelect"];
45
47
 
48
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
49
+
50
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof3(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
51
+
46
52
  function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
47
53
 
48
54
  function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
@@ -129,8 +135,12 @@ var InternalSelect = function InternalSelect(_ref2) {
129
135
  isClearable = _ref2.isClearable,
130
136
  isDisabled = _ref2.isDisabled,
131
137
  rest = (0, _objectWithoutProperties2["default"])(_ref2, _excluded2);
132
- var invalid = (0, _validationError.validationError)(meta, validateOnMount);
133
- var internalValue = (0, _parseInternalValue["default"])(value, isMulti);
138
+ var invalid = (0, _validationError.validationError)(meta, validateOnMount); // When isMulti is true, the "parseInternalValue" always creates new value array, we need to memoize it to not create new array instance
139
+ // Memo is required to fix https://github.com/data-driven-forms/react-forms/issues/1366
140
+
141
+ var internalValue = (0, _react.useMemo)(function () {
142
+ return (0, _parseInternalValue["default"])(value, isMulti);
143
+ }, [value, isMulti]);
134
144
  return /*#__PURE__*/_react["default"].createElement(_formFieldGrid["default"], FormFieldGridProps, /*#__PURE__*/_react["default"].createElement(_Autocomplete["default"], (0, _extends2["default"])({
135
145
  filterSelectedOptions: hideSelectedOptions,
136
146
  disabled: isDisabled,