@commercetools-uikit/localized-multiline-text-input 15.8.0 → 15.10.0
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.
- package/dist/commercetools-uikit-localized-multiline-text-input.cjs.dev.js +40 -50
- package/dist/commercetools-uikit-localized-multiline-text-input.cjs.prod.js +22 -25
- package/dist/commercetools-uikit-localized-multiline-text-input.esm.js +40 -49
- package/dist/declarations/src/localized-multiline-text-input.d.ts +1 -1
- package/dist/declarations/src/translation-input.d.ts +2 -2
- package/dist/declarations/src/translation-input.styles.d.ts +4 -2
- package/package.json +14 -14
|
@@ -17,18 +17,17 @@ var _Object$keys = require('@babel/runtime-corejs3/core-js-stable/object/keys');
|
|
|
17
17
|
var _mapInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/map');
|
|
18
18
|
var react$1 = require('react');
|
|
19
19
|
var reactIntl = require('react-intl');
|
|
20
|
-
var react = require('@emotion/react');
|
|
21
20
|
var hooks = require('@commercetools-uikit/hooks');
|
|
22
21
|
var Stack = require('@commercetools-uikit/spacings-stack');
|
|
23
22
|
var Constraints = require('@commercetools-uikit/constraints');
|
|
24
23
|
var localizedUtils = require('@commercetools-uikit/localized-utils');
|
|
25
24
|
var inputUtils = require('@commercetools-uikit/input-utils');
|
|
26
25
|
var _styled = require('@emotion/styled/base');
|
|
26
|
+
var react = require('@emotion/react');
|
|
27
27
|
var FlatButton = require('@commercetools-uikit/flat-button');
|
|
28
28
|
var icons = require('@commercetools-uikit/icons');
|
|
29
29
|
var utils = require('@commercetools-uikit/utils');
|
|
30
30
|
var designSystem = require('@commercetools-uikit/design-system');
|
|
31
|
-
var Text = require('@commercetools-uikit/text');
|
|
32
31
|
var jsxRuntime = require('@emotion/react/jsx-runtime');
|
|
33
32
|
var messages = require('@commercetools-uikit/messages');
|
|
34
33
|
|
|
@@ -49,21 +48,20 @@ var Stack__default = /*#__PURE__*/_interopDefault(Stack);
|
|
|
49
48
|
var Constraints__default = /*#__PURE__*/_interopDefault(Constraints);
|
|
50
49
|
var _styled__default = /*#__PURE__*/_interopDefault(_styled);
|
|
51
50
|
var FlatButton__default = /*#__PURE__*/_interopDefault(FlatButton);
|
|
52
|
-
var Text__default = /*#__PURE__*/_interopDefault(Text);
|
|
53
51
|
|
|
54
|
-
function _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
52
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__$1() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
55
53
|
// * a disabled-field currently does not display warning/error-states so it takes precedence
|
|
56
54
|
// * a readonly-field cannot be changed, but it might be relevant for validation, so error and warning are checked first
|
|
57
55
|
// how you can interact with the field is controlled separately by the props, this only influences visuals
|
|
58
56
|
|
|
59
|
-
var _ref$
|
|
57
|
+
var _ref$1 = process.env.NODE_ENV === "production" ? {
|
|
60
58
|
name: "d3v9zr",
|
|
61
59
|
styles: "overflow:hidden"
|
|
62
60
|
} : {
|
|
63
61
|
name: "1h6gnzr-baseStyles",
|
|
64
62
|
styles: "overflow:hidden;label:baseStyles;",
|
|
65
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
66
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
63
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRyYW5zbGF0aW9uLWlucHV0LnN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFzQlMiLCJmaWxlIjoidHJhbnNsYXRpb24taW5wdXQuc3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5cbi8vIE5PVEU6IG9yZGVyIGlzIGltcG9ydGFudCBoZXJlXG4vLyAqIGEgZGlzYWJsZWQtZmllbGQgY3VycmVudGx5IGRvZXMgbm90IGRpc3BsYXkgd2FybmluZy9lcnJvci1zdGF0ZXMgc28gaXQgdGFrZXMgcHJlY2VkZW5jZVxuLy8gKiBhIHJlYWRvbmx5LWZpZWxkIGNhbm5vdCBiZSBjaGFuZ2VkLCBidXQgaXQgbWlnaHQgYmUgcmVsZXZhbnQgZm9yIHZhbGlkYXRpb24sIHNvIGVycm9yIGFuZCB3YXJuaW5nIGFyZSBjaGVja2VkIGZpcnN0XG4vLyBob3cgeW91IGNhbiBpbnRlcmFjdCB3aXRoIHRoZSBmaWVsZCBpcyBjb250cm9sbGVkIHNlcGFyYXRlbHkgYnkgdGhlIHByb3BzLCB0aGlzIG9ubHkgaW5mbHVlbmNlcyB2aXN1YWxzXG5cbnR5cGUgVFRyYW5zbGF0aW9uSW5wdXRTdHlsZXNQcm9wcyA9IHtcbiAgaXNDb2xsYXBzZWQ/OiBib29sZWFuO1xuICBpc0Rpc2FibGVkPzogYm9vbGVhbjtcbiAgaXNSZWFkT25seT86IGJvb2xlYW47XG59O1xuXG5jb25zdCBnZXRUZXh0YXJlYVN0eWxlcyA9IChwcm9wczogVFRyYW5zbGF0aW9uSW5wdXRTdHlsZXNQcm9wcykgPT4ge1xuICBjb25zdCBiYXNlU3R5bGVzID0gW1xuICAgIGNzc2BcbiAgICAgIGJvcmRlci10b3AtbGVmdC1yYWRpdXM6IDAgIWltcG9ydGFudDtcbiAgICAgIGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6IDAgIWltcG9ydGFudDtcbiAgICBgLFxuICAgIHByb3BzLmlzQ29sbGFwc2VkICYmXG4gICAgICBjc3NgXG4gICAgICAgIG92ZXJmbG93OiBoaWRkZW47XG4gICAgICBgLFxuICBdO1xuICByZXR1cm4gYmFzZVN0eWxlcztcbn07XG5cbmNvbnN0IGdldExhbmd1YWdlTGFiZWxCYWNrZ3JvdW5kQ29sb3IgPSAocHJvcHM6IFRUcmFuc2xhdGlvbklucHV0U3R5bGVzUHJvcHMpID0+XG4gIHByb3BzLmlzRGlzYWJsZWRcbiAgICA/IGRlc2lnblRva2Vucy5iYWNrZ3JvdW5kQ29sb3JGb3JMb2NhbGl6ZWRNdWx0aWxpbmVUZXh0SW5wdXRMYWJlbFdoZW5EaXNhYmxlZFxuICAgIDogZGVzaWduVG9rZW5zLmJhY2tncm91bmRDb2xvckZvckxvY2FsaXplZE11bHRpbGluZVRleHRJbnB1dExhYmVsO1xuXG5jb25zdCBnZXRMYW5ndWFnZUxhYmVsQm9yZGVyQ29sb3IgPSAocHJvcHM6IFRUcmFuc2xhdGlvbklucHV0U3R5bGVzUHJvcHMpID0+XG4gIHByb3BzLmlzUmVhZE9ubHlcbiAgICA/IGRlc2lnblRva2Vucy5ib3JkZXJDb2xvckZvckxvY2FsaXplZE11bHRpbGluZVRleHRJbnB1dExhYmVsV2hlblJlYWRvbmx5XG4gICAgOiBkZXNpZ25Ub2tlbnMuYm9yZGVyQ29sb3JGb3JMb2NhbGl6ZWRNdWx0aWxpbmVUZXh0SW5wdXRMYWJlbDtcblxuY29uc3QgZ2V0TGFuZ3VhZ2VMYWJlbFN0eWxlcyA9IChwcm9wczogVFRyYW5zbGF0aW9uSW5wdXRTdHlsZXNQcm9wcykgPT4ge1xuICByZXR1cm4gY3NzYFxuICAgIC8qIGF2b2lkIHdyYXBwaW5nIGxhYmVsIG9udG8gbmV3IGxpbmVzICovXG4gICAgZmxleDogMSAwIGF1dG87XG4gICAgY29sb3I6ICR7ZGVzaWduVG9rZW5zLmZvbnRDb2xvckZvckxvY2FsaXplZE11bHRpbGluZVRleHRJbnB1dExhYmVsfTtcbiAgICBsaW5lLWhlaWdodDogY2FsYyhcbiAgICAgICR7ZGVzaWduVG9rZW5zLmhlaWdodEZvcklucHV0fSAtIDIgKiAke2Rlc2lnblRva2Vucy5ib3JkZXJSYWRpdXMxfVxuICAgICk7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHtnZXRMYW5ndWFnZUxhYmVsQmFja2dyb3VuZENvbG9yKHByb3BzKX07XG4gICAgYm9yZGVyLXRvcC1sZWZ0LXJhZGl1czogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzRm9ySW5wdXR9O1xuICAgIGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6ICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1c0ZvcklucHV0fTtcbiAgICBib3JkZXI6IDFweCAke2dldExhbmd1YWdlTGFiZWxCb3JkZXJDb2xvcihwcm9wcyl9IHNvbGlkO1xuICAgIHBhZGRpbmc6ICR7ZGVzaWduVG9rZW5zLnBhZGRpbmdGb3JMb2NhbGl6ZWRNdWx0aWxpbmVUZXh0SW5wdXRMYWJlbH07XG4gICAgZm9udC1zaXplOiAke2Rlc2lnblRva2Vucy5mb250U2l6ZUZvckxvY2FsaXplZE11bHRpbGluZVRleHRJbnB1dExhYmVsfTtcbiAgICB0cmFuc2l0aW9uOiBib3JkZXItY29sb3IgJHtkZXNpZ25Ub2tlbnMudHJhbnNpdGlvblN0YW5kYXJkfSxcbiAgICAgIGJhY2tncm91bmQtY29sb3IgJHtkZXNpZ25Ub2tlbnMudHJhbnNpdGlvblN0YW5kYXJkfSxcbiAgICAgIGNvbG9yICR7ZGVzaWduVG9rZW5zLnRyYW5zaXRpb25TdGFuZGFyZH07XG4gICAgYm9yZGVyLXJpZ2h0OiAwO1xuICAgIGJveC1zaGFkb3c6IG5vbmU7XG4gICAgYXBwZWFyYW5jZTogbm9uZTtcbiAgYDtcbn07XG5cbmNvbnN0IFRvZ2dsZUJ1dHRvbldyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBmbGV4OiAwO1xuICBkaXNwbGF5OiBmbGV4O1xuYDtcblxuZXhwb3J0IHsgZ2V0VGV4dGFyZWFTdHlsZXMsIGdldExhbmd1YWdlTGFiZWxTdHlsZXMsIFRvZ2dsZUJ1dHRvbldyYXBwZXIgfTtcbiJdfQ== */",
|
|
64
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
|
|
67
65
|
};
|
|
68
66
|
|
|
69
67
|
var _ref2 = process.env.NODE_ENV === "production" ? {
|
|
@@ -72,17 +70,25 @@ var _ref2 = process.env.NODE_ENV === "production" ? {
|
|
|
72
70
|
} : {
|
|
73
71
|
name: "pb9fe4-baseStyles",
|
|
74
72
|
styles: "border-top-left-radius:0!important;border-bottom-left-radius:0!important;label:baseStyles;",
|
|
75
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
76
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
73
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRyYW5zbGF0aW9uLWlucHV0LnN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFpQk8iLCJmaWxlIjoidHJhbnNsYXRpb24taW5wdXQuc3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5cbi8vIE5PVEU6IG9yZGVyIGlzIGltcG9ydGFudCBoZXJlXG4vLyAqIGEgZGlzYWJsZWQtZmllbGQgY3VycmVudGx5IGRvZXMgbm90IGRpc3BsYXkgd2FybmluZy9lcnJvci1zdGF0ZXMgc28gaXQgdGFrZXMgcHJlY2VkZW5jZVxuLy8gKiBhIHJlYWRvbmx5LWZpZWxkIGNhbm5vdCBiZSBjaGFuZ2VkLCBidXQgaXQgbWlnaHQgYmUgcmVsZXZhbnQgZm9yIHZhbGlkYXRpb24sIHNvIGVycm9yIGFuZCB3YXJuaW5nIGFyZSBjaGVja2VkIGZpcnN0XG4vLyBob3cgeW91IGNhbiBpbnRlcmFjdCB3aXRoIHRoZSBmaWVsZCBpcyBjb250cm9sbGVkIHNlcGFyYXRlbHkgYnkgdGhlIHByb3BzLCB0aGlzIG9ubHkgaW5mbHVlbmNlcyB2aXN1YWxzXG5cbnR5cGUgVFRyYW5zbGF0aW9uSW5wdXRTdHlsZXNQcm9wcyA9IHtcbiAgaXNDb2xsYXBzZWQ/OiBib29sZWFuO1xuICBpc0Rpc2FibGVkPzogYm9vbGVhbjtcbiAgaXNSZWFkT25seT86IGJvb2xlYW47XG59O1xuXG5jb25zdCBnZXRUZXh0YXJlYVN0eWxlcyA9IChwcm9wczogVFRyYW5zbGF0aW9uSW5wdXRTdHlsZXNQcm9wcykgPT4ge1xuICBjb25zdCBiYXNlU3R5bGVzID0gW1xuICAgIGNzc2BcbiAgICAgIGJvcmRlci10b3AtbGVmdC1yYWRpdXM6IDAgIWltcG9ydGFudDtcbiAgICAgIGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6IDAgIWltcG9ydGFudDtcbiAgICBgLFxuICAgIHByb3BzLmlzQ29sbGFwc2VkICYmXG4gICAgICBjc3NgXG4gICAgICAgIG92ZXJmbG93OiBoaWRkZW47XG4gICAgICBgLFxuICBdO1xuICByZXR1cm4gYmFzZVN0eWxlcztcbn07XG5cbmNvbnN0IGdldExhbmd1YWdlTGFiZWxCYWNrZ3JvdW5kQ29sb3IgPSAocHJvcHM6IFRUcmFuc2xhdGlvbklucHV0U3R5bGVzUHJvcHMpID0+XG4gIHByb3BzLmlzRGlzYWJsZWRcbiAgICA/IGRlc2lnblRva2Vucy5iYWNrZ3JvdW5kQ29sb3JGb3JMb2NhbGl6ZWRNdWx0aWxpbmVUZXh0SW5wdXRMYWJlbFdoZW5EaXNhYmxlZFxuICAgIDogZGVzaWduVG9rZW5zLmJhY2tncm91bmRDb2xvckZvckxvY2FsaXplZE11bHRpbGluZVRleHRJbnB1dExhYmVsO1xuXG5jb25zdCBnZXRMYW5ndWFnZUxhYmVsQm9yZGVyQ29sb3IgPSAocHJvcHM6IFRUcmFuc2xhdGlvbklucHV0U3R5bGVzUHJvcHMpID0+XG4gIHByb3BzLmlzUmVhZE9ubHlcbiAgICA/IGRlc2lnblRva2Vucy5ib3JkZXJDb2xvckZvckxvY2FsaXplZE11bHRpbGluZVRleHRJbnB1dExhYmVsV2hlblJlYWRvbmx5XG4gICAgOiBkZXNpZ25Ub2tlbnMuYm9yZGVyQ29sb3JGb3JMb2NhbGl6ZWRNdWx0aWxpbmVUZXh0SW5wdXRMYWJlbDtcblxuY29uc3QgZ2V0TGFuZ3VhZ2VMYWJlbFN0eWxlcyA9IChwcm9wczogVFRyYW5zbGF0aW9uSW5wdXRTdHlsZXNQcm9wcykgPT4ge1xuICByZXR1cm4gY3NzYFxuICAgIC8qIGF2b2lkIHdyYXBwaW5nIGxhYmVsIG9udG8gbmV3IGxpbmVzICovXG4gICAgZmxleDogMSAwIGF1dG87XG4gICAgY29sb3I6ICR7ZGVzaWduVG9rZW5zLmZvbnRDb2xvckZvckxvY2FsaXplZE11bHRpbGluZVRleHRJbnB1dExhYmVsfTtcbiAgICBsaW5lLWhlaWdodDogY2FsYyhcbiAgICAgICR7ZGVzaWduVG9rZW5zLmhlaWdodEZvcklucHV0fSAtIDIgKiAke2Rlc2lnblRva2Vucy5ib3JkZXJSYWRpdXMxfVxuICAgICk7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHtnZXRMYW5ndWFnZUxhYmVsQmFja2dyb3VuZENvbG9yKHByb3BzKX07XG4gICAgYm9yZGVyLXRvcC1sZWZ0LXJhZGl1czogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzRm9ySW5wdXR9O1xuICAgIGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6ICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1c0ZvcklucHV0fTtcbiAgICBib3JkZXI6IDFweCAke2dldExhbmd1YWdlTGFiZWxCb3JkZXJDb2xvcihwcm9wcyl9IHNvbGlkO1xuICAgIHBhZGRpbmc6ICR7ZGVzaWduVG9rZW5zLnBhZGRpbmdGb3JMb2NhbGl6ZWRNdWx0aWxpbmVUZXh0SW5wdXRMYWJlbH07XG4gICAgZm9udC1zaXplOiAke2Rlc2lnblRva2Vucy5mb250U2l6ZUZvckxvY2FsaXplZE11bHRpbGluZVRleHRJbnB1dExhYmVsfTtcbiAgICB0cmFuc2l0aW9uOiBib3JkZXItY29sb3IgJHtkZXNpZ25Ub2tlbnMudHJhbnNpdGlvblN0YW5kYXJkfSxcbiAgICAgIGJhY2tncm91bmQtY29sb3IgJHtkZXNpZ25Ub2tlbnMudHJhbnNpdGlvblN0YW5kYXJkfSxcbiAgICAgIGNvbG9yICR7ZGVzaWduVG9rZW5zLnRyYW5zaXRpb25TdGFuZGFyZH07XG4gICAgYm9yZGVyLXJpZ2h0OiAwO1xuICAgIGJveC1zaGFkb3c6IG5vbmU7XG4gICAgYXBwZWFyYW5jZTogbm9uZTtcbiAgYDtcbn07XG5cbmNvbnN0IFRvZ2dsZUJ1dHRvbldyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBmbGV4OiAwO1xuICBkaXNwbGF5OiBmbGV4O1xuYDtcblxuZXhwb3J0IHsgZ2V0VGV4dGFyZWFTdHlsZXMsIGdldExhbmd1YWdlTGFiZWxTdHlsZXMsIFRvZ2dsZUJ1dHRvbldyYXBwZXIgfTtcbiJdfQ== */",
|
|
74
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
|
|
77
75
|
};
|
|
78
76
|
|
|
79
77
|
var getTextareaStyles = function getTextareaStyles(props) {
|
|
80
|
-
var baseStyles = [_ref2, props.isCollapsed && _ref$
|
|
78
|
+
var baseStyles = [_ref2, props.isCollapsed && _ref$1];
|
|
81
79
|
return baseStyles;
|
|
82
80
|
};
|
|
83
81
|
|
|
84
|
-
var
|
|
85
|
-
return
|
|
82
|
+
var getLanguageLabelBackgroundColor = function getLanguageLabelBackgroundColor(props) {
|
|
83
|
+
return props.isDisabled ? designSystem.designTokens.backgroundColorForLocalizedMultilineTextInputLabelWhenDisabled : designSystem.designTokens.backgroundColorForLocalizedMultilineTextInputLabel;
|
|
84
|
+
};
|
|
85
|
+
|
|
86
|
+
var getLanguageLabelBorderColor = function getLanguageLabelBorderColor(props) {
|
|
87
|
+
return props.isReadOnly ? designSystem.designTokens.borderColorForLocalizedMultilineTextInputLabelWhenReadonly : designSystem.designTokens.borderColorForLocalizedMultilineTextInputLabel;
|
|
88
|
+
};
|
|
89
|
+
|
|
90
|
+
var getLanguageLabelStyles = function getLanguageLabelStyles(props) {
|
|
91
|
+
return /*#__PURE__*/react.css("flex:1 0 auto;color:", designSystem.designTokens.fontColorForLocalizedMultilineTextInputLabel, ";line-height:calc(\n ", designSystem.designTokens.heightForInput, " - 2 * ", designSystem.designTokens.borderRadius1, "\n );background-color:", getLanguageLabelBackgroundColor(props), ";border-top-left-radius:", designSystem.designTokens.borderRadiusForInput, ";border-bottom-left-radius:", designSystem.designTokens.borderRadiusForInput, ";border:1px ", getLanguageLabelBorderColor(props), " solid;padding:", designSystem.designTokens.paddingForLocalizedMultilineTextInputLabel, ";font-size:", designSystem.designTokens.fontSizeForLocalizedMultilineTextInputLabel, ";transition:border-color ", designSystem.designTokens.transitionStandard, ",background-color ", designSystem.designTokens.transitionStandard, ",color ", designSystem.designTokens.transitionStandard, ";border-right:0;box-shadow:none;appearance:none;" + (process.env.NODE_ENV === "production" ? "" : ";label:getLanguageLabelStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRyYW5zbGF0aW9uLWlucHV0LnN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF3Q1kiLCJmaWxlIjoidHJhbnNsYXRpb24taW5wdXQuc3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5cbi8vIE5PVEU6IG9yZGVyIGlzIGltcG9ydGFudCBoZXJlXG4vLyAqIGEgZGlzYWJsZWQtZmllbGQgY3VycmVudGx5IGRvZXMgbm90IGRpc3BsYXkgd2FybmluZy9lcnJvci1zdGF0ZXMgc28gaXQgdGFrZXMgcHJlY2VkZW5jZVxuLy8gKiBhIHJlYWRvbmx5LWZpZWxkIGNhbm5vdCBiZSBjaGFuZ2VkLCBidXQgaXQgbWlnaHQgYmUgcmVsZXZhbnQgZm9yIHZhbGlkYXRpb24sIHNvIGVycm9yIGFuZCB3YXJuaW5nIGFyZSBjaGVja2VkIGZpcnN0XG4vLyBob3cgeW91IGNhbiBpbnRlcmFjdCB3aXRoIHRoZSBmaWVsZCBpcyBjb250cm9sbGVkIHNlcGFyYXRlbHkgYnkgdGhlIHByb3BzLCB0aGlzIG9ubHkgaW5mbHVlbmNlcyB2aXN1YWxzXG5cbnR5cGUgVFRyYW5zbGF0aW9uSW5wdXRTdHlsZXNQcm9wcyA9IHtcbiAgaXNDb2xsYXBzZWQ/OiBib29sZWFuO1xuICBpc0Rpc2FibGVkPzogYm9vbGVhbjtcbiAgaXNSZWFkT25seT86IGJvb2xlYW47XG59O1xuXG5jb25zdCBnZXRUZXh0YXJlYVN0eWxlcyA9IChwcm9wczogVFRyYW5zbGF0aW9uSW5wdXRTdHlsZXNQcm9wcykgPT4ge1xuICBjb25zdCBiYXNlU3R5bGVzID0gW1xuICAgIGNzc2BcbiAgICAgIGJvcmRlci10b3AtbGVmdC1yYWRpdXM6IDAgIWltcG9ydGFudDtcbiAgICAgIGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6IDAgIWltcG9ydGFudDtcbiAgICBgLFxuICAgIHByb3BzLmlzQ29sbGFwc2VkICYmXG4gICAgICBjc3NgXG4gICAgICAgIG92ZXJmbG93OiBoaWRkZW47XG4gICAgICBgLFxuICBdO1xuICByZXR1cm4gYmFzZVN0eWxlcztcbn07XG5cbmNvbnN0IGdldExhbmd1YWdlTGFiZWxCYWNrZ3JvdW5kQ29sb3IgPSAocHJvcHM6IFRUcmFuc2xhdGlvbklucHV0U3R5bGVzUHJvcHMpID0+XG4gIHByb3BzLmlzRGlzYWJsZWRcbiAgICA/IGRlc2lnblRva2Vucy5iYWNrZ3JvdW5kQ29sb3JGb3JMb2NhbGl6ZWRNdWx0aWxpbmVUZXh0SW5wdXRMYWJlbFdoZW5EaXNhYmxlZFxuICAgIDogZGVzaWduVG9rZW5zLmJhY2tncm91bmRDb2xvckZvckxvY2FsaXplZE11bHRpbGluZVRleHRJbnB1dExhYmVsO1xuXG5jb25zdCBnZXRMYW5ndWFnZUxhYmVsQm9yZGVyQ29sb3IgPSAocHJvcHM6IFRUcmFuc2xhdGlvbklucHV0U3R5bGVzUHJvcHMpID0+XG4gIHByb3BzLmlzUmVhZE9ubHlcbiAgICA/IGRlc2lnblRva2Vucy5ib3JkZXJDb2xvckZvckxvY2FsaXplZE11bHRpbGluZVRleHRJbnB1dExhYmVsV2hlblJlYWRvbmx5XG4gICAgOiBkZXNpZ25Ub2tlbnMuYm9yZGVyQ29sb3JGb3JMb2NhbGl6ZWRNdWx0aWxpbmVUZXh0SW5wdXRMYWJlbDtcblxuY29uc3QgZ2V0TGFuZ3VhZ2VMYWJlbFN0eWxlcyA9IChwcm9wczogVFRyYW5zbGF0aW9uSW5wdXRTdHlsZXNQcm9wcykgPT4ge1xuICByZXR1cm4gY3NzYFxuICAgIC8qIGF2b2lkIHdyYXBwaW5nIGxhYmVsIG9udG8gbmV3IGxpbmVzICovXG4gICAgZmxleDogMSAwIGF1dG87XG4gICAgY29sb3I6ICR7ZGVzaWduVG9rZW5zLmZvbnRDb2xvckZvckxvY2FsaXplZE11bHRpbGluZVRleHRJbnB1dExhYmVsfTtcbiAgICBsaW5lLWhlaWdodDogY2FsYyhcbiAgICAgICR7ZGVzaWduVG9rZW5zLmhlaWdodEZvcklucHV0fSAtIDIgKiAke2Rlc2lnblRva2Vucy5ib3JkZXJSYWRpdXMxfVxuICAgICk7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHtnZXRMYW5ndWFnZUxhYmVsQmFja2dyb3VuZENvbG9yKHByb3BzKX07XG4gICAgYm9yZGVyLXRvcC1sZWZ0LXJhZGl1czogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzRm9ySW5wdXR9O1xuICAgIGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6ICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1c0ZvcklucHV0fTtcbiAgICBib3JkZXI6IDFweCAke2dldExhbmd1YWdlTGFiZWxCb3JkZXJDb2xvcihwcm9wcyl9IHNvbGlkO1xuICAgIHBhZGRpbmc6ICR7ZGVzaWduVG9rZW5zLnBhZGRpbmdGb3JMb2NhbGl6ZWRNdWx0aWxpbmVUZXh0SW5wdXRMYWJlbH07XG4gICAgZm9udC1zaXplOiAke2Rlc2lnblRva2Vucy5mb250U2l6ZUZvckxvY2FsaXplZE11bHRpbGluZVRleHRJbnB1dExhYmVsfTtcbiAgICB0cmFuc2l0aW9uOiBib3JkZXItY29sb3IgJHtkZXNpZ25Ub2tlbnMudHJhbnNpdGlvblN0YW5kYXJkfSxcbiAgICAgIGJhY2tncm91bmQtY29sb3IgJHtkZXNpZ25Ub2tlbnMudHJhbnNpdGlvblN0YW5kYXJkfSxcbiAgICAgIGNvbG9yICR7ZGVzaWduVG9rZW5zLnRyYW5zaXRpb25TdGFuZGFyZH07XG4gICAgYm9yZGVyLXJpZ2h0OiAwO1xuICAgIGJveC1zaGFkb3c6IG5vbmU7XG4gICAgYXBwZWFyYW5jZTogbm9uZTtcbiAgYDtcbn07XG5cbmNvbnN0IFRvZ2dsZUJ1dHRvbldyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBmbGV4OiAwO1xuICBkaXNwbGF5OiBmbGV4O1xuYDtcblxuZXhwb3J0IHsgZ2V0VGV4dGFyZWFTdHlsZXMsIGdldExhbmd1YWdlTGFiZWxTdHlsZXMsIFRvZ2dsZUJ1dHRvbldyYXBwZXIgfTtcbiJdfQ== */");
|
|
86
92
|
};
|
|
87
93
|
|
|
88
94
|
var ToggleButtonWrapper = /*#__PURE__*/_styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
|
|
@@ -96,15 +102,15 @@ var ToggleButtonWrapper = /*#__PURE__*/_styled__default["default"]("div", proces
|
|
|
96
102
|
} : {
|
|
97
103
|
name: "ejz79s",
|
|
98
104
|
styles: "flex:0;display:flex",
|
|
99
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
100
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
105
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRyYW5zbGF0aW9uLWlucHV0LnN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE4RHNDIiwiZmlsZSI6InRyYW5zbGF0aW9uLWlucHV0LnN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGRlc2lnblRva2VucyB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuXG4vLyBOT1RFOiBvcmRlciBpcyBpbXBvcnRhbnQgaGVyZVxuLy8gKiBhIGRpc2FibGVkLWZpZWxkIGN1cnJlbnRseSBkb2VzIG5vdCBkaXNwbGF5IHdhcm5pbmcvZXJyb3Itc3RhdGVzIHNvIGl0IHRha2VzIHByZWNlZGVuY2Vcbi8vICogYSByZWFkb25seS1maWVsZCBjYW5ub3QgYmUgY2hhbmdlZCwgYnV0IGl0IG1pZ2h0IGJlIHJlbGV2YW50IGZvciB2YWxpZGF0aW9uLCBzbyBlcnJvciBhbmQgd2FybmluZyBhcmUgY2hlY2tlZCBmaXJzdFxuLy8gaG93IHlvdSBjYW4gaW50ZXJhY3Qgd2l0aCB0aGUgZmllbGQgaXMgY29udHJvbGxlZCBzZXBhcmF0ZWx5IGJ5IHRoZSBwcm9wcywgdGhpcyBvbmx5IGluZmx1ZW5jZXMgdmlzdWFsc1xuXG50eXBlIFRUcmFuc2xhdGlvbklucHV0U3R5bGVzUHJvcHMgPSB7XG4gIGlzQ29sbGFwc2VkPzogYm9vbGVhbjtcbiAgaXNEaXNhYmxlZD86IGJvb2xlYW47XG4gIGlzUmVhZE9ubHk/OiBib29sZWFuO1xufTtcblxuY29uc3QgZ2V0VGV4dGFyZWFTdHlsZXMgPSAocHJvcHM6IFRUcmFuc2xhdGlvbklucHV0U3R5bGVzUHJvcHMpID0+IHtcbiAgY29uc3QgYmFzZVN0eWxlcyA9IFtcbiAgICBjc3NgXG4gICAgICBib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAwICFpbXBvcnRhbnQ7XG4gICAgICBib3JkZXItYm90dG9tLWxlZnQtcmFkaXVzOiAwICFpbXBvcnRhbnQ7XG4gICAgYCxcbiAgICBwcm9wcy5pc0NvbGxhcHNlZCAmJlxuICAgICAgY3NzYFxuICAgICAgICBvdmVyZmxvdzogaGlkZGVuO1xuICAgICAgYCxcbiAgXTtcbiAgcmV0dXJuIGJhc2VTdHlsZXM7XG59O1xuXG5jb25zdCBnZXRMYW5ndWFnZUxhYmVsQmFja2dyb3VuZENvbG9yID0gKHByb3BzOiBUVHJhbnNsYXRpb25JbnB1dFN0eWxlc1Byb3BzKSA9PlxuICBwcm9wcy5pc0Rpc2FibGVkXG4gICAgPyBkZXNpZ25Ub2tlbnMuYmFja2dyb3VuZENvbG9yRm9yTG9jYWxpemVkTXVsdGlsaW5lVGV4dElucHV0TGFiZWxXaGVuRGlzYWJsZWRcbiAgICA6IGRlc2lnblRva2Vucy5iYWNrZ3JvdW5kQ29sb3JGb3JMb2NhbGl6ZWRNdWx0aWxpbmVUZXh0SW5wdXRMYWJlbDtcblxuY29uc3QgZ2V0TGFuZ3VhZ2VMYWJlbEJvcmRlckNvbG9yID0gKHByb3BzOiBUVHJhbnNsYXRpb25JbnB1dFN0eWxlc1Byb3BzKSA9PlxuICBwcm9wcy5pc1JlYWRPbmx5XG4gICAgPyBkZXNpZ25Ub2tlbnMuYm9yZGVyQ29sb3JGb3JMb2NhbGl6ZWRNdWx0aWxpbmVUZXh0SW5wdXRMYWJlbFdoZW5SZWFkb25seVxuICAgIDogZGVzaWduVG9rZW5zLmJvcmRlckNvbG9yRm9yTG9jYWxpemVkTXVsdGlsaW5lVGV4dElucHV0TGFiZWw7XG5cbmNvbnN0IGdldExhbmd1YWdlTGFiZWxTdHlsZXMgPSAocHJvcHM6IFRUcmFuc2xhdGlvbklucHV0U3R5bGVzUHJvcHMpID0+IHtcbiAgcmV0dXJuIGNzc2BcbiAgICAvKiBhdm9pZCB3cmFwcGluZyBsYWJlbCBvbnRvIG5ldyBsaW5lcyAqL1xuICAgIGZsZXg6IDEgMCBhdXRvO1xuICAgIGNvbG9yOiAke2Rlc2lnblRva2Vucy5mb250Q29sb3JGb3JMb2NhbGl6ZWRNdWx0aWxpbmVUZXh0SW5wdXRMYWJlbH07XG4gICAgbGluZS1oZWlnaHQ6IGNhbGMoXG4gICAgICAke2Rlc2lnblRva2Vucy5oZWlnaHRGb3JJbnB1dH0gLSAyICogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzMX1cbiAgICApO1xuICAgIGJhY2tncm91bmQtY29sb3I6ICR7Z2V0TGFuZ3VhZ2VMYWJlbEJhY2tncm91bmRDb2xvcihwcm9wcyl9O1xuICAgIGJvcmRlci10b3AtbGVmdC1yYWRpdXM6ICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1c0ZvcklucHV0fTtcbiAgICBib3JkZXItYm90dG9tLWxlZnQtcmFkaXVzOiAke2Rlc2lnblRva2Vucy5ib3JkZXJSYWRpdXNGb3JJbnB1dH07XG4gICAgYm9yZGVyOiAxcHggJHtnZXRMYW5ndWFnZUxhYmVsQm9yZGVyQ29sb3IocHJvcHMpfSBzb2xpZDtcbiAgICBwYWRkaW5nOiAke2Rlc2lnblRva2Vucy5wYWRkaW5nRm9yTG9jYWxpemVkTXVsdGlsaW5lVGV4dElucHV0TGFiZWx9O1xuICAgIGZvbnQtc2l6ZTogJHtkZXNpZ25Ub2tlbnMuZm9udFNpemVGb3JMb2NhbGl6ZWRNdWx0aWxpbmVUZXh0SW5wdXRMYWJlbH07XG4gICAgdHJhbnNpdGlvbjogYm9yZGVyLWNvbG9yICR7ZGVzaWduVG9rZW5zLnRyYW5zaXRpb25TdGFuZGFyZH0sXG4gICAgICBiYWNrZ3JvdW5kLWNvbG9yICR7ZGVzaWduVG9rZW5zLnRyYW5zaXRpb25TdGFuZGFyZH0sXG4gICAgICBjb2xvciAke2Rlc2lnblRva2Vucy50cmFuc2l0aW9uU3RhbmRhcmR9O1xuICAgIGJvcmRlci1yaWdodDogMDtcbiAgICBib3gtc2hhZG93OiBub25lO1xuICAgIGFwcGVhcmFuY2U6IG5vbmU7XG4gIGA7XG59O1xuXG5jb25zdCBUb2dnbGVCdXR0b25XcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgZmxleDogMDtcbiAgZGlzcGxheTogZmxleDtcbmA7XG5cbmV4cG9ydCB7IGdldFRleHRhcmVhU3R5bGVzLCBnZXRMYW5ndWFnZUxhYmVsU3R5bGVzLCBUb2dnbGVCdXR0b25XcmFwcGVyIH07XG4iXX0= */",
|
|
106
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
|
|
101
107
|
});
|
|
102
108
|
|
|
103
109
|
function ownKeys$2(object, enumerableOnly) { var keys = _Object$keys__default["default"](object); if (_Object$getOwnPropertySymbols__default["default"]) { var symbols = _Object$getOwnPropertySymbols__default["default"](object); enumerableOnly && (symbols = _filterInstanceProperty__default["default"](symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor__default["default"](object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
104
110
|
|
|
105
111
|
function _objectSpread$2(target) { for (var i = 1; i < arguments.length; i++) { var _context, _context2; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty__default["default"](_context = ownKeys$2(Object(source), !0)).call(_context, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](target, _Object$getOwnPropertyDescriptors__default["default"](source)) : _forEachInstanceProperty__default["default"](_context2 = ownKeys$2(Object(source))).call(_context2, function (key) { _Object$defineProperty__default["default"](target, key, _Object$getOwnPropertyDescriptor__default["default"](source, key)); }); } return target; }
|
|
106
112
|
|
|
107
|
-
function _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
113
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
108
114
|
|
|
109
115
|
var LeftColumn = /*#__PURE__*/_styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
|
|
110
116
|
target: "eepo5hu2"
|
|
@@ -117,8 +123,8 @@ var LeftColumn = /*#__PURE__*/_styled__default["default"]("div", process.env.NOD
|
|
|
117
123
|
} : {
|
|
118
124
|
name: "82a6rk",
|
|
119
125
|
styles: "flex:1",
|
|
120
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["translation-input.tsx"],"names":[],"mappings":"AAoE6B","file":"translation-input.tsx","sourcesContent":["import {\n  useState,\n  useCallback,\n  type ChangeEventHandler,\n  type FocusEventHandler,\n  type ReactNode,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport { AngleUpIcon } from '@commercetools-uikit/icons';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport { filterDataAttributes, warning } from '@commercetools-uikit/utils';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport Text from '@commercetools-uikit/text';\nimport {\n  MultilineInput,\n  messagesMultilineInput,\n} from '@commercetools-uikit/input-utils';\nimport {\n  getTextareaStyles,\n  getLanguageLabelStyles,\n  ToggleButtonWrapper,\n} from './translation-input.styles';\n\ninterface HTMLLocalizedTextAreaElement extends HTMLTextAreaElement {\n  language: string;\n}\n\ntype TranslationInputProps = {\n  /**\n   * Indicate if the value entered in the input is invalid.\n   */\n  'aria-invalid'?: boolean;\n  /**\n   * HTML ID of an element containing an error message related to the input.\n   */\n  'aria-errormessage'?: string;\n  onChange?: ChangeEventHandler<HTMLLocalizedTextAreaElement>;\n  language: string;\n  onFocus?: () => void;\n  onToggle?: () => void;\n  isCollapsed?: boolean;\n  hasLanguagesControl?: boolean;\n  warning?: ReactNode;\n  error?: ReactNode;\n  id?: string;\n  name?: string;\n  autoComplete?: string;\n  value: string;\n  onBlur?: FocusEventHandler<HTMLLocalizedTextAreaElement>;\n  isDisabled?: boolean;\n  placeholder?: string;\n  hasWarning?: boolean;\n  hasError?: boolean;\n  isReadOnly?: boolean;\n  isAutofocussed?: boolean;\n  intl: {\n    formatMessage: (messageObject: TMessagesMultilineInput) => string;\n  };\n};\n\ntype TMessagesMultilineInput = {\n  id: string;\n  description: string;\n  defaultMessage: string;\n};\n\nconst LeftColumn = styled.div`\n  flex: 1;\n`;\n\nconst RightColumn = styled.div`\n  position: relative;\n  flex: 0;\n  display: flex;\n  align-items: flex-start;\n`;\n\nconst Row = styled.div`\n  display: flex;\n  justify-content: flex-end;\n`;\n\nconst TranslationInput = (props: TranslationInputProps) => {\n  const [contentRowCount, setContentRowCount] = useState(\n    TranslationInput.MIN_ROW_COUNT\n  );\n\n  const handleHeightChange = useCallback(\n    (_, rowCount) => {\n      setContentRowCount(rowCount);\n    },\n    [setContentRowCount]\n  );\n\n  const { onChange } = props;\n\n  const handleChange = useCallback<\n    ChangeEventHandler<HTMLLocalizedTextAreaElement>\n  >(\n    (event) => {\n      // We manipulate the event to add the language to the target.\n      // That way the users of LocalizedTextInput's onChange can read\n      // event.target.language and event.target.value to determine the next value.\n      //\n      // We only need this information for the story, the MC application code will\n      // never need to access the information in such an inconvenient way, as\n      // Formik can deal with a name like \"foo.en\" and sets the value correctly.\n      // We can't use this as we aren't guaranteed a name in the story as the user\n      // might clear it using the knob, and then we can't parse the language from\n      // the input name anymore.\n      event.target.language = props.language;\n      onChange?.(event);\n    },\n    [onChange, props.language]\n  );\n\n  const { onFocus, onToggle } = props;\n  const handleFocus = useCallback(() => {\n    // Expand the input on focus\n    if (props.isCollapsed) onToggle?.();\n    if (onFocus) onFocus();\n  }, [props.isCollapsed, onFocus, onToggle]);\n\n  // This checks if the content in the textarea overflows the minimum\n  // amount of lines it should have when collapsed\n  const contentExceedsShownRows =\n    contentRowCount > TranslationInput.MIN_ROW_COUNT;\n\n  const shouldToggleButtonTakeSpace =\n    /*\n      - if hasLanguagesControl and there are no errors/warnings to display\n      - then the toggleButton is absolutely positioned\n      This is because the toggle button is placed next to the LocalizedInputToggle without being siblings in the DOM.\n      If there is a error or warning showing,\n      then it can be placed statically because it will then be a sibling to the error/warning message\n      and LocalizedInputToggle is placed below the errors/warnings.\n    */\n    (!props.isCollapsed &&\n      contentExceedsShownRows &&\n      !props.hasLanguagesControl) ||\n    props.error ||\n    props.warning;\n\n  if (!props.isReadOnly) {\n    warning(\n      typeof props.onChange === 'function',\n      'LocalizedMultilineTextInput/TranslationInput: \"onChange\" is required when isReadOnly is not true'\n    );\n  }\n\n  return (\n    <Stack scale=\"xs\">\n      <div\n        key={props.language}\n        css={css`\n          width: 100%;\n          position: relative;\n          display: flex;\n        `}\n      >\n        <label htmlFor={props.id} css={getLanguageLabelStyles(props)}>\n          {/* FIXME: add proper tone for disabled when tones are refactored */}\n          <Text.Detail tone=\"secondary\">\n            {props.language.toUpperCase()}\n          </Text.Detail>\n        </label>\n        <MultilineInput\n          id={props.id}\n          name={props.name}\n          autoComplete={props.autoComplete}\n          value={props.value}\n          onChange={handleChange}\n          onHeightChange={handleHeightChange}\n          onBlur={props.onBlur}\n          onFocus={handleFocus}\n          isDisabled={props.isDisabled}\n          placeholder={props.placeholder}\n          css={getTextareaStyles(props)}\n          hasError={props.hasError}\n          hasWarning={props.hasWarning}\n          isReadOnly={props.isReadOnly}\n          isAutofocussed={props.isAutofocussed}\n          isOpen={!props.isCollapsed}\n          {...filterDataAttributes(props)}\n          /* ARIA */\n          aria-invalid={props['aria-invalid']}\n          aria-errormessage={props['aria-errormessage']}\n        />\n      </div>\n      <Row\n        // NOTE: applying this style withing the `styled` component results in the production\n        // bundle to apply the style in the wrong order.\n        // For instance, we need to override the marging of the spacing component, which also\n        // uses `!important`.\n        // Anyway, apparently by passing the style as a `css` prop to the `styled` component\n        // does the trick.\n        // TODO: revisit the logic and the implementation to maybe avoid having to apply this style.\n        css={css`\n          margin-top: ${shouldToggleButtonTakeSpace\n            ? 'inherit'\n            : '0px !important'};\n        `}\n      >\n        {(() => {\n          if (props.error)\n            return (\n              <LeftColumn>\n                <div>{props.error}</div>\n              </LeftColumn>\n            );\n          if (props.warning)\n            return (\n              <LeftColumn>\n                <div>{props.warning}</div>\n              </LeftColumn>\n            );\n          return null;\n        })()}\n        {!props.isCollapsed && contentExceedsShownRows && (\n          <>\n            <LeftColumn />\n            <RightColumn>\n              <ToggleButtonWrapper\n                css={[\n                  !shouldToggleButtonTakeSpace &&\n                    css`\n                      position: absolute;\n                      top: 0;\n                      right: 0;\n                      margin-top: ${designTokens.spacing10};\n                    `,\n                ]}\n              >\n                <FlatButton\n                  onClick={props.onToggle}\n                  isDisabled={props.isDisabled}\n                  label={props.intl.formatMessage(\n                    messagesMultilineInput.collapse\n                  )}\n                  icon={<AngleUpIcon size=\"small\" />}\n                />\n              </ToggleButtonWrapper>\n            </RightColumn>\n          </>\n        )}\n      </Row>\n    </Stack>\n  );\n};\n\nTranslationInput.displayName = 'TranslationInput';\n\n// The minimum ammount of rows the MultilineTextInput will show.\n// When the input is closed, this is used as the maximum row count as well\n// so that the input \"collapses\".\nTranslationInput.MIN_ROW_COUNT = 1;\n\nexport default TranslationInput;\n"]} */",
|
|
121
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
126
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["translation-input.tsx"],"names":[],"mappings":"AAmE6B","file":"translation-input.tsx","sourcesContent":["import {\n  useState,\n  useCallback,\n  type ChangeEventHandler,\n  type FocusEventHandler,\n  type ReactNode,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport { AngleUpIcon } from '@commercetools-uikit/icons';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport { filterDataAttributes, warning } from '@commercetools-uikit/utils';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport {\n  MultilineInput,\n  messagesMultilineInput,\n} from '@commercetools-uikit/input-utils';\nimport {\n  getTextareaStyles,\n  getLanguageLabelStyles,\n  ToggleButtonWrapper,\n} from './translation-input.styles';\n\ninterface HTMLLocalizedTextAreaElement extends HTMLTextAreaElement {\n  language: string;\n}\n\ntype TranslationInputProps = {\n  /**\n   * Indicate if the value entered in the input is invalid.\n   */\n  'aria-invalid'?: boolean;\n  /**\n   * HTML ID of an element containing an error message related to the input.\n   */\n  'aria-errormessage'?: string;\n  onChange?: ChangeEventHandler<HTMLLocalizedTextAreaElement>;\n  language: string;\n  onFocus?: () => void;\n  onToggle?: () => void;\n  isCollapsed?: boolean;\n  hasLanguagesControl?: boolean;\n  warning?: ReactNode;\n  error?: ReactNode;\n  id?: string;\n  name?: string;\n  autoComplete?: string;\n  value: string;\n  onBlur?: FocusEventHandler<HTMLLocalizedTextAreaElement>;\n  isDisabled?: boolean;\n  placeholder?: string;\n  hasWarning?: boolean;\n  hasError?: boolean;\n  isReadOnly?: boolean;\n  isAutofocussed?: boolean;\n  intl: {\n    formatMessage: (messageObject: TMessagesMultilineInput) => string;\n  };\n};\n\ntype TMessagesMultilineInput = {\n  id: string;\n  description: string;\n  defaultMessage: string;\n};\n\nconst LeftColumn = styled.div`\n  flex: 1;\n`;\n\nconst RightColumn = styled.div`\n  position: relative;\n  flex: 0;\n  display: flex;\n  align-items: flex-start;\n`;\n\nconst Row = styled.div`\n  display: flex;\n  justify-content: flex-end;\n`;\n\nconst TranslationInput = (props: TranslationInputProps) => {\n  const [contentRowCount, setContentRowCount] = useState(\n    TranslationInput.MIN_ROW_COUNT\n  );\n\n  const handleHeightChange = useCallback(\n    (_, rowCount) => {\n      setContentRowCount(rowCount);\n    },\n    [setContentRowCount]\n  );\n\n  const { onChange } = props;\n\n  const handleChange = useCallback<\n    ChangeEventHandler<HTMLLocalizedTextAreaElement>\n  >(\n    (event) => {\n      // We manipulate the event to add the language to the target.\n      // That way the users of LocalizedTextInput's onChange can read\n      // event.target.language and event.target.value to determine the next value.\n      //\n      // We only need this information for the story, the MC application code will\n      // never need to access the information in such an inconvenient way, as\n      // Formik can deal with a name like \"foo.en\" and sets the value correctly.\n      // We can't use this as we aren't guaranteed a name in the story as the user\n      // might clear it using the knob, and then we can't parse the language from\n      // the input name anymore.\n      event.target.language = props.language;\n      onChange?.(event);\n    },\n    [onChange, props.language]\n  );\n\n  const { onFocus, onToggle } = props;\n  const handleFocus = useCallback(() => {\n    // Expand the input on focus\n    if (props.isCollapsed) onToggle?.();\n    if (onFocus) onFocus();\n  }, [props.isCollapsed, onFocus, onToggle]);\n\n  // This checks if the content in the textarea overflows the minimum\n  // amount of lines it should have when collapsed\n  const contentExceedsShownRows =\n    contentRowCount > TranslationInput.MIN_ROW_COUNT;\n\n  const shouldToggleButtonTakeSpace =\n    /*\n      - if hasLanguagesControl and there are no errors/warnings to display\n      - then the toggleButton is absolutely positioned\n      This is because the toggle button is placed next to the LocalizedInputToggle without being siblings in the DOM.\n      If there is a error or warning showing,\n      then it can be placed statically because it will then be a sibling to the error/warning message\n      and LocalizedInputToggle is placed below the errors/warnings.\n    */\n    (!props.isCollapsed &&\n      contentExceedsShownRows &&\n      !props.hasLanguagesControl) ||\n    props.error ||\n    props.warning;\n\n  if (!props.isReadOnly) {\n    warning(\n      typeof props.onChange === 'function',\n      'LocalizedMultilineTextInput/TranslationInput: \"onChange\" is required when isReadOnly is not true'\n    );\n  }\n\n  return (\n    <Stack scale=\"xs\">\n      <div\n        key={props.language}\n        css={css`\n          width: 100%;\n          position: relative;\n          display: flex;\n        `}\n      >\n        <label htmlFor={props.id} css={getLanguageLabelStyles(props)}>\n          <span>{props.language.toUpperCase()}</span>\n        </label>\n        <MultilineInput\n          id={props.id}\n          name={props.name}\n          autoComplete={props.autoComplete}\n          value={props.value}\n          onChange={handleChange}\n          onHeightChange={handleHeightChange}\n          onBlur={props.onBlur}\n          onFocus={handleFocus}\n          isDisabled={props.isDisabled}\n          placeholder={props.placeholder}\n          css={getTextareaStyles(props)}\n          hasError={props.hasError}\n          hasWarning={props.hasWarning}\n          isReadOnly={props.isReadOnly}\n          isAutofocussed={props.isAutofocussed}\n          isOpen={!props.isCollapsed}\n          {...filterDataAttributes(props)}\n          /* ARIA */\n          aria-invalid={props['aria-invalid']}\n          aria-errormessage={props['aria-errormessage']}\n        />\n      </div>\n      <Row\n        // NOTE: applying this style withing the `styled` component results in the production\n        // bundle to apply the style in the wrong order.\n        // For instance, we need to override the marging of the spacing component, which also\n        // uses `!important`.\n        // Anyway, apparently by passing the style as a `css` prop to the `styled` component\n        // does the trick.\n        // TODO: revisit the logic and the implementation to maybe avoid having to apply this style.\n        css={css`\n          margin-top: ${shouldToggleButtonTakeSpace\n            ? 'inherit'\n            : '0px !important'};\n        `}\n      >\n        {(() => {\n          if (props.error)\n            return (\n              <LeftColumn>\n                <div>{props.error}</div>\n              </LeftColumn>\n            );\n          if (props.warning)\n            return (\n              <LeftColumn>\n                <div>{props.warning}</div>\n              </LeftColumn>\n            );\n          return null;\n        })()}\n        {!props.isCollapsed && contentExceedsShownRows && (\n          <>\n            <LeftColumn />\n            <RightColumn>\n              <ToggleButtonWrapper\n                css={[\n                  !shouldToggleButtonTakeSpace &&\n                    css`\n                      position: absolute;\n                      top: 0;\n                      right: 0;\n                      margin-top: ${designTokens.spacing10};\n                    `,\n                ]}\n              >\n                <FlatButton\n                  onClick={props.onToggle}\n                  isDisabled={props.isDisabled}\n                  label={props.intl.formatMessage(\n                    messagesMultilineInput.collapse\n                  )}\n                  icon={<AngleUpIcon size=\"small\" />}\n                />\n              </ToggleButtonWrapper>\n            </RightColumn>\n          </>\n        )}\n      </Row>\n    </Stack>\n  );\n};\n\nTranslationInput.displayName = 'TranslationInput';\n\n// The minimum ammount of rows the MultilineTextInput will show.\n// When the input is closed, this is used as the maximum row count as well\n// so that the input \"collapses\".\nTranslationInput.MIN_ROW_COUNT = 1;\n\nexport default TranslationInput;\n"]} */",
|
|
127
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
122
128
|
});
|
|
123
129
|
|
|
124
130
|
var RightColumn = /*#__PURE__*/_styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
|
|
@@ -132,8 +138,8 @@ var RightColumn = /*#__PURE__*/_styled__default["default"]("div", process.env.NO
|
|
|
132
138
|
} : {
|
|
133
139
|
name: "1m04uhl",
|
|
134
140
|
styles: "position:relative;flex:0;display:flex;align-items:flex-start",
|
|
135
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["translation-input.tsx"],"names":[],"mappings":"AAwE8B","file":"translation-input.tsx","sourcesContent":["import {\n  useState,\n  useCallback,\n  type ChangeEventHandler,\n  type FocusEventHandler,\n  type ReactNode,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport { AngleUpIcon } from '@commercetools-uikit/icons';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport { filterDataAttributes, warning } from '@commercetools-uikit/utils';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport Text from '@commercetools-uikit/text';\nimport {\n  MultilineInput,\n  messagesMultilineInput,\n} from '@commercetools-uikit/input-utils';\nimport {\n  getTextareaStyles,\n  getLanguageLabelStyles,\n  ToggleButtonWrapper,\n} from './translation-input.styles';\n\ninterface HTMLLocalizedTextAreaElement extends HTMLTextAreaElement {\n  language: string;\n}\n\ntype TranslationInputProps = {\n  /**\n   * Indicate if the value entered in the input is invalid.\n   */\n  'aria-invalid'?: boolean;\n  /**\n   * HTML ID of an element containing an error message related to the input.\n   */\n  'aria-errormessage'?: string;\n  onChange?: ChangeEventHandler<HTMLLocalizedTextAreaElement>;\n  language: string;\n  onFocus?: () => void;\n  onToggle?: () => void;\n  isCollapsed?: boolean;\n  hasLanguagesControl?: boolean;\n  warning?: ReactNode;\n  error?: ReactNode;\n  id?: string;\n  name?: string;\n  autoComplete?: string;\n  value: string;\n  onBlur?: FocusEventHandler<HTMLLocalizedTextAreaElement>;\n  isDisabled?: boolean;\n  placeholder?: string;\n  hasWarning?: boolean;\n  hasError?: boolean;\n  isReadOnly?: boolean;\n  isAutofocussed?: boolean;\n  intl: {\n    formatMessage: (messageObject: TMessagesMultilineInput) => string;\n  };\n};\n\ntype TMessagesMultilineInput = {\n  id: string;\n  description: string;\n  defaultMessage: string;\n};\n\nconst LeftColumn = styled.div`\n  flex: 1;\n`;\n\nconst RightColumn = styled.div`\n  position: relative;\n  flex: 0;\n  display: flex;\n  align-items: flex-start;\n`;\n\nconst Row = styled.div`\n  display: flex;\n  justify-content: flex-end;\n`;\n\nconst TranslationInput = (props: TranslationInputProps) => {\n  const [contentRowCount, setContentRowCount] = useState(\n    TranslationInput.MIN_ROW_COUNT\n  );\n\n  const handleHeightChange = useCallback(\n    (_, rowCount) => {\n      setContentRowCount(rowCount);\n    },\n    [setContentRowCount]\n  );\n\n  const { onChange } = props;\n\n  const handleChange = useCallback<\n    ChangeEventHandler<HTMLLocalizedTextAreaElement>\n  >(\n    (event) => {\n      // We manipulate the event to add the language to the target.\n      // That way the users of LocalizedTextInput's onChange can read\n      // event.target.language and event.target.value to determine the next value.\n      //\n      // We only need this information for the story, the MC application code will\n      // never need to access the information in such an inconvenient way, as\n      // Formik can deal with a name like \"foo.en\" and sets the value correctly.\n      // We can't use this as we aren't guaranteed a name in the story as the user\n      // might clear it using the knob, and then we can't parse the language from\n      // the input name anymore.\n      event.target.language = props.language;\n      onChange?.(event);\n    },\n    [onChange, props.language]\n  );\n\n  const { onFocus, onToggle } = props;\n  const handleFocus = useCallback(() => {\n    // Expand the input on focus\n    if (props.isCollapsed) onToggle?.();\n    if (onFocus) onFocus();\n  }, [props.isCollapsed, onFocus, onToggle]);\n\n  // This checks if the content in the textarea overflows the minimum\n  // amount of lines it should have when collapsed\n  const contentExceedsShownRows =\n    contentRowCount > TranslationInput.MIN_ROW_COUNT;\n\n  const shouldToggleButtonTakeSpace =\n    /*\n      - if hasLanguagesControl and there are no errors/warnings to display\n      - then the toggleButton is absolutely positioned\n      This is because the toggle button is placed next to the LocalizedInputToggle without being siblings in the DOM.\n      If there is a error or warning showing,\n      then it can be placed statically because it will then be a sibling to the error/warning message\n      and LocalizedInputToggle is placed below the errors/warnings.\n    */\n    (!props.isCollapsed &&\n      contentExceedsShownRows &&\n      !props.hasLanguagesControl) ||\n    props.error ||\n    props.warning;\n\n  if (!props.isReadOnly) {\n    warning(\n      typeof props.onChange === 'function',\n      'LocalizedMultilineTextInput/TranslationInput: \"onChange\" is required when isReadOnly is not true'\n    );\n  }\n\n  return (\n    <Stack scale=\"xs\">\n      <div\n        key={props.language}\n        css={css`\n          width: 100%;\n          position: relative;\n          display: flex;\n        `}\n      >\n        <label htmlFor={props.id} css={getLanguageLabelStyles(props)}>\n          {/* FIXME: add proper tone for disabled when tones are refactored */}\n          <Text.Detail tone=\"secondary\">\n            {props.language.toUpperCase()}\n          </Text.Detail>\n        </label>\n        <MultilineInput\n          id={props.id}\n          name={props.name}\n          autoComplete={props.autoComplete}\n          value={props.value}\n          onChange={handleChange}\n          onHeightChange={handleHeightChange}\n          onBlur={props.onBlur}\n          onFocus={handleFocus}\n          isDisabled={props.isDisabled}\n          placeholder={props.placeholder}\n          css={getTextareaStyles(props)}\n          hasError={props.hasError}\n          hasWarning={props.hasWarning}\n          isReadOnly={props.isReadOnly}\n          isAutofocussed={props.isAutofocussed}\n          isOpen={!props.isCollapsed}\n          {...filterDataAttributes(props)}\n          /* ARIA */\n          aria-invalid={props['aria-invalid']}\n          aria-errormessage={props['aria-errormessage']}\n        />\n      </div>\n      <Row\n        // NOTE: applying this style withing the `styled` component results in the production\n        // bundle to apply the style in the wrong order.\n        // For instance, we need to override the marging of the spacing component, which also\n        // uses `!important`.\n        // Anyway, apparently by passing the style as a `css` prop to the `styled` component\n        // does the trick.\n        // TODO: revisit the logic and the implementation to maybe avoid having to apply this style.\n        css={css`\n          margin-top: ${shouldToggleButtonTakeSpace\n            ? 'inherit'\n            : '0px !important'};\n        `}\n      >\n        {(() => {\n          if (props.error)\n            return (\n              <LeftColumn>\n                <div>{props.error}</div>\n              </LeftColumn>\n            );\n          if (props.warning)\n            return (\n              <LeftColumn>\n                <div>{props.warning}</div>\n              </LeftColumn>\n            );\n          return null;\n        })()}\n        {!props.isCollapsed && contentExceedsShownRows && (\n          <>\n            <LeftColumn />\n            <RightColumn>\n              <ToggleButtonWrapper\n                css={[\n                  !shouldToggleButtonTakeSpace &&\n                    css`\n                      position: absolute;\n                      top: 0;\n                      right: 0;\n                      margin-top: ${designTokens.spacing10};\n                    `,\n                ]}\n              >\n                <FlatButton\n                  onClick={props.onToggle}\n                  isDisabled={props.isDisabled}\n                  label={props.intl.formatMessage(\n                    messagesMultilineInput.collapse\n                  )}\n                  icon={<AngleUpIcon size=\"small\" />}\n                />\n              </ToggleButtonWrapper>\n            </RightColumn>\n          </>\n        )}\n      </Row>\n    </Stack>\n  );\n};\n\nTranslationInput.displayName = 'TranslationInput';\n\n// The minimum ammount of rows the MultilineTextInput will show.\n// When the input is closed, this is used as the maximum row count as well\n// so that the input \"collapses\".\nTranslationInput.MIN_ROW_COUNT = 1;\n\nexport default TranslationInput;\n"]} */",
|
|
136
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
141
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["translation-input.tsx"],"names":[],"mappings":"AAuE8B","file":"translation-input.tsx","sourcesContent":["import {\n  useState,\n  useCallback,\n  type ChangeEventHandler,\n  type FocusEventHandler,\n  type ReactNode,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport { AngleUpIcon } from '@commercetools-uikit/icons';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport { filterDataAttributes, warning } from '@commercetools-uikit/utils';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport {\n  MultilineInput,\n  messagesMultilineInput,\n} from '@commercetools-uikit/input-utils';\nimport {\n  getTextareaStyles,\n  getLanguageLabelStyles,\n  ToggleButtonWrapper,\n} from './translation-input.styles';\n\ninterface HTMLLocalizedTextAreaElement extends HTMLTextAreaElement {\n  language: string;\n}\n\ntype TranslationInputProps = {\n  /**\n   * Indicate if the value entered in the input is invalid.\n   */\n  'aria-invalid'?: boolean;\n  /**\n   * HTML ID of an element containing an error message related to the input.\n   */\n  'aria-errormessage'?: string;\n  onChange?: ChangeEventHandler<HTMLLocalizedTextAreaElement>;\n  language: string;\n  onFocus?: () => void;\n  onToggle?: () => void;\n  isCollapsed?: boolean;\n  hasLanguagesControl?: boolean;\n  warning?: ReactNode;\n  error?: ReactNode;\n  id?: string;\n  name?: string;\n  autoComplete?: string;\n  value: string;\n  onBlur?: FocusEventHandler<HTMLLocalizedTextAreaElement>;\n  isDisabled?: boolean;\n  placeholder?: string;\n  hasWarning?: boolean;\n  hasError?: boolean;\n  isReadOnly?: boolean;\n  isAutofocussed?: boolean;\n  intl: {\n    formatMessage: (messageObject: TMessagesMultilineInput) => string;\n  };\n};\n\ntype TMessagesMultilineInput = {\n  id: string;\n  description: string;\n  defaultMessage: string;\n};\n\nconst LeftColumn = styled.div`\n  flex: 1;\n`;\n\nconst RightColumn = styled.div`\n  position: relative;\n  flex: 0;\n  display: flex;\n  align-items: flex-start;\n`;\n\nconst Row = styled.div`\n  display: flex;\n  justify-content: flex-end;\n`;\n\nconst TranslationInput = (props: TranslationInputProps) => {\n  const [contentRowCount, setContentRowCount] = useState(\n    TranslationInput.MIN_ROW_COUNT\n  );\n\n  const handleHeightChange = useCallback(\n    (_, rowCount) => {\n      setContentRowCount(rowCount);\n    },\n    [setContentRowCount]\n  );\n\n  const { onChange } = props;\n\n  const handleChange = useCallback<\n    ChangeEventHandler<HTMLLocalizedTextAreaElement>\n  >(\n    (event) => {\n      // We manipulate the event to add the language to the target.\n      // That way the users of LocalizedTextInput's onChange can read\n      // event.target.language and event.target.value to determine the next value.\n      //\n      // We only need this information for the story, the MC application code will\n      // never need to access the information in such an inconvenient way, as\n      // Formik can deal with a name like \"foo.en\" and sets the value correctly.\n      // We can't use this as we aren't guaranteed a name in the story as the user\n      // might clear it using the knob, and then we can't parse the language from\n      // the input name anymore.\n      event.target.language = props.language;\n      onChange?.(event);\n    },\n    [onChange, props.language]\n  );\n\n  const { onFocus, onToggle } = props;\n  const handleFocus = useCallback(() => {\n    // Expand the input on focus\n    if (props.isCollapsed) onToggle?.();\n    if (onFocus) onFocus();\n  }, [props.isCollapsed, onFocus, onToggle]);\n\n  // This checks if the content in the textarea overflows the minimum\n  // amount of lines it should have when collapsed\n  const contentExceedsShownRows =\n    contentRowCount > TranslationInput.MIN_ROW_COUNT;\n\n  const shouldToggleButtonTakeSpace =\n    /*\n      - if hasLanguagesControl and there are no errors/warnings to display\n      - then the toggleButton is absolutely positioned\n      This is because the toggle button is placed next to the LocalizedInputToggle without being siblings in the DOM.\n      If there is a error or warning showing,\n      then it can be placed statically because it will then be a sibling to the error/warning message\n      and LocalizedInputToggle is placed below the errors/warnings.\n    */\n    (!props.isCollapsed &&\n      contentExceedsShownRows &&\n      !props.hasLanguagesControl) ||\n    props.error ||\n    props.warning;\n\n  if (!props.isReadOnly) {\n    warning(\n      typeof props.onChange === 'function',\n      'LocalizedMultilineTextInput/TranslationInput: \"onChange\" is required when isReadOnly is not true'\n    );\n  }\n\n  return (\n    <Stack scale=\"xs\">\n      <div\n        key={props.language}\n        css={css`\n          width: 100%;\n          position: relative;\n          display: flex;\n        `}\n      >\n        <label htmlFor={props.id} css={getLanguageLabelStyles(props)}>\n          <span>{props.language.toUpperCase()}</span>\n        </label>\n        <MultilineInput\n          id={props.id}\n          name={props.name}\n          autoComplete={props.autoComplete}\n          value={props.value}\n          onChange={handleChange}\n          onHeightChange={handleHeightChange}\n          onBlur={props.onBlur}\n          onFocus={handleFocus}\n          isDisabled={props.isDisabled}\n          placeholder={props.placeholder}\n          css={getTextareaStyles(props)}\n          hasError={props.hasError}\n          hasWarning={props.hasWarning}\n          isReadOnly={props.isReadOnly}\n          isAutofocussed={props.isAutofocussed}\n          isOpen={!props.isCollapsed}\n          {...filterDataAttributes(props)}\n          /* ARIA */\n          aria-invalid={props['aria-invalid']}\n          aria-errormessage={props['aria-errormessage']}\n        />\n      </div>\n      <Row\n        // NOTE: applying this style withing the `styled` component results in the production\n        // bundle to apply the style in the wrong order.\n        // For instance, we need to override the marging of the spacing component, which also\n        // uses `!important`.\n        // Anyway, apparently by passing the style as a `css` prop to the `styled` component\n        // does the trick.\n        // TODO: revisit the logic and the implementation to maybe avoid having to apply this style.\n        css={css`\n          margin-top: ${shouldToggleButtonTakeSpace\n            ? 'inherit'\n            : '0px !important'};\n        `}\n      >\n        {(() => {\n          if (props.error)\n            return (\n              <LeftColumn>\n                <div>{props.error}</div>\n              </LeftColumn>\n            );\n          if (props.warning)\n            return (\n              <LeftColumn>\n                <div>{props.warning}</div>\n              </LeftColumn>\n            );\n          return null;\n        })()}\n        {!props.isCollapsed && contentExceedsShownRows && (\n          <>\n            <LeftColumn />\n            <RightColumn>\n              <ToggleButtonWrapper\n                css={[\n                  !shouldToggleButtonTakeSpace &&\n                    css`\n                      position: absolute;\n                      top: 0;\n                      right: 0;\n                      margin-top: ${designTokens.spacing10};\n                    `,\n                ]}\n              >\n                <FlatButton\n                  onClick={props.onToggle}\n                  isDisabled={props.isDisabled}\n                  label={props.intl.formatMessage(\n                    messagesMultilineInput.collapse\n                  )}\n                  icon={<AngleUpIcon size=\"small\" />}\n                />\n              </ToggleButtonWrapper>\n            </RightColumn>\n          </>\n        )}\n      </Row>\n    </Stack>\n  );\n};\n\nTranslationInput.displayName = 'TranslationInput';\n\n// The minimum ammount of rows the MultilineTextInput will show.\n// When the input is closed, this is used as the maximum row count as well\n// so that the input \"collapses\".\nTranslationInput.MIN_ROW_COUNT = 1;\n\nexport default TranslationInput;\n"]} */",
|
|
142
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
137
143
|
});
|
|
138
144
|
|
|
139
145
|
var Row = /*#__PURE__*/_styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
|
|
@@ -147,18 +153,18 @@ var Row = /*#__PURE__*/_styled__default["default"]("div", process.env.NODE_ENV =
|
|
|
147
153
|
} : {
|
|
148
154
|
name: "skgbeu",
|
|
149
155
|
styles: "display:flex;justify-content:flex-end",
|
|
150
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["translation-input.tsx"],"names":[],"mappings":"AA+EsB","file":"translation-input.tsx","sourcesContent":["import {\n  useState,\n  useCallback,\n  type ChangeEventHandler,\n  type FocusEventHandler,\n  type ReactNode,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport { AngleUpIcon } from '@commercetools-uikit/icons';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport { filterDataAttributes, warning } from '@commercetools-uikit/utils';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport Text from '@commercetools-uikit/text';\nimport {\n  MultilineInput,\n  messagesMultilineInput,\n} from '@commercetools-uikit/input-utils';\nimport {\n  getTextareaStyles,\n  getLanguageLabelStyles,\n  ToggleButtonWrapper,\n} from './translation-input.styles';\n\ninterface HTMLLocalizedTextAreaElement extends HTMLTextAreaElement {\n  language: string;\n}\n\ntype TranslationInputProps = {\n  /**\n   * Indicate if the value entered in the input is invalid.\n   */\n  'aria-invalid'?: boolean;\n  /**\n   * HTML ID of an element containing an error message related to the input.\n   */\n  'aria-errormessage'?: string;\n  onChange?: ChangeEventHandler<HTMLLocalizedTextAreaElement>;\n  language: string;\n  onFocus?: () => void;\n  onToggle?: () => void;\n  isCollapsed?: boolean;\n  hasLanguagesControl?: boolean;\n  warning?: ReactNode;\n  error?: ReactNode;\n  id?: string;\n  name?: string;\n  autoComplete?: string;\n  value: string;\n  onBlur?: FocusEventHandler<HTMLLocalizedTextAreaElement>;\n  isDisabled?: boolean;\n  placeholder?: string;\n  hasWarning?: boolean;\n  hasError?: boolean;\n  isReadOnly?: boolean;\n  isAutofocussed?: boolean;\n  intl: {\n    formatMessage: (messageObject: TMessagesMultilineInput) => string;\n  };\n};\n\ntype TMessagesMultilineInput = {\n  id: string;\n  description: string;\n  defaultMessage: string;\n};\n\nconst LeftColumn = styled.div`\n  flex: 1;\n`;\n\nconst RightColumn = styled.div`\n  position: relative;\n  flex: 0;\n  display: flex;\n  align-items: flex-start;\n`;\n\nconst Row = styled.div`\n  display: flex;\n  justify-content: flex-end;\n`;\n\nconst TranslationInput = (props: TranslationInputProps) => {\n  const [contentRowCount, setContentRowCount] = useState(\n    TranslationInput.MIN_ROW_COUNT\n  );\n\n  const handleHeightChange = useCallback(\n    (_, rowCount) => {\n      setContentRowCount(rowCount);\n    },\n    [setContentRowCount]\n  );\n\n  const { onChange } = props;\n\n  const handleChange = useCallback<\n    ChangeEventHandler<HTMLLocalizedTextAreaElement>\n  >(\n    (event) => {\n      // We manipulate the event to add the language to the target.\n      // That way the users of LocalizedTextInput's onChange can read\n      // event.target.language and event.target.value to determine the next value.\n      //\n      // We only need this information for the story, the MC application code will\n      // never need to access the information in such an inconvenient way, as\n      // Formik can deal with a name like \"foo.en\" and sets the value correctly.\n      // We can't use this as we aren't guaranteed a name in the story as the user\n      // might clear it using the knob, and then we can't parse the language from\n      // the input name anymore.\n      event.target.language = props.language;\n      onChange?.(event);\n    },\n    [onChange, props.language]\n  );\n\n  const { onFocus, onToggle } = props;\n  const handleFocus = useCallback(() => {\n    // Expand the input on focus\n    if (props.isCollapsed) onToggle?.();\n    if (onFocus) onFocus();\n  }, [props.isCollapsed, onFocus, onToggle]);\n\n  // This checks if the content in the textarea overflows the minimum\n  // amount of lines it should have when collapsed\n  const contentExceedsShownRows =\n    contentRowCount > TranslationInput.MIN_ROW_COUNT;\n\n  const shouldToggleButtonTakeSpace =\n    /*\n      - if hasLanguagesControl and there are no errors/warnings to display\n      - then the toggleButton is absolutely positioned\n      This is because the toggle button is placed next to the LocalizedInputToggle without being siblings in the DOM.\n      If there is a error or warning showing,\n      then it can be placed statically because it will then be a sibling to the error/warning message\n      and LocalizedInputToggle is placed below the errors/warnings.\n    */\n    (!props.isCollapsed &&\n      contentExceedsShownRows &&\n      !props.hasLanguagesControl) ||\n    props.error ||\n    props.warning;\n\n  if (!props.isReadOnly) {\n    warning(\n      typeof props.onChange === 'function',\n      'LocalizedMultilineTextInput/TranslationInput: \"onChange\" is required when isReadOnly is not true'\n    );\n  }\n\n  return (\n    <Stack scale=\"xs\">\n      <div\n        key={props.language}\n        css={css`\n          width: 100%;\n          position: relative;\n          display: flex;\n        `}\n      >\n        <label htmlFor={props.id} css={getLanguageLabelStyles(props)}>\n          {/* FIXME: add proper tone for disabled when tones are refactored */}\n          <Text.Detail tone=\"secondary\">\n            {props.language.toUpperCase()}\n          </Text.Detail>\n        </label>\n        <MultilineInput\n          id={props.id}\n          name={props.name}\n          autoComplete={props.autoComplete}\n          value={props.value}\n          onChange={handleChange}\n          onHeightChange={handleHeightChange}\n          onBlur={props.onBlur}\n          onFocus={handleFocus}\n          isDisabled={props.isDisabled}\n          placeholder={props.placeholder}\n          css={getTextareaStyles(props)}\n          hasError={props.hasError}\n          hasWarning={props.hasWarning}\n          isReadOnly={props.isReadOnly}\n          isAutofocussed={props.isAutofocussed}\n          isOpen={!props.isCollapsed}\n          {...filterDataAttributes(props)}\n          /* ARIA */\n          aria-invalid={props['aria-invalid']}\n          aria-errormessage={props['aria-errormessage']}\n        />\n      </div>\n      <Row\n        // NOTE: applying this style withing the `styled` component results in the production\n        // bundle to apply the style in the wrong order.\n        // For instance, we need to override the marging of the spacing component, which also\n        // uses `!important`.\n        // Anyway, apparently by passing the style as a `css` prop to the `styled` component\n        // does the trick.\n        // TODO: revisit the logic and the implementation to maybe avoid having to apply this style.\n        css={css`\n          margin-top: ${shouldToggleButtonTakeSpace\n            ? 'inherit'\n            : '0px !important'};\n        `}\n      >\n        {(() => {\n          if (props.error)\n            return (\n              <LeftColumn>\n                <div>{props.error}</div>\n              </LeftColumn>\n            );\n          if (props.warning)\n            return (\n              <LeftColumn>\n                <div>{props.warning}</div>\n              </LeftColumn>\n            );\n          return null;\n        })()}\n        {!props.isCollapsed && contentExceedsShownRows && (\n          <>\n            <LeftColumn />\n            <RightColumn>\n              <ToggleButtonWrapper\n                css={[\n                  !shouldToggleButtonTakeSpace &&\n                    css`\n                      position: absolute;\n                      top: 0;\n                      right: 0;\n                      margin-top: ${designTokens.spacing10};\n                    `,\n                ]}\n              >\n                <FlatButton\n                  onClick={props.onToggle}\n                  isDisabled={props.isDisabled}\n                  label={props.intl.formatMessage(\n                    messagesMultilineInput.collapse\n                  )}\n                  icon={<AngleUpIcon size=\"small\" />}\n                />\n              </ToggleButtonWrapper>\n            </RightColumn>\n          </>\n        )}\n      </Row>\n    </Stack>\n  );\n};\n\nTranslationInput.displayName = 'TranslationInput';\n\n// The minimum ammount of rows the MultilineTextInput will show.\n// When the input is closed, this is used as the maximum row count as well\n// so that the input \"collapses\".\nTranslationInput.MIN_ROW_COUNT = 1;\n\nexport default TranslationInput;\n"]} */",
|
|
151
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
156
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["translation-input.tsx"],"names":[],"mappings":"AA8EsB","file":"translation-input.tsx","sourcesContent":["import {\n  useState,\n  useCallback,\n  type ChangeEventHandler,\n  type FocusEventHandler,\n  type ReactNode,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport { AngleUpIcon } from '@commercetools-uikit/icons';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport { filterDataAttributes, warning } from '@commercetools-uikit/utils';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport {\n  MultilineInput,\n  messagesMultilineInput,\n} from '@commercetools-uikit/input-utils';\nimport {\n  getTextareaStyles,\n  getLanguageLabelStyles,\n  ToggleButtonWrapper,\n} from './translation-input.styles';\n\ninterface HTMLLocalizedTextAreaElement extends HTMLTextAreaElement {\n  language: string;\n}\n\ntype TranslationInputProps = {\n  /**\n   * Indicate if the value entered in the input is invalid.\n   */\n  'aria-invalid'?: boolean;\n  /**\n   * HTML ID of an element containing an error message related to the input.\n   */\n  'aria-errormessage'?: string;\n  onChange?: ChangeEventHandler<HTMLLocalizedTextAreaElement>;\n  language: string;\n  onFocus?: () => void;\n  onToggle?: () => void;\n  isCollapsed?: boolean;\n  hasLanguagesControl?: boolean;\n  warning?: ReactNode;\n  error?: ReactNode;\n  id?: string;\n  name?: string;\n  autoComplete?: string;\n  value: string;\n  onBlur?: FocusEventHandler<HTMLLocalizedTextAreaElement>;\n  isDisabled?: boolean;\n  placeholder?: string;\n  hasWarning?: boolean;\n  hasError?: boolean;\n  isReadOnly?: boolean;\n  isAutofocussed?: boolean;\n  intl: {\n    formatMessage: (messageObject: TMessagesMultilineInput) => string;\n  };\n};\n\ntype TMessagesMultilineInput = {\n  id: string;\n  description: string;\n  defaultMessage: string;\n};\n\nconst LeftColumn = styled.div`\n  flex: 1;\n`;\n\nconst RightColumn = styled.div`\n  position: relative;\n  flex: 0;\n  display: flex;\n  align-items: flex-start;\n`;\n\nconst Row = styled.div`\n  display: flex;\n  justify-content: flex-end;\n`;\n\nconst TranslationInput = (props: TranslationInputProps) => {\n  const [contentRowCount, setContentRowCount] = useState(\n    TranslationInput.MIN_ROW_COUNT\n  );\n\n  const handleHeightChange = useCallback(\n    (_, rowCount) => {\n      setContentRowCount(rowCount);\n    },\n    [setContentRowCount]\n  );\n\n  const { onChange } = props;\n\n  const handleChange = useCallback<\n    ChangeEventHandler<HTMLLocalizedTextAreaElement>\n  >(\n    (event) => {\n      // We manipulate the event to add the language to the target.\n      // That way the users of LocalizedTextInput's onChange can read\n      // event.target.language and event.target.value to determine the next value.\n      //\n      // We only need this information for the story, the MC application code will\n      // never need to access the information in such an inconvenient way, as\n      // Formik can deal with a name like \"foo.en\" and sets the value correctly.\n      // We can't use this as we aren't guaranteed a name in the story as the user\n      // might clear it using the knob, and then we can't parse the language from\n      // the input name anymore.\n      event.target.language = props.language;\n      onChange?.(event);\n    },\n    [onChange, props.language]\n  );\n\n  const { onFocus, onToggle } = props;\n  const handleFocus = useCallback(() => {\n    // Expand the input on focus\n    if (props.isCollapsed) onToggle?.();\n    if (onFocus) onFocus();\n  }, [props.isCollapsed, onFocus, onToggle]);\n\n  // This checks if the content in the textarea overflows the minimum\n  // amount of lines it should have when collapsed\n  const contentExceedsShownRows =\n    contentRowCount > TranslationInput.MIN_ROW_COUNT;\n\n  const shouldToggleButtonTakeSpace =\n    /*\n      - if hasLanguagesControl and there are no errors/warnings to display\n      - then the toggleButton is absolutely positioned\n      This is because the toggle button is placed next to the LocalizedInputToggle without being siblings in the DOM.\n      If there is a error or warning showing,\n      then it can be placed statically because it will then be a sibling to the error/warning message\n      and LocalizedInputToggle is placed below the errors/warnings.\n    */\n    (!props.isCollapsed &&\n      contentExceedsShownRows &&\n      !props.hasLanguagesControl) ||\n    props.error ||\n    props.warning;\n\n  if (!props.isReadOnly) {\n    warning(\n      typeof props.onChange === 'function',\n      'LocalizedMultilineTextInput/TranslationInput: \"onChange\" is required when isReadOnly is not true'\n    );\n  }\n\n  return (\n    <Stack scale=\"xs\">\n      <div\n        key={props.language}\n        css={css`\n          width: 100%;\n          position: relative;\n          display: flex;\n        `}\n      >\n        <label htmlFor={props.id} css={getLanguageLabelStyles(props)}>\n          <span>{props.language.toUpperCase()}</span>\n        </label>\n        <MultilineInput\n          id={props.id}\n          name={props.name}\n          autoComplete={props.autoComplete}\n          value={props.value}\n          onChange={handleChange}\n          onHeightChange={handleHeightChange}\n          onBlur={props.onBlur}\n          onFocus={handleFocus}\n          isDisabled={props.isDisabled}\n          placeholder={props.placeholder}\n          css={getTextareaStyles(props)}\n          hasError={props.hasError}\n          hasWarning={props.hasWarning}\n          isReadOnly={props.isReadOnly}\n          isAutofocussed={props.isAutofocussed}\n          isOpen={!props.isCollapsed}\n          {...filterDataAttributes(props)}\n          /* ARIA */\n          aria-invalid={props['aria-invalid']}\n          aria-errormessage={props['aria-errormessage']}\n        />\n      </div>\n      <Row\n        // NOTE: applying this style withing the `styled` component results in the production\n        // bundle to apply the style in the wrong order.\n        // For instance, we need to override the marging of the spacing component, which also\n        // uses `!important`.\n        // Anyway, apparently by passing the style as a `css` prop to the `styled` component\n        // does the trick.\n        // TODO: revisit the logic and the implementation to maybe avoid having to apply this style.\n        css={css`\n          margin-top: ${shouldToggleButtonTakeSpace\n            ? 'inherit'\n            : '0px !important'};\n        `}\n      >\n        {(() => {\n          if (props.error)\n            return (\n              <LeftColumn>\n                <div>{props.error}</div>\n              </LeftColumn>\n            );\n          if (props.warning)\n            return (\n              <LeftColumn>\n                <div>{props.warning}</div>\n              </LeftColumn>\n            );\n          return null;\n        })()}\n        {!props.isCollapsed && contentExceedsShownRows && (\n          <>\n            <LeftColumn />\n            <RightColumn>\n              <ToggleButtonWrapper\n                css={[\n                  !shouldToggleButtonTakeSpace &&\n                    css`\n                      position: absolute;\n                      top: 0;\n                      right: 0;\n                      margin-top: ${designTokens.spacing10};\n                    `,\n                ]}\n              >\n                <FlatButton\n                  onClick={props.onToggle}\n                  isDisabled={props.isDisabled}\n                  label={props.intl.formatMessage(\n                    messagesMultilineInput.collapse\n                  )}\n                  icon={<AngleUpIcon size=\"small\" />}\n                />\n              </ToggleButtonWrapper>\n            </RightColumn>\n          </>\n        )}\n      </Row>\n    </Stack>\n  );\n};\n\nTranslationInput.displayName = 'TranslationInput';\n\n// The minimum ammount of rows the MultilineTextInput will show.\n// When the input is closed, this is used as the maximum row count as well\n// so that the input \"collapses\".\nTranslationInput.MIN_ROW_COUNT = 1;\n\nexport default TranslationInput;\n"]} */",
|
|
157
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
152
158
|
});
|
|
153
159
|
|
|
154
|
-
var _ref
|
|
160
|
+
var _ref = process.env.NODE_ENV === "production" ? {
|
|
155
161
|
name: "1ktetz7",
|
|
156
162
|
styles: "width:100%;position:relative;display:flex"
|
|
157
163
|
} : {
|
|
158
164
|
name: "1r0st9p-TranslationInput",
|
|
159
165
|
styles: "width:100%;position:relative;display:flex;label:TranslationInput;",
|
|
160
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["translation-input.tsx"],"names":[],"mappings":"AA4JgB","file":"translation-input.tsx","sourcesContent":["import {\n  useState,\n  useCallback,\n  type ChangeEventHandler,\n  type FocusEventHandler,\n  type ReactNode,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport { AngleUpIcon } from '@commercetools-uikit/icons';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport { filterDataAttributes, warning } from '@commercetools-uikit/utils';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport Text from '@commercetools-uikit/text';\nimport {\n  MultilineInput,\n  messagesMultilineInput,\n} from '@commercetools-uikit/input-utils';\nimport {\n  getTextareaStyles,\n  getLanguageLabelStyles,\n  ToggleButtonWrapper,\n} from './translation-input.styles';\n\ninterface HTMLLocalizedTextAreaElement extends HTMLTextAreaElement {\n  language: string;\n}\n\ntype TranslationInputProps = {\n  /**\n   * Indicate if the value entered in the input is invalid.\n   */\n  'aria-invalid'?: boolean;\n  /**\n   * HTML ID of an element containing an error message related to the input.\n   */\n  'aria-errormessage'?: string;\n  onChange?: ChangeEventHandler<HTMLLocalizedTextAreaElement>;\n  language: string;\n  onFocus?: () => void;\n  onToggle?: () => void;\n  isCollapsed?: boolean;\n  hasLanguagesControl?: boolean;\n  warning?: ReactNode;\n  error?: ReactNode;\n  id?: string;\n  name?: string;\n  autoComplete?: string;\n  value: string;\n  onBlur?: FocusEventHandler<HTMLLocalizedTextAreaElement>;\n  isDisabled?: boolean;\n  placeholder?: string;\n  hasWarning?: boolean;\n  hasError?: boolean;\n  isReadOnly?: boolean;\n  isAutofocussed?: boolean;\n  intl: {\n    formatMessage: (messageObject: TMessagesMultilineInput) => string;\n  };\n};\n\ntype TMessagesMultilineInput = {\n  id: string;\n  description: string;\n  defaultMessage: string;\n};\n\nconst LeftColumn = styled.div`\n  flex: 1;\n`;\n\nconst RightColumn = styled.div`\n  position: relative;\n  flex: 0;\n  display: flex;\n  align-items: flex-start;\n`;\n\nconst Row = styled.div`\n  display: flex;\n  justify-content: flex-end;\n`;\n\nconst TranslationInput = (props: TranslationInputProps) => {\n  const [contentRowCount, setContentRowCount] = useState(\n    TranslationInput.MIN_ROW_COUNT\n  );\n\n  const handleHeightChange = useCallback(\n    (_, rowCount) => {\n      setContentRowCount(rowCount);\n    },\n    [setContentRowCount]\n  );\n\n  const { onChange } = props;\n\n  const handleChange = useCallback<\n    ChangeEventHandler<HTMLLocalizedTextAreaElement>\n  >(\n    (event) => {\n      // We manipulate the event to add the language to the target.\n      // That way the users of LocalizedTextInput's onChange can read\n      // event.target.language and event.target.value to determine the next value.\n      //\n      // We only need this information for the story, the MC application code will\n      // never need to access the information in such an inconvenient way, as\n      // Formik can deal with a name like \"foo.en\" and sets the value correctly.\n      // We can't use this as we aren't guaranteed a name in the story as the user\n      // might clear it using the knob, and then we can't parse the language from\n      // the input name anymore.\n      event.target.language = props.language;\n      onChange?.(event);\n    },\n    [onChange, props.language]\n  );\n\n  const { onFocus, onToggle } = props;\n  const handleFocus = useCallback(() => {\n    // Expand the input on focus\n    if (props.isCollapsed) onToggle?.();\n    if (onFocus) onFocus();\n  }, [props.isCollapsed, onFocus, onToggle]);\n\n  // This checks if the content in the textarea overflows the minimum\n  // amount of lines it should have when collapsed\n  const contentExceedsShownRows =\n    contentRowCount > TranslationInput.MIN_ROW_COUNT;\n\n  const shouldToggleButtonTakeSpace =\n    /*\n      - if hasLanguagesControl and there are no errors/warnings to display\n      - then the toggleButton is absolutely positioned\n      This is because the toggle button is placed next to the LocalizedInputToggle without being siblings in the DOM.\n      If there is a error or warning showing,\n      then it can be placed statically because it will then be a sibling to the error/warning message\n      and LocalizedInputToggle is placed below the errors/warnings.\n    */\n    (!props.isCollapsed &&\n      contentExceedsShownRows &&\n      !props.hasLanguagesControl) ||\n    props.error ||\n    props.warning;\n\n  if (!props.isReadOnly) {\n    warning(\n      typeof props.onChange === 'function',\n      'LocalizedMultilineTextInput/TranslationInput: \"onChange\" is required when isReadOnly is not true'\n    );\n  }\n\n  return (\n    <Stack scale=\"xs\">\n      <div\n        key={props.language}\n        css={css`\n          width: 100%;\n          position: relative;\n          display: flex;\n        `}\n      >\n        <label htmlFor={props.id} css={getLanguageLabelStyles(props)}>\n          {/* FIXME: add proper tone for disabled when tones are refactored */}\n          <Text.Detail tone=\"secondary\">\n            {props.language.toUpperCase()}\n          </Text.Detail>\n        </label>\n        <MultilineInput\n          id={props.id}\n          name={props.name}\n          autoComplete={props.autoComplete}\n          value={props.value}\n          onChange={handleChange}\n          onHeightChange={handleHeightChange}\n          onBlur={props.onBlur}\n          onFocus={handleFocus}\n          isDisabled={props.isDisabled}\n          placeholder={props.placeholder}\n          css={getTextareaStyles(props)}\n          hasError={props.hasError}\n          hasWarning={props.hasWarning}\n          isReadOnly={props.isReadOnly}\n          isAutofocussed={props.isAutofocussed}\n          isOpen={!props.isCollapsed}\n          {...filterDataAttributes(props)}\n          /* ARIA */\n          aria-invalid={props['aria-invalid']}\n          aria-errormessage={props['aria-errormessage']}\n        />\n      </div>\n      <Row\n        // NOTE: applying this style withing the `styled` component results in the production\n        // bundle to apply the style in the wrong order.\n        // For instance, we need to override the marging of the spacing component, which also\n        // uses `!important`.\n        // Anyway, apparently by passing the style as a `css` prop to the `styled` component\n        // does the trick.\n        // TODO: revisit the logic and the implementation to maybe avoid having to apply this style.\n        css={css`\n          margin-top: ${shouldToggleButtonTakeSpace\n            ? 'inherit'\n            : '0px !important'};\n        `}\n      >\n        {(() => {\n          if (props.error)\n            return (\n              <LeftColumn>\n                <div>{props.error}</div>\n              </LeftColumn>\n            );\n          if (props.warning)\n            return (\n              <LeftColumn>\n                <div>{props.warning}</div>\n              </LeftColumn>\n            );\n          return null;\n        })()}\n        {!props.isCollapsed && contentExceedsShownRows && (\n          <>\n            <LeftColumn />\n            <RightColumn>\n              <ToggleButtonWrapper\n                css={[\n                  !shouldToggleButtonTakeSpace &&\n                    css`\n                      position: absolute;\n                      top: 0;\n                      right: 0;\n                      margin-top: ${designTokens.spacing10};\n                    `,\n                ]}\n              >\n                <FlatButton\n                  onClick={props.onToggle}\n                  isDisabled={props.isDisabled}\n                  label={props.intl.formatMessage(\n                    messagesMultilineInput.collapse\n                  )}\n                  icon={<AngleUpIcon size=\"small\" />}\n                />\n              </ToggleButtonWrapper>\n            </RightColumn>\n          </>\n        )}\n      </Row>\n    </Stack>\n  );\n};\n\nTranslationInput.displayName = 'TranslationInput';\n\n// The minimum ammount of rows the MultilineTextInput will show.\n// When the input is closed, this is used as the maximum row count as well\n// so that the input \"collapses\".\nTranslationInput.MIN_ROW_COUNT = 1;\n\nexport default TranslationInput;\n"]} */",
|
|
161
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
166
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["translation-input.tsx"],"names":[],"mappings":"AA2JgB","file":"translation-input.tsx","sourcesContent":["import {\n  useState,\n  useCallback,\n  type ChangeEventHandler,\n  type FocusEventHandler,\n  type ReactNode,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport { AngleUpIcon } from '@commercetools-uikit/icons';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport { filterDataAttributes, warning } from '@commercetools-uikit/utils';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport {\n  MultilineInput,\n  messagesMultilineInput,\n} from '@commercetools-uikit/input-utils';\nimport {\n  getTextareaStyles,\n  getLanguageLabelStyles,\n  ToggleButtonWrapper,\n} from './translation-input.styles';\n\ninterface HTMLLocalizedTextAreaElement extends HTMLTextAreaElement {\n  language: string;\n}\n\ntype TranslationInputProps = {\n  /**\n   * Indicate if the value entered in the input is invalid.\n   */\n  'aria-invalid'?: boolean;\n  /**\n   * HTML ID of an element containing an error message related to the input.\n   */\n  'aria-errormessage'?: string;\n  onChange?: ChangeEventHandler<HTMLLocalizedTextAreaElement>;\n  language: string;\n  onFocus?: () => void;\n  onToggle?: () => void;\n  isCollapsed?: boolean;\n  hasLanguagesControl?: boolean;\n  warning?: ReactNode;\n  error?: ReactNode;\n  id?: string;\n  name?: string;\n  autoComplete?: string;\n  value: string;\n  onBlur?: FocusEventHandler<HTMLLocalizedTextAreaElement>;\n  isDisabled?: boolean;\n  placeholder?: string;\n  hasWarning?: boolean;\n  hasError?: boolean;\n  isReadOnly?: boolean;\n  isAutofocussed?: boolean;\n  intl: {\n    formatMessage: (messageObject: TMessagesMultilineInput) => string;\n  };\n};\n\ntype TMessagesMultilineInput = {\n  id: string;\n  description: string;\n  defaultMessage: string;\n};\n\nconst LeftColumn = styled.div`\n  flex: 1;\n`;\n\nconst RightColumn = styled.div`\n  position: relative;\n  flex: 0;\n  display: flex;\n  align-items: flex-start;\n`;\n\nconst Row = styled.div`\n  display: flex;\n  justify-content: flex-end;\n`;\n\nconst TranslationInput = (props: TranslationInputProps) => {\n  const [contentRowCount, setContentRowCount] = useState(\n    TranslationInput.MIN_ROW_COUNT\n  );\n\n  const handleHeightChange = useCallback(\n    (_, rowCount) => {\n      setContentRowCount(rowCount);\n    },\n    [setContentRowCount]\n  );\n\n  const { onChange } = props;\n\n  const handleChange = useCallback<\n    ChangeEventHandler<HTMLLocalizedTextAreaElement>\n  >(\n    (event) => {\n      // We manipulate the event to add the language to the target.\n      // That way the users of LocalizedTextInput's onChange can read\n      // event.target.language and event.target.value to determine the next value.\n      //\n      // We only need this information for the story, the MC application code will\n      // never need to access the information in such an inconvenient way, as\n      // Formik can deal with a name like \"foo.en\" and sets the value correctly.\n      // We can't use this as we aren't guaranteed a name in the story as the user\n      // might clear it using the knob, and then we can't parse the language from\n      // the input name anymore.\n      event.target.language = props.language;\n      onChange?.(event);\n    },\n    [onChange, props.language]\n  );\n\n  const { onFocus, onToggle } = props;\n  const handleFocus = useCallback(() => {\n    // Expand the input on focus\n    if (props.isCollapsed) onToggle?.();\n    if (onFocus) onFocus();\n  }, [props.isCollapsed, onFocus, onToggle]);\n\n  // This checks if the content in the textarea overflows the minimum\n  // amount of lines it should have when collapsed\n  const contentExceedsShownRows =\n    contentRowCount > TranslationInput.MIN_ROW_COUNT;\n\n  const shouldToggleButtonTakeSpace =\n    /*\n      - if hasLanguagesControl and there are no errors/warnings to display\n      - then the toggleButton is absolutely positioned\n      This is because the toggle button is placed next to the LocalizedInputToggle without being siblings in the DOM.\n      If there is a error or warning showing,\n      then it can be placed statically because it will then be a sibling to the error/warning message\n      and LocalizedInputToggle is placed below the errors/warnings.\n    */\n    (!props.isCollapsed &&\n      contentExceedsShownRows &&\n      !props.hasLanguagesControl) ||\n    props.error ||\n    props.warning;\n\n  if (!props.isReadOnly) {\n    warning(\n      typeof props.onChange === 'function',\n      'LocalizedMultilineTextInput/TranslationInput: \"onChange\" is required when isReadOnly is not true'\n    );\n  }\n\n  return (\n    <Stack scale=\"xs\">\n      <div\n        key={props.language}\n        css={css`\n          width: 100%;\n          position: relative;\n          display: flex;\n        `}\n      >\n        <label htmlFor={props.id} css={getLanguageLabelStyles(props)}>\n          <span>{props.language.toUpperCase()}</span>\n        </label>\n        <MultilineInput\n          id={props.id}\n          name={props.name}\n          autoComplete={props.autoComplete}\n          value={props.value}\n          onChange={handleChange}\n          onHeightChange={handleHeightChange}\n          onBlur={props.onBlur}\n          onFocus={handleFocus}\n          isDisabled={props.isDisabled}\n          placeholder={props.placeholder}\n          css={getTextareaStyles(props)}\n          hasError={props.hasError}\n          hasWarning={props.hasWarning}\n          isReadOnly={props.isReadOnly}\n          isAutofocussed={props.isAutofocussed}\n          isOpen={!props.isCollapsed}\n          {...filterDataAttributes(props)}\n          /* ARIA */\n          aria-invalid={props['aria-invalid']}\n          aria-errormessage={props['aria-errormessage']}\n        />\n      </div>\n      <Row\n        // NOTE: applying this style withing the `styled` component results in the production\n        // bundle to apply the style in the wrong order.\n        // For instance, we need to override the marging of the spacing component, which also\n        // uses `!important`.\n        // Anyway, apparently by passing the style as a `css` prop to the `styled` component\n        // does the trick.\n        // TODO: revisit the logic and the implementation to maybe avoid having to apply this style.\n        css={css`\n          margin-top: ${shouldToggleButtonTakeSpace\n            ? 'inherit'\n            : '0px !important'};\n        `}\n      >\n        {(() => {\n          if (props.error)\n            return (\n              <LeftColumn>\n                <div>{props.error}</div>\n              </LeftColumn>\n            );\n          if (props.warning)\n            return (\n              <LeftColumn>\n                <div>{props.warning}</div>\n              </LeftColumn>\n            );\n          return null;\n        })()}\n        {!props.isCollapsed && contentExceedsShownRows && (\n          <>\n            <LeftColumn />\n            <RightColumn>\n              <ToggleButtonWrapper\n                css={[\n                  !shouldToggleButtonTakeSpace &&\n                    css`\n                      position: absolute;\n                      top: 0;\n                      right: 0;\n                      margin-top: ${designTokens.spacing10};\n                    `,\n                ]}\n              >\n                <FlatButton\n                  onClick={props.onToggle}\n                  isDisabled={props.isDisabled}\n                  label={props.intl.formatMessage(\n                    messagesMultilineInput.collapse\n                  )}\n                  icon={<AngleUpIcon size=\"small\" />}\n                />\n              </ToggleButtonWrapper>\n            </RightColumn>\n          </>\n        )}\n      </Row>\n    </Stack>\n  );\n};\n\nTranslationInput.displayName = 'TranslationInput';\n\n// The minimum ammount of rows the MultilineTextInput will show.\n// When the input is closed, this is used as the maximum row count as well\n// so that the input \"collapses\".\nTranslationInput.MIN_ROW_COUNT = 1;\n\nexport default TranslationInput;\n"]} */",
|
|
167
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
162
168
|
};
|
|
163
169
|
|
|
164
170
|
var TranslationInput = function TranslationInput(props) {
|
|
@@ -213,12 +219,11 @@ var TranslationInput = function TranslationInput(props) {
|
|
|
213
219
|
return jsxRuntime.jsxs(Stack__default["default"], {
|
|
214
220
|
scale: "xs",
|
|
215
221
|
children: [jsxRuntime.jsxs("div", {
|
|
216
|
-
css: _ref
|
|
222
|
+
css: _ref,
|
|
217
223
|
children: [jsxRuntime.jsx("label", {
|
|
218
224
|
htmlFor: props.id,
|
|
219
225
|
css: getLanguageLabelStyles(props),
|
|
220
|
-
children: jsxRuntime.jsx(
|
|
221
|
-
tone: "secondary",
|
|
226
|
+
children: jsxRuntime.jsx("span", {
|
|
222
227
|
children: props.language.toUpperCase()
|
|
223
228
|
})
|
|
224
229
|
}), jsxRuntime.jsx(inputUtils.MultilineInput, _objectSpread$2(_objectSpread$2({
|
|
@@ -251,7 +256,7 @@ var TranslationInput = function TranslationInput(props) {
|
|
|
251
256
|
// does the trick.
|
|
252
257
|
// TODO: revisit the logic and the implementation to maybe avoid having to apply this style.
|
|
253
258
|
, {
|
|
254
|
-
css: /*#__PURE__*/react.css("margin-top:", shouldToggleButtonTakeSpace ? 'inherit' : '0px !important', ";" + (process.env.NODE_ENV === "production" ? "" : ";label:TranslationInput;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["translation-input.tsx"],"names":[],"mappings":"AAuMgB","file":"translation-input.tsx","sourcesContent":["import {\n  useState,\n  useCallback,\n  type ChangeEventHandler,\n  type FocusEventHandler,\n  type ReactNode,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport { AngleUpIcon } from '@commercetools-uikit/icons';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport { filterDataAttributes, warning } from '@commercetools-uikit/utils';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport Text from '@commercetools-uikit/text';\nimport {\n  MultilineInput,\n  messagesMultilineInput,\n} from '@commercetools-uikit/input-utils';\nimport {\n  getTextareaStyles,\n  getLanguageLabelStyles,\n  ToggleButtonWrapper,\n} from './translation-input.styles';\n\ninterface HTMLLocalizedTextAreaElement extends HTMLTextAreaElement {\n  language: string;\n}\n\ntype TranslationInputProps = {\n  /**\n   * Indicate if the value entered in the input is invalid.\n   */\n  'aria-invalid'?: boolean;\n  /**\n   * HTML ID of an element containing an error message related to the input.\n   */\n  'aria-errormessage'?: string;\n  onChange?: ChangeEventHandler<HTMLLocalizedTextAreaElement>;\n  language: string;\n  onFocus?: () => void;\n  onToggle?: () => void;\n  isCollapsed?: boolean;\n  hasLanguagesControl?: boolean;\n  warning?: ReactNode;\n  error?: ReactNode;\n  id?: string;\n  name?: string;\n  autoComplete?: string;\n  value: string;\n  onBlur?: FocusEventHandler<HTMLLocalizedTextAreaElement>;\n  isDisabled?: boolean;\n  placeholder?: string;\n  hasWarning?: boolean;\n  hasError?: boolean;\n  isReadOnly?: boolean;\n  isAutofocussed?: boolean;\n  intl: {\n    formatMessage: (messageObject: TMessagesMultilineInput) => string;\n  };\n};\n\ntype TMessagesMultilineInput = {\n  id: string;\n  description: string;\n  defaultMessage: string;\n};\n\nconst LeftColumn = styled.div`\n  flex: 1;\n`;\n\nconst RightColumn = styled.div`\n  position: relative;\n  flex: 0;\n  display: flex;\n  align-items: flex-start;\n`;\n\nconst Row = styled.div`\n  display: flex;\n  justify-content: flex-end;\n`;\n\nconst TranslationInput = (props: TranslationInputProps) => {\n  const [contentRowCount, setContentRowCount] = useState(\n    TranslationInput.MIN_ROW_COUNT\n  );\n\n  const handleHeightChange = useCallback(\n    (_, rowCount) => {\n      setContentRowCount(rowCount);\n    },\n    [setContentRowCount]\n  );\n\n  const { onChange } = props;\n\n  const handleChange = useCallback<\n    ChangeEventHandler<HTMLLocalizedTextAreaElement>\n  >(\n    (event) => {\n      // We manipulate the event to add the language to the target.\n      // That way the users of LocalizedTextInput's onChange can read\n      // event.target.language and event.target.value to determine the next value.\n      //\n      // We only need this information for the story, the MC application code will\n      // never need to access the information in such an inconvenient way, as\n      // Formik can deal with a name like \"foo.en\" and sets the value correctly.\n      // We can't use this as we aren't guaranteed a name in the story as the user\n      // might clear it using the knob, and then we can't parse the language from\n      // the input name anymore.\n      event.target.language = props.language;\n      onChange?.(event);\n    },\n    [onChange, props.language]\n  );\n\n  const { onFocus, onToggle } = props;\n  const handleFocus = useCallback(() => {\n    // Expand the input on focus\n    if (props.isCollapsed) onToggle?.();\n    if (onFocus) onFocus();\n  }, [props.isCollapsed, onFocus, onToggle]);\n\n  // This checks if the content in the textarea overflows the minimum\n  // amount of lines it should have when collapsed\n  const contentExceedsShownRows =\n    contentRowCount > TranslationInput.MIN_ROW_COUNT;\n\n  const shouldToggleButtonTakeSpace =\n    /*\n      - if hasLanguagesControl and there are no errors/warnings to display\n      - then the toggleButton is absolutely positioned\n      This is because the toggle button is placed next to the LocalizedInputToggle without being siblings in the DOM.\n      If there is a error or warning showing,\n      then it can be placed statically because it will then be a sibling to the error/warning message\n      and LocalizedInputToggle is placed below the errors/warnings.\n    */\n    (!props.isCollapsed &&\n      contentExceedsShownRows &&\n      !props.hasLanguagesControl) ||\n    props.error ||\n    props.warning;\n\n  if (!props.isReadOnly) {\n    warning(\n      typeof props.onChange === 'function',\n      'LocalizedMultilineTextInput/TranslationInput: \"onChange\" is required when isReadOnly is not true'\n    );\n  }\n\n  return (\n    <Stack scale=\"xs\">\n      <div\n        key={props.language}\n        css={css`\n          width: 100%;\n          position: relative;\n          display: flex;\n        `}\n      >\n        <label htmlFor={props.id} css={getLanguageLabelStyles(props)}>\n          {/* FIXME: add proper tone for disabled when tones are refactored */}\n          <Text.Detail tone=\"secondary\">\n            {props.language.toUpperCase()}\n          </Text.Detail>\n        </label>\n        <MultilineInput\n          id={props.id}\n          name={props.name}\n          autoComplete={props.autoComplete}\n          value={props.value}\n          onChange={handleChange}\n          onHeightChange={handleHeightChange}\n          onBlur={props.onBlur}\n          onFocus={handleFocus}\n          isDisabled={props.isDisabled}\n          placeholder={props.placeholder}\n          css={getTextareaStyles(props)}\n          hasError={props.hasError}\n          hasWarning={props.hasWarning}\n          isReadOnly={props.isReadOnly}\n          isAutofocussed={props.isAutofocussed}\n          isOpen={!props.isCollapsed}\n          {...filterDataAttributes(props)}\n          /* ARIA */\n          aria-invalid={props['aria-invalid']}\n          aria-errormessage={props['aria-errormessage']}\n        />\n      </div>\n      <Row\n        // NOTE: applying this style withing the `styled` component results in the production\n        // bundle to apply the style in the wrong order.\n        // For instance, we need to override the marging of the spacing component, which also\n        // uses `!important`.\n        // Anyway, apparently by passing the style as a `css` prop to the `styled` component\n        // does the trick.\n        // TODO: revisit the logic and the implementation to maybe avoid having to apply this style.\n        css={css`\n          margin-top: ${shouldToggleButtonTakeSpace\n            ? 'inherit'\n            : '0px !important'};\n        `}\n      >\n        {(() => {\n          if (props.error)\n            return (\n              <LeftColumn>\n                <div>{props.error}</div>\n              </LeftColumn>\n            );\n          if (props.warning)\n            return (\n              <LeftColumn>\n                <div>{props.warning}</div>\n              </LeftColumn>\n            );\n          return null;\n        })()}\n        {!props.isCollapsed && contentExceedsShownRows && (\n          <>\n            <LeftColumn />\n            <RightColumn>\n              <ToggleButtonWrapper\n                css={[\n                  !shouldToggleButtonTakeSpace &&\n                    css`\n                      position: absolute;\n                      top: 0;\n                      right: 0;\n                      margin-top: ${designTokens.spacing10};\n                    `,\n                ]}\n              >\n                <FlatButton\n                  onClick={props.onToggle}\n                  isDisabled={props.isDisabled}\n                  label={props.intl.formatMessage(\n                    messagesMultilineInput.collapse\n                  )}\n                  icon={<AngleUpIcon size=\"small\" />}\n                />\n              </ToggleButtonWrapper>\n            </RightColumn>\n          </>\n        )}\n      </Row>\n    </Stack>\n  );\n};\n\nTranslationInput.displayName = 'TranslationInput';\n\n// The minimum ammount of rows the MultilineTextInput will show.\n// When the input is closed, this is used as the maximum row count as well\n// so that the input \"collapses\".\nTranslationInput.MIN_ROW_COUNT = 1;\n\nexport default TranslationInput;\n"]} */"),
|
|
259
|
+
css: /*#__PURE__*/react.css("margin-top:", shouldToggleButtonTakeSpace ? 'inherit' : '0px !important', ";" + (process.env.NODE_ENV === "production" ? "" : ";label:TranslationInput;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["translation-input.tsx"],"names":[],"mappings":"AAmMgB","file":"translation-input.tsx","sourcesContent":["import {\n  useState,\n  useCallback,\n  type ChangeEventHandler,\n  type FocusEventHandler,\n  type ReactNode,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport { AngleUpIcon } from '@commercetools-uikit/icons';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport { filterDataAttributes, warning } from '@commercetools-uikit/utils';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport {\n  MultilineInput,\n  messagesMultilineInput,\n} from '@commercetools-uikit/input-utils';\nimport {\n  getTextareaStyles,\n  getLanguageLabelStyles,\n  ToggleButtonWrapper,\n} from './translation-input.styles';\n\ninterface HTMLLocalizedTextAreaElement extends HTMLTextAreaElement {\n  language: string;\n}\n\ntype TranslationInputProps = {\n  /**\n   * Indicate if the value entered in the input is invalid.\n   */\n  'aria-invalid'?: boolean;\n  /**\n   * HTML ID of an element containing an error message related to the input.\n   */\n  'aria-errormessage'?: string;\n  onChange?: ChangeEventHandler<HTMLLocalizedTextAreaElement>;\n  language: string;\n  onFocus?: () => void;\n  onToggle?: () => void;\n  isCollapsed?: boolean;\n  hasLanguagesControl?: boolean;\n  warning?: ReactNode;\n  error?: ReactNode;\n  id?: string;\n  name?: string;\n  autoComplete?: string;\n  value: string;\n  onBlur?: FocusEventHandler<HTMLLocalizedTextAreaElement>;\n  isDisabled?: boolean;\n  placeholder?: string;\n  hasWarning?: boolean;\n  hasError?: boolean;\n  isReadOnly?: boolean;\n  isAutofocussed?: boolean;\n  intl: {\n    formatMessage: (messageObject: TMessagesMultilineInput) => string;\n  };\n};\n\ntype TMessagesMultilineInput = {\n  id: string;\n  description: string;\n  defaultMessage: string;\n};\n\nconst LeftColumn = styled.div`\n  flex: 1;\n`;\n\nconst RightColumn = styled.div`\n  position: relative;\n  flex: 0;\n  display: flex;\n  align-items: flex-start;\n`;\n\nconst Row = styled.div`\n  display: flex;\n  justify-content: flex-end;\n`;\n\nconst TranslationInput = (props: TranslationInputProps) => {\n  const [contentRowCount, setContentRowCount] = useState(\n    TranslationInput.MIN_ROW_COUNT\n  );\n\n  const handleHeightChange = useCallback(\n    (_, rowCount) => {\n      setContentRowCount(rowCount);\n    },\n    [setContentRowCount]\n  );\n\n  const { onChange } = props;\n\n  const handleChange = useCallback<\n    ChangeEventHandler<HTMLLocalizedTextAreaElement>\n  >(\n    (event) => {\n      // We manipulate the event to add the language to the target.\n      // That way the users of LocalizedTextInput's onChange can read\n      // event.target.language and event.target.value to determine the next value.\n      //\n      // We only need this information for the story, the MC application code will\n      // never need to access the information in such an inconvenient way, as\n      // Formik can deal with a name like \"foo.en\" and sets the value correctly.\n      // We can't use this as we aren't guaranteed a name in the story as the user\n      // might clear it using the knob, and then we can't parse the language from\n      // the input name anymore.\n      event.target.language = props.language;\n      onChange?.(event);\n    },\n    [onChange, props.language]\n  );\n\n  const { onFocus, onToggle } = props;\n  const handleFocus = useCallback(() => {\n    // Expand the input on focus\n    if (props.isCollapsed) onToggle?.();\n    if (onFocus) onFocus();\n  }, [props.isCollapsed, onFocus, onToggle]);\n\n  // This checks if the content in the textarea overflows the minimum\n  // amount of lines it should have when collapsed\n  const contentExceedsShownRows =\n    contentRowCount > TranslationInput.MIN_ROW_COUNT;\n\n  const shouldToggleButtonTakeSpace =\n    /*\n      - if hasLanguagesControl and there are no errors/warnings to display\n      - then the toggleButton is absolutely positioned\n      This is because the toggle button is placed next to the LocalizedInputToggle without being siblings in the DOM.\n      If there is a error or warning showing,\n      then it can be placed statically because it will then be a sibling to the error/warning message\n      and LocalizedInputToggle is placed below the errors/warnings.\n    */\n    (!props.isCollapsed &&\n      contentExceedsShownRows &&\n      !props.hasLanguagesControl) ||\n    props.error ||\n    props.warning;\n\n  if (!props.isReadOnly) {\n    warning(\n      typeof props.onChange === 'function',\n      'LocalizedMultilineTextInput/TranslationInput: \"onChange\" is required when isReadOnly is not true'\n    );\n  }\n\n  return (\n    <Stack scale=\"xs\">\n      <div\n        key={props.language}\n        css={css`\n          width: 100%;\n          position: relative;\n          display: flex;\n        `}\n      >\n        <label htmlFor={props.id} css={getLanguageLabelStyles(props)}>\n          <span>{props.language.toUpperCase()}</span>\n        </label>\n        <MultilineInput\n          id={props.id}\n          name={props.name}\n          autoComplete={props.autoComplete}\n          value={props.value}\n          onChange={handleChange}\n          onHeightChange={handleHeightChange}\n          onBlur={props.onBlur}\n          onFocus={handleFocus}\n          isDisabled={props.isDisabled}\n          placeholder={props.placeholder}\n          css={getTextareaStyles(props)}\n          hasError={props.hasError}\n          hasWarning={props.hasWarning}\n          isReadOnly={props.isReadOnly}\n          isAutofocussed={props.isAutofocussed}\n          isOpen={!props.isCollapsed}\n          {...filterDataAttributes(props)}\n          /* ARIA */\n          aria-invalid={props['aria-invalid']}\n          aria-errormessage={props['aria-errormessage']}\n        />\n      </div>\n      <Row\n        // NOTE: applying this style withing the `styled` component results in the production\n        // bundle to apply the style in the wrong order.\n        // For instance, we need to override the marging of the spacing component, which also\n        // uses `!important`.\n        // Anyway, apparently by passing the style as a `css` prop to the `styled` component\n        // does the trick.\n        // TODO: revisit the logic and the implementation to maybe avoid having to apply this style.\n        css={css`\n          margin-top: ${shouldToggleButtonTakeSpace\n            ? 'inherit'\n            : '0px !important'};\n        `}\n      >\n        {(() => {\n          if (props.error)\n            return (\n              <LeftColumn>\n                <div>{props.error}</div>\n              </LeftColumn>\n            );\n          if (props.warning)\n            return (\n              <LeftColumn>\n                <div>{props.warning}</div>\n              </LeftColumn>\n            );\n          return null;\n        })()}\n        {!props.isCollapsed && contentExceedsShownRows && (\n          <>\n            <LeftColumn />\n            <RightColumn>\n              <ToggleButtonWrapper\n                css={[\n                  !shouldToggleButtonTakeSpace &&\n                    css`\n                      position: absolute;\n                      top: 0;\n                      right: 0;\n                      margin-top: ${designTokens.spacing10};\n                    `,\n                ]}\n              >\n                <FlatButton\n                  onClick={props.onToggle}\n                  isDisabled={props.isDisabled}\n                  label={props.intl.formatMessage(\n                    messagesMultilineInput.collapse\n                  )}\n                  icon={<AngleUpIcon size=\"small\" />}\n                />\n              </ToggleButtonWrapper>\n            </RightColumn>\n          </>\n        )}\n      </Row>\n    </Stack>\n  );\n};\n\nTranslationInput.displayName = 'TranslationInput';\n\n// The minimum ammount of rows the MultilineTextInput will show.\n// When the input is closed, this is used as the maximum row count as well\n// so that the input \"collapses\".\nTranslationInput.MIN_ROW_COUNT = 1;\n\nexport default TranslationInput;\n"]} */"),
|
|
255
260
|
children: [function () {
|
|
256
261
|
if (props.error) return jsxRuntime.jsx(LeftColumn, {
|
|
257
262
|
children: jsxRuntime.jsx("div", {
|
|
@@ -267,7 +272,7 @@ var TranslationInput = function TranslationInput(props) {
|
|
|
267
272
|
}(), !props.isCollapsed && contentExceedsShownRows && jsxRuntime.jsxs(jsxRuntime.Fragment, {
|
|
268
273
|
children: [jsxRuntime.jsx(LeftColumn, {}), jsxRuntime.jsx(RightColumn, {
|
|
269
274
|
children: jsxRuntime.jsx(ToggleButtonWrapper, {
|
|
270
|
-
css: [!shouldToggleButtonTakeSpace && /*#__PURE__*/react.css("position:absolute;top:0;right:0;margin-top:", designSystem.designTokens.spacing10, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:TranslationInput;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["translation-input.tsx"],"names":[],"mappings":"AAmOuB","file":"translation-input.tsx","sourcesContent":["import {\n  useState,\n  useCallback,\n  type ChangeEventHandler,\n  type FocusEventHandler,\n  type ReactNode,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport { AngleUpIcon } from '@commercetools-uikit/icons';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport { filterDataAttributes, warning } from '@commercetools-uikit/utils';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport Text from '@commercetools-uikit/text';\nimport {\n  MultilineInput,\n  messagesMultilineInput,\n} from '@commercetools-uikit/input-utils';\nimport {\n  getTextareaStyles,\n  getLanguageLabelStyles,\n  ToggleButtonWrapper,\n} from './translation-input.styles';\n\ninterface HTMLLocalizedTextAreaElement extends HTMLTextAreaElement {\n  language: string;\n}\n\ntype TranslationInputProps = {\n  /**\n   * Indicate if the value entered in the input is invalid.\n   */\n  'aria-invalid'?: boolean;\n  /**\n   * HTML ID of an element containing an error message related to the input.\n   */\n  'aria-errormessage'?: string;\n  onChange?: ChangeEventHandler<HTMLLocalizedTextAreaElement>;\n  language: string;\n  onFocus?: () => void;\n  onToggle?: () => void;\n  isCollapsed?: boolean;\n  hasLanguagesControl?: boolean;\n  warning?: ReactNode;\n  error?: ReactNode;\n  id?: string;\n  name?: string;\n  autoComplete?: string;\n  value: string;\n  onBlur?: FocusEventHandler<HTMLLocalizedTextAreaElement>;\n  isDisabled?: boolean;\n  placeholder?: string;\n  hasWarning?: boolean;\n  hasError?: boolean;\n  isReadOnly?: boolean;\n  isAutofocussed?: boolean;\n  intl: {\n    formatMessage: (messageObject: TMessagesMultilineInput) => string;\n  };\n};\n\ntype TMessagesMultilineInput = {\n  id: string;\n  description: string;\n  defaultMessage: string;\n};\n\nconst LeftColumn = styled.div`\n  flex: 1;\n`;\n\nconst RightColumn = styled.div`\n  position: relative;\n  flex: 0;\n  display: flex;\n  align-items: flex-start;\n`;\n\nconst Row = styled.div`\n  display: flex;\n  justify-content: flex-end;\n`;\n\nconst TranslationInput = (props: TranslationInputProps) => {\n  const [contentRowCount, setContentRowCount] = useState(\n    TranslationInput.MIN_ROW_COUNT\n  );\n\n  const handleHeightChange = useCallback(\n    (_, rowCount) => {\n      setContentRowCount(rowCount);\n    },\n    [setContentRowCount]\n  );\n\n  const { onChange } = props;\n\n  const handleChange = useCallback<\n    ChangeEventHandler<HTMLLocalizedTextAreaElement>\n  >(\n    (event) => {\n      // We manipulate the event to add the language to the target.\n      // That way the users of LocalizedTextInput's onChange can read\n      // event.target.language and event.target.value to determine the next value.\n      //\n      // We only need this information for the story, the MC application code will\n      // never need to access the information in such an inconvenient way, as\n      // Formik can deal with a name like \"foo.en\" and sets the value correctly.\n      // We can't use this as we aren't guaranteed a name in the story as the user\n      // might clear it using the knob, and then we can't parse the language from\n      // the input name anymore.\n      event.target.language = props.language;\n      onChange?.(event);\n    },\n    [onChange, props.language]\n  );\n\n  const { onFocus, onToggle } = props;\n  const handleFocus = useCallback(() => {\n    // Expand the input on focus\n    if (props.isCollapsed) onToggle?.();\n    if (onFocus) onFocus();\n  }, [props.isCollapsed, onFocus, onToggle]);\n\n  // This checks if the content in the textarea overflows the minimum\n  // amount of lines it should have when collapsed\n  const contentExceedsShownRows =\n    contentRowCount > TranslationInput.MIN_ROW_COUNT;\n\n  const shouldToggleButtonTakeSpace =\n    /*\n      - if hasLanguagesControl and there are no errors/warnings to display\n      - then the toggleButton is absolutely positioned\n      This is because the toggle button is placed next to the LocalizedInputToggle without being siblings in the DOM.\n      If there is a error or warning showing,\n      then it can be placed statically because it will then be a sibling to the error/warning message\n      and LocalizedInputToggle is placed below the errors/warnings.\n    */\n    (!props.isCollapsed &&\n      contentExceedsShownRows &&\n      !props.hasLanguagesControl) ||\n    props.error ||\n    props.warning;\n\n  if (!props.isReadOnly) {\n    warning(\n      typeof props.onChange === 'function',\n      'LocalizedMultilineTextInput/TranslationInput: \"onChange\" is required when isReadOnly is not true'\n    );\n  }\n\n  return (\n    <Stack scale=\"xs\">\n      <div\n        key={props.language}\n        css={css`\n          width: 100%;\n          position: relative;\n          display: flex;\n        `}\n      >\n        <label htmlFor={props.id} css={getLanguageLabelStyles(props)}>\n          {/* FIXME: add proper tone for disabled when tones are refactored */}\n          <Text.Detail tone=\"secondary\">\n            {props.language.toUpperCase()}\n          </Text.Detail>\n        </label>\n        <MultilineInput\n          id={props.id}\n          name={props.name}\n          autoComplete={props.autoComplete}\n          value={props.value}\n          onChange={handleChange}\n          onHeightChange={handleHeightChange}\n          onBlur={props.onBlur}\n          onFocus={handleFocus}\n          isDisabled={props.isDisabled}\n          placeholder={props.placeholder}\n          css={getTextareaStyles(props)}\n          hasError={props.hasError}\n          hasWarning={props.hasWarning}\n          isReadOnly={props.isReadOnly}\n          isAutofocussed={props.isAutofocussed}\n          isOpen={!props.isCollapsed}\n          {...filterDataAttributes(props)}\n          /* ARIA */\n          aria-invalid={props['aria-invalid']}\n          aria-errormessage={props['aria-errormessage']}\n        />\n      </div>\n      <Row\n        // NOTE: applying this style withing the `styled` component results in the production\n        // bundle to apply the style in the wrong order.\n        // For instance, we need to override the marging of the spacing component, which also\n        // uses `!important`.\n        // Anyway, apparently by passing the style as a `css` prop to the `styled` component\n        // does the trick.\n        // TODO: revisit the logic and the implementation to maybe avoid having to apply this style.\n        css={css`\n          margin-top: ${shouldToggleButtonTakeSpace\n            ? 'inherit'\n            : '0px !important'};\n        `}\n      >\n        {(() => {\n          if (props.error)\n            return (\n              <LeftColumn>\n                <div>{props.error}</div>\n              </LeftColumn>\n            );\n          if (props.warning)\n            return (\n              <LeftColumn>\n                <div>{props.warning}</div>\n              </LeftColumn>\n            );\n          return null;\n        })()}\n        {!props.isCollapsed && contentExceedsShownRows && (\n          <>\n            <LeftColumn />\n            <RightColumn>\n              <ToggleButtonWrapper\n                css={[\n                  !shouldToggleButtonTakeSpace &&\n                    css`\n                      position: absolute;\n                      top: 0;\n                      right: 0;\n                      margin-top: ${designTokens.spacing10};\n                    `,\n                ]}\n              >\n                <FlatButton\n                  onClick={props.onToggle}\n                  isDisabled={props.isDisabled}\n                  label={props.intl.formatMessage(\n                    messagesMultilineInput.collapse\n                  )}\n                  icon={<AngleUpIcon size=\"small\" />}\n                />\n              </ToggleButtonWrapper>\n            </RightColumn>\n          </>\n        )}\n      </Row>\n    </Stack>\n  );\n};\n\nTranslationInput.displayName = 'TranslationInput';\n\n// The minimum ammount of rows the MultilineTextInput will show.\n// When the input is closed, this is used as the maximum row count as well\n// so that the input \"collapses\".\nTranslationInput.MIN_ROW_COUNT = 1;\n\nexport default TranslationInput;\n"]} */"), process.env.NODE_ENV === "production" ? "" : ";label:TranslationInput;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["translation-input.tsx"],"names":[],"mappings":"AAiOgB","file":"translation-input.tsx","sourcesContent":["import {\n  useState,\n  useCallback,\n  type ChangeEventHandler,\n  type FocusEventHandler,\n  type ReactNode,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport { AngleUpIcon } from '@commercetools-uikit/icons';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport { filterDataAttributes, warning } from '@commercetools-uikit/utils';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport Text from '@commercetools-uikit/text';\nimport {\n  MultilineInput,\n  messagesMultilineInput,\n} from '@commercetools-uikit/input-utils';\nimport {\n  getTextareaStyles,\n  getLanguageLabelStyles,\n  ToggleButtonWrapper,\n} from './translation-input.styles';\n\ninterface HTMLLocalizedTextAreaElement extends HTMLTextAreaElement {\n  language: string;\n}\n\ntype TranslationInputProps = {\n  /**\n   * Indicate if the value entered in the input is invalid.\n   */\n  'aria-invalid'?: boolean;\n  /**\n   * HTML ID of an element containing an error message related to the input.\n   */\n  'aria-errormessage'?: string;\n  onChange?: ChangeEventHandler<HTMLLocalizedTextAreaElement>;\n  language: string;\n  onFocus?: () => void;\n  onToggle?: () => void;\n  isCollapsed?: boolean;\n  hasLanguagesControl?: boolean;\n  warning?: ReactNode;\n  error?: ReactNode;\n  id?: string;\n  name?: string;\n  autoComplete?: string;\n  value: string;\n  onBlur?: FocusEventHandler<HTMLLocalizedTextAreaElement>;\n  isDisabled?: boolean;\n  placeholder?: string;\n  hasWarning?: boolean;\n  hasError?: boolean;\n  isReadOnly?: boolean;\n  isAutofocussed?: boolean;\n  intl: {\n    formatMessage: (messageObject: TMessagesMultilineInput) => string;\n  };\n};\n\ntype TMessagesMultilineInput = {\n  id: string;\n  description: string;\n  defaultMessage: string;\n};\n\nconst LeftColumn = styled.div`\n  flex: 1;\n`;\n\nconst RightColumn = styled.div`\n  position: relative;\n  flex: 0;\n  display: flex;\n  align-items: flex-start;\n`;\n\nconst Row = styled.div`\n  display: flex;\n  justify-content: flex-end;\n`;\n\nconst TranslationInput = (props: TranslationInputProps) => {\n  const [contentRowCount, setContentRowCount] = useState(\n    TranslationInput.MIN_ROW_COUNT\n  );\n\n  const handleHeightChange = useCallback(\n    (_, rowCount) => {\n      setContentRowCount(rowCount);\n    },\n    [setContentRowCount]\n  );\n\n  const { onChange } = props;\n\n  const handleChange = useCallback<\n    ChangeEventHandler<HTMLLocalizedTextAreaElement>\n  >(\n    (event) => {\n      // We manipulate the event to add the language to the target.\n      // That way the users of LocalizedTextInput's onChange can read\n      // event.target.language and event.target.value to determine the next value.\n      //\n      // We only need this information for the story, the MC application code will\n      // never need to access the information in such an inconvenient way, as\n      // Formik can deal with a name like \"foo.en\" and sets the value correctly.\n      // We can't use this as we aren't guaranteed a name in the story as the user\n      // might clear it using the knob, and then we can't parse the language from\n      // the input name anymore.\n      event.target.language = props.language;\n      onChange?.(event);\n    },\n    [onChange, props.language]\n  );\n\n  const { onFocus, onToggle } = props;\n  const handleFocus = useCallback(() => {\n    // Expand the input on focus\n    if (props.isCollapsed) onToggle?.();\n    if (onFocus) onFocus();\n  }, [props.isCollapsed, onFocus, onToggle]);\n\n  // This checks if the content in the textarea overflows the minimum\n  // amount of lines it should have when collapsed\n  const contentExceedsShownRows =\n    contentRowCount > TranslationInput.MIN_ROW_COUNT;\n\n  const shouldToggleButtonTakeSpace =\n    /*\n      - if hasLanguagesControl and there are no errors/warnings to display\n      - then the toggleButton is absolutely positioned\n      This is because the toggle button is placed next to the LocalizedInputToggle without being siblings in the DOM.\n      If there is a error or warning showing,\n      then it can be placed statically because it will then be a sibling to the error/warning message\n      and LocalizedInputToggle is placed below the errors/warnings.\n    */\n    (!props.isCollapsed &&\n      contentExceedsShownRows &&\n      !props.hasLanguagesControl) ||\n    props.error ||\n    props.warning;\n\n  if (!props.isReadOnly) {\n    warning(\n      typeof props.onChange === 'function',\n      'LocalizedMultilineTextInput/TranslationInput: \"onChange\" is required when isReadOnly is not true'\n    );\n  }\n\n  return (\n    <Stack scale=\"xs\">\n      <div\n        key={props.language}\n        css={css`\n          width: 100%;\n          position: relative;\n          display: flex;\n        `}\n      >\n        <label htmlFor={props.id} css={getLanguageLabelStyles(props)}>\n          {/* FIXME: add proper tone for disabled when tones are refactored */}\n          <Text.Detail tone=\"secondary\">\n            {props.language.toUpperCase()}\n          </Text.Detail>\n        </label>\n        <MultilineInput\n          id={props.id}\n          name={props.name}\n          autoComplete={props.autoComplete}\n          value={props.value}\n          onChange={handleChange}\n          onHeightChange={handleHeightChange}\n          onBlur={props.onBlur}\n          onFocus={handleFocus}\n          isDisabled={props.isDisabled}\n          placeholder={props.placeholder}\n          css={getTextareaStyles(props)}\n          hasError={props.hasError}\n          hasWarning={props.hasWarning}\n          isReadOnly={props.isReadOnly}\n          isAutofocussed={props.isAutofocussed}\n          isOpen={!props.isCollapsed}\n          {...filterDataAttributes(props)}\n          /* ARIA */\n          aria-invalid={props['aria-invalid']}\n          aria-errormessage={props['aria-errormessage']}\n        />\n      </div>\n      <Row\n        // NOTE: applying this style withing the `styled` component results in the production\n        // bundle to apply the style in the wrong order.\n        // For instance, we need to override the marging of the spacing component, which also\n        // uses `!important`.\n        // Anyway, apparently by passing the style as a `css` prop to the `styled` component\n        // does the trick.\n        // TODO: revisit the logic and the implementation to maybe avoid having to apply this style.\n        css={css`\n          margin-top: ${shouldToggleButtonTakeSpace\n            ? 'inherit'\n            : '0px !important'};\n        `}\n      >\n        {(() => {\n          if (props.error)\n            return (\n              <LeftColumn>\n                <div>{props.error}</div>\n              </LeftColumn>\n            );\n          if (props.warning)\n            return (\n              <LeftColumn>\n                <div>{props.warning}</div>\n              </LeftColumn>\n            );\n          return null;\n        })()}\n        {!props.isCollapsed && contentExceedsShownRows && (\n          <>\n            <LeftColumn />\n            <RightColumn>\n              <ToggleButtonWrapper\n                css={[\n                  !shouldToggleButtonTakeSpace &&\n                    css`\n                      position: absolute;\n                      top: 0;\n                      right: 0;\n                      margin-top: ${designTokens.spacing10};\n                    `,\n                ]}\n              >\n                <FlatButton\n                  onClick={props.onToggle}\n                  isDisabled={props.isDisabled}\n                  label={props.intl.formatMessage(\n                    messagesMultilineInput.collapse\n                  )}\n                  icon={<AngleUpIcon size=\"small\" />}\n                />\n              </ToggleButtonWrapper>\n            </RightColumn>\n          </>\n        )}\n      </Row>\n    </Stack>\n  );\n};\n\nTranslationInput.displayName = 'TranslationInput';\n\n// The minimum ammount of rows the MultilineTextInput will show.\n// When the input is closed, this is used as the maximum row count as well\n// so that the input \"collapses\".\nTranslationInput.MIN_ROW_COUNT = 1;\n\nexport default TranslationInput;\n"]} */"],
|
|
275
|
+
css: [!shouldToggleButtonTakeSpace && /*#__PURE__*/react.css("position:absolute;top:0;right:0;margin-top:", designSystem.designTokens.spacing10, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:TranslationInput;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["translation-input.tsx"],"names":[],"mappings":"AA+NuB","file":"translation-input.tsx","sourcesContent":["import {\n  useState,\n  useCallback,\n  type ChangeEventHandler,\n  type FocusEventHandler,\n  type ReactNode,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport { AngleUpIcon } from '@commercetools-uikit/icons';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport { filterDataAttributes, warning } from '@commercetools-uikit/utils';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport {\n  MultilineInput,\n  messagesMultilineInput,\n} from '@commercetools-uikit/input-utils';\nimport {\n  getTextareaStyles,\n  getLanguageLabelStyles,\n  ToggleButtonWrapper,\n} from './translation-input.styles';\n\ninterface HTMLLocalizedTextAreaElement extends HTMLTextAreaElement {\n  language: string;\n}\n\ntype TranslationInputProps = {\n  /**\n   * Indicate if the value entered in the input is invalid.\n   */\n  'aria-invalid'?: boolean;\n  /**\n   * HTML ID of an element containing an error message related to the input.\n   */\n  'aria-errormessage'?: string;\n  onChange?: ChangeEventHandler<HTMLLocalizedTextAreaElement>;\n  language: string;\n  onFocus?: () => void;\n  onToggle?: () => void;\n  isCollapsed?: boolean;\n  hasLanguagesControl?: boolean;\n  warning?: ReactNode;\n  error?: ReactNode;\n  id?: string;\n  name?: string;\n  autoComplete?: string;\n  value: string;\n  onBlur?: FocusEventHandler<HTMLLocalizedTextAreaElement>;\n  isDisabled?: boolean;\n  placeholder?: string;\n  hasWarning?: boolean;\n  hasError?: boolean;\n  isReadOnly?: boolean;\n  isAutofocussed?: boolean;\n  intl: {\n    formatMessage: (messageObject: TMessagesMultilineInput) => string;\n  };\n};\n\ntype TMessagesMultilineInput = {\n  id: string;\n  description: string;\n  defaultMessage: string;\n};\n\nconst LeftColumn = styled.div`\n  flex: 1;\n`;\n\nconst RightColumn = styled.div`\n  position: relative;\n  flex: 0;\n  display: flex;\n  align-items: flex-start;\n`;\n\nconst Row = styled.div`\n  display: flex;\n  justify-content: flex-end;\n`;\n\nconst TranslationInput = (props: TranslationInputProps) => {\n  const [contentRowCount, setContentRowCount] = useState(\n    TranslationInput.MIN_ROW_COUNT\n  );\n\n  const handleHeightChange = useCallback(\n    (_, rowCount) => {\n      setContentRowCount(rowCount);\n    },\n    [setContentRowCount]\n  );\n\n  const { onChange } = props;\n\n  const handleChange = useCallback<\n    ChangeEventHandler<HTMLLocalizedTextAreaElement>\n  >(\n    (event) => {\n      // We manipulate the event to add the language to the target.\n      // That way the users of LocalizedTextInput's onChange can read\n      // event.target.language and event.target.value to determine the next value.\n      //\n      // We only need this information for the story, the MC application code will\n      // never need to access the information in such an inconvenient way, as\n      // Formik can deal with a name like \"foo.en\" and sets the value correctly.\n      // We can't use this as we aren't guaranteed a name in the story as the user\n      // might clear it using the knob, and then we can't parse the language from\n      // the input name anymore.\n      event.target.language = props.language;\n      onChange?.(event);\n    },\n    [onChange, props.language]\n  );\n\n  const { onFocus, onToggle } = props;\n  const handleFocus = useCallback(() => {\n    // Expand the input on focus\n    if (props.isCollapsed) onToggle?.();\n    if (onFocus) onFocus();\n  }, [props.isCollapsed, onFocus, onToggle]);\n\n  // This checks if the content in the textarea overflows the minimum\n  // amount of lines it should have when collapsed\n  const contentExceedsShownRows =\n    contentRowCount > TranslationInput.MIN_ROW_COUNT;\n\n  const shouldToggleButtonTakeSpace =\n    /*\n      - if hasLanguagesControl and there are no errors/warnings to display\n      - then the toggleButton is absolutely positioned\n      This is because the toggle button is placed next to the LocalizedInputToggle without being siblings in the DOM.\n      If there is a error or warning showing,\n      then it can be placed statically because it will then be a sibling to the error/warning message\n      and LocalizedInputToggle is placed below the errors/warnings.\n    */\n    (!props.isCollapsed &&\n      contentExceedsShownRows &&\n      !props.hasLanguagesControl) ||\n    props.error ||\n    props.warning;\n\n  if (!props.isReadOnly) {\n    warning(\n      typeof props.onChange === 'function',\n      'LocalizedMultilineTextInput/TranslationInput: \"onChange\" is required when isReadOnly is not true'\n    );\n  }\n\n  return (\n    <Stack scale=\"xs\">\n      <div\n        key={props.language}\n        css={css`\n          width: 100%;\n          position: relative;\n          display: flex;\n        `}\n      >\n        <label htmlFor={props.id} css={getLanguageLabelStyles(props)}>\n          <span>{props.language.toUpperCase()}</span>\n        </label>\n        <MultilineInput\n          id={props.id}\n          name={props.name}\n          autoComplete={props.autoComplete}\n          value={props.value}\n          onChange={handleChange}\n          onHeightChange={handleHeightChange}\n          onBlur={props.onBlur}\n          onFocus={handleFocus}\n          isDisabled={props.isDisabled}\n          placeholder={props.placeholder}\n          css={getTextareaStyles(props)}\n          hasError={props.hasError}\n          hasWarning={props.hasWarning}\n          isReadOnly={props.isReadOnly}\n          isAutofocussed={props.isAutofocussed}\n          isOpen={!props.isCollapsed}\n          {...filterDataAttributes(props)}\n          /* ARIA */\n          aria-invalid={props['aria-invalid']}\n          aria-errormessage={props['aria-errormessage']}\n        />\n      </div>\n      <Row\n        // NOTE: applying this style withing the `styled` component results in the production\n        // bundle to apply the style in the wrong order.\n        // For instance, we need to override the marging of the spacing component, which also\n        // uses `!important`.\n        // Anyway, apparently by passing the style as a `css` prop to the `styled` component\n        // does the trick.\n        // TODO: revisit the logic and the implementation to maybe avoid having to apply this style.\n        css={css`\n          margin-top: ${shouldToggleButtonTakeSpace\n            ? 'inherit'\n            : '0px !important'};\n        `}\n      >\n        {(() => {\n          if (props.error)\n            return (\n              <LeftColumn>\n                <div>{props.error}</div>\n              </LeftColumn>\n            );\n          if (props.warning)\n            return (\n              <LeftColumn>\n                <div>{props.warning}</div>\n              </LeftColumn>\n            );\n          return null;\n        })()}\n        {!props.isCollapsed && contentExceedsShownRows && (\n          <>\n            <LeftColumn />\n            <RightColumn>\n              <ToggleButtonWrapper\n                css={[\n                  !shouldToggleButtonTakeSpace &&\n                    css`\n                      position: absolute;\n                      top: 0;\n                      right: 0;\n                      margin-top: ${designTokens.spacing10};\n                    `,\n                ]}\n              >\n                <FlatButton\n                  onClick={props.onToggle}\n                  isDisabled={props.isDisabled}\n                  label={props.intl.formatMessage(\n                    messagesMultilineInput.collapse\n                  )}\n                  icon={<AngleUpIcon size=\"small\" />}\n                />\n              </ToggleButtonWrapper>\n            </RightColumn>\n          </>\n        )}\n      </Row>\n    </Stack>\n  );\n};\n\nTranslationInput.displayName = 'TranslationInput';\n\n// The minimum ammount of rows the MultilineTextInput will show.\n// When the input is closed, this is used as the maximum row count as well\n// so that the input \"collapses\".\nTranslationInput.MIN_ROW_COUNT = 1;\n\nexport default TranslationInput;\n"]} */"), process.env.NODE_ENV === "production" ? "" : ";label:TranslationInput;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["translation-input.tsx"],"names":[],"mappings":"AA6NgB","file":"translation-input.tsx","sourcesContent":["import {\n  useState,\n  useCallback,\n  type ChangeEventHandler,\n  type FocusEventHandler,\n  type ReactNode,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport { AngleUpIcon } from '@commercetools-uikit/icons';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport { filterDataAttributes, warning } from '@commercetools-uikit/utils';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport {\n  MultilineInput,\n  messagesMultilineInput,\n} from '@commercetools-uikit/input-utils';\nimport {\n  getTextareaStyles,\n  getLanguageLabelStyles,\n  ToggleButtonWrapper,\n} from './translation-input.styles';\n\ninterface HTMLLocalizedTextAreaElement extends HTMLTextAreaElement {\n  language: string;\n}\n\ntype TranslationInputProps = {\n  /**\n   * Indicate if the value entered in the input is invalid.\n   */\n  'aria-invalid'?: boolean;\n  /**\n   * HTML ID of an element containing an error message related to the input.\n   */\n  'aria-errormessage'?: string;\n  onChange?: ChangeEventHandler<HTMLLocalizedTextAreaElement>;\n  language: string;\n  onFocus?: () => void;\n  onToggle?: () => void;\n  isCollapsed?: boolean;\n  hasLanguagesControl?: boolean;\n  warning?: ReactNode;\n  error?: ReactNode;\n  id?: string;\n  name?: string;\n  autoComplete?: string;\n  value: string;\n  onBlur?: FocusEventHandler<HTMLLocalizedTextAreaElement>;\n  isDisabled?: boolean;\n  placeholder?: string;\n  hasWarning?: boolean;\n  hasError?: boolean;\n  isReadOnly?: boolean;\n  isAutofocussed?: boolean;\n  intl: {\n    formatMessage: (messageObject: TMessagesMultilineInput) => string;\n  };\n};\n\ntype TMessagesMultilineInput = {\n  id: string;\n  description: string;\n  defaultMessage: string;\n};\n\nconst LeftColumn = styled.div`\n  flex: 1;\n`;\n\nconst RightColumn = styled.div`\n  position: relative;\n  flex: 0;\n  display: flex;\n  align-items: flex-start;\n`;\n\nconst Row = styled.div`\n  display: flex;\n  justify-content: flex-end;\n`;\n\nconst TranslationInput = (props: TranslationInputProps) => {\n  const [contentRowCount, setContentRowCount] = useState(\n    TranslationInput.MIN_ROW_COUNT\n  );\n\n  const handleHeightChange = useCallback(\n    (_, rowCount) => {\n      setContentRowCount(rowCount);\n    },\n    [setContentRowCount]\n  );\n\n  const { onChange } = props;\n\n  const handleChange = useCallback<\n    ChangeEventHandler<HTMLLocalizedTextAreaElement>\n  >(\n    (event) => {\n      // We manipulate the event to add the language to the target.\n      // That way the users of LocalizedTextInput's onChange can read\n      // event.target.language and event.target.value to determine the next value.\n      //\n      // We only need this information for the story, the MC application code will\n      // never need to access the information in such an inconvenient way, as\n      // Formik can deal with a name like \"foo.en\" and sets the value correctly.\n      // We can't use this as we aren't guaranteed a name in the story as the user\n      // might clear it using the knob, and then we can't parse the language from\n      // the input name anymore.\n      event.target.language = props.language;\n      onChange?.(event);\n    },\n    [onChange, props.language]\n  );\n\n  const { onFocus, onToggle } = props;\n  const handleFocus = useCallback(() => {\n    // Expand the input on focus\n    if (props.isCollapsed) onToggle?.();\n    if (onFocus) onFocus();\n  }, [props.isCollapsed, onFocus, onToggle]);\n\n  // This checks if the content in the textarea overflows the minimum\n  // amount of lines it should have when collapsed\n  const contentExceedsShownRows =\n    contentRowCount > TranslationInput.MIN_ROW_COUNT;\n\n  const shouldToggleButtonTakeSpace =\n    /*\n      - if hasLanguagesControl and there are no errors/warnings to display\n      - then the toggleButton is absolutely positioned\n      This is because the toggle button is placed next to the LocalizedInputToggle without being siblings in the DOM.\n      If there is a error or warning showing,\n      then it can be placed statically because it will then be a sibling to the error/warning message\n      and LocalizedInputToggle is placed below the errors/warnings.\n    */\n    (!props.isCollapsed &&\n      contentExceedsShownRows &&\n      !props.hasLanguagesControl) ||\n    props.error ||\n    props.warning;\n\n  if (!props.isReadOnly) {\n    warning(\n      typeof props.onChange === 'function',\n      'LocalizedMultilineTextInput/TranslationInput: \"onChange\" is required when isReadOnly is not true'\n    );\n  }\n\n  return (\n    <Stack scale=\"xs\">\n      <div\n        key={props.language}\n        css={css`\n          width: 100%;\n          position: relative;\n          display: flex;\n        `}\n      >\n        <label htmlFor={props.id} css={getLanguageLabelStyles(props)}>\n          <span>{props.language.toUpperCase()}</span>\n        </label>\n        <MultilineInput\n          id={props.id}\n          name={props.name}\n          autoComplete={props.autoComplete}\n          value={props.value}\n          onChange={handleChange}\n          onHeightChange={handleHeightChange}\n          onBlur={props.onBlur}\n          onFocus={handleFocus}\n          isDisabled={props.isDisabled}\n          placeholder={props.placeholder}\n          css={getTextareaStyles(props)}\n          hasError={props.hasError}\n          hasWarning={props.hasWarning}\n          isReadOnly={props.isReadOnly}\n          isAutofocussed={props.isAutofocussed}\n          isOpen={!props.isCollapsed}\n          {...filterDataAttributes(props)}\n          /* ARIA */\n          aria-invalid={props['aria-invalid']}\n          aria-errormessage={props['aria-errormessage']}\n        />\n      </div>\n      <Row\n        // NOTE: applying this style withing the `styled` component results in the production\n        // bundle to apply the style in the wrong order.\n        // For instance, we need to override the marging of the spacing component, which also\n        // uses `!important`.\n        // Anyway, apparently by passing the style as a `css` prop to the `styled` component\n        // does the trick.\n        // TODO: revisit the logic and the implementation to maybe avoid having to apply this style.\n        css={css`\n          margin-top: ${shouldToggleButtonTakeSpace\n            ? 'inherit'\n            : '0px !important'};\n        `}\n      >\n        {(() => {\n          if (props.error)\n            return (\n              <LeftColumn>\n                <div>{props.error}</div>\n              </LeftColumn>\n            );\n          if (props.warning)\n            return (\n              <LeftColumn>\n                <div>{props.warning}</div>\n              </LeftColumn>\n            );\n          return null;\n        })()}\n        {!props.isCollapsed && contentExceedsShownRows && (\n          <>\n            <LeftColumn />\n            <RightColumn>\n              <ToggleButtonWrapper\n                css={[\n                  !shouldToggleButtonTakeSpace &&\n                    css`\n                      position: absolute;\n                      top: 0;\n                      right: 0;\n                      margin-top: ${designTokens.spacing10};\n                    `,\n                ]}\n              >\n                <FlatButton\n                  onClick={props.onToggle}\n                  isDisabled={props.isDisabled}\n                  label={props.intl.formatMessage(\n                    messagesMultilineInput.collapse\n                  )}\n                  icon={<AngleUpIcon size=\"small\" />}\n                />\n              </ToggleButtonWrapper>\n            </RightColumn>\n          </>\n        )}\n      </Row>\n    </Stack>\n  );\n};\n\nTranslationInput.displayName = 'TranslationInput';\n\n// The minimum ammount of rows the MultilineTextInput will show.\n// When the input is closed, this is used as the maximum row count as well\n// so that the input \"collapses\".\nTranslationInput.MIN_ROW_COUNT = 1;\n\nexport default TranslationInput;\n"]} */"],
|
|
271
276
|
children: jsxRuntime.jsx(FlatButton__default["default"], {
|
|
272
277
|
onClick: props.onToggle,
|
|
273
278
|
isDisabled: props.isDisabled,
|
|
@@ -333,8 +338,6 @@ function ownKeys(object, enumerableOnly) { var keys = _Object$keys__default["def
|
|
|
333
338
|
|
|
334
339
|
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var _context3, _context4; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty__default["default"](_context3 = ownKeys(Object(source), !0)).call(_context3, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](target, _Object$getOwnPropertyDescriptors__default["default"](source)) : _forEachInstanceProperty__default["default"](_context4 = ownKeys(Object(source))).call(_context4, function (key) { _Object$defineProperty__default["default"](target, key, _Object$getOwnPropertyDescriptor__default["default"](source, key)); }); } return target; }
|
|
335
340
|
|
|
336
|
-
function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
337
|
-
|
|
338
341
|
var expandedTranslationsReducer = function expandedTranslationsReducer(state, action) {
|
|
339
342
|
switch (action.type) {
|
|
340
343
|
case 'toggle':
|
|
@@ -362,16 +365,6 @@ var expandedTranslationsReducer = function expandedTranslationsReducer(state, ac
|
|
|
362
365
|
// languages.
|
|
363
366
|
|
|
364
367
|
|
|
365
|
-
var _ref = process.env.NODE_ENV === "production" ? {
|
|
366
|
-
name: "xyzkeb",
|
|
367
|
-
styles: "align-self:flex-start"
|
|
368
|
-
} : {
|
|
369
|
-
name: "1nns3eb-LocalizedMultilineTextInput",
|
|
370
|
-
styles: "align-self:flex-start;label:LocalizedMultilineTextInput;",
|
|
371
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["localized-multiline-text-input.tsx"],"names":[],"mappings":"AAwUoB","file":"localized-multiline-text-input.tsx","sourcesContent":["import {\n  useReducer,\n  useCallback,\n  type ReactNode,\n  type ChangeEventHandler,\n  type FocusEventHandler,\n} from 'react';\nimport { useIntl } from 'react-intl';\nimport { css } from '@emotion/react';\nimport { useToggleState } from '@commercetools-uikit/hooks';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport Constraints from '@commercetools-uikit/constraints';\nimport {\n  sortLanguages,\n  createLocalizedDataAttributes,\n  getHasErrorOnRemainingLanguages,\n  getHasWarningOnRemainingLanguages,\n  isTouched,\n  omitEmptyTranslations,\n  isEmpty,\n  createLocalizedString,\n  getId,\n  getName,\n} from '@commercetools-uikit/localized-utils';\nimport { LocalizedInputToggle } from '@commercetools-uikit/input-utils';\nimport TranslationInput from './translation-input';\nimport RequiredValueErrorMessage from './required-value-error-message';\nimport { warning } from '@commercetools-uikit/utils';\n\ntype TState = {\n  [key: string]: string;\n};\n\ntype TExpandedTranslationsReducerState = {\n  state?: TState;\n};\n\ntype TExpandedTranslationsReducerAction = {\n  type: string;\n  payload: string;\n};\n\ninterface HTMLLocalizedTextAreaElement extends HTMLTextAreaElement {\n  language: string;\n}\n\ntype TLocalizedMultilineTextInputProps = {\n  /**\n   * Used as prefix of HTML `id` property. Each input field id will have the language as a suffix (`${idPrefix}.${lang}`), e.g. `foo.en`\n   */\n  id?: string;\n  /**\n   * Used as HTML `name` property for each input field. Each input field name will have the language as a suffix (`${namePrefix}.${lang}`), e.g. `foo.en`\n   */\n  name?: string;\n  /**\n   * Used as HTML `autocomplete` property\n   */\n  autoComplete?: string;\n  /**\n   * Indicate if the value entered in the input is invalid.\n   */\n  'aria-invalid'?: boolean;\n  /**\n   * HTML ID of an element containing an error message related to the input.\n   */\n  'aria-errormessage'?: string;\n  /**\n   * Values to use. Keyed by language, the values are the actual values, e.g. `{ en: 'Horse', de: 'Pferd' }`\n   * <br />\n   * The input doesn't accept a \"languages\" prop, instead all possible\n   * languages have to exist (with empty or filled strings) on the value:\n   * <br />\n   * { en: 'foo', de: '', es: '' }\n   */\n  value: {\n    [key: string]: string;\n  };\n  /**\n   * Gets called when any input is changed. Is called with the change event of the changed input.\n   */\n  onChange?: ChangeEventHandler<HTMLLocalizedTextAreaElement>;\n  /**\n   * Specifies which language will be shown in case the `LocalizedTextInput` is collapsed.\n   */\n  selectedLanguage: string;\n  /**\n   * Called when input is blurred\n   */\n  onBlur?: FocusEventHandler<HTMLLocalizedTextAreaElement>;\n  /**\n   * Called when input is focused\n   */\n  onFocus?: () => void;\n  /**\n   * Expands input components holding multiline values instead of collpasing them by default.\n   */\n  defaultExpandMultilineText?: boolean;\n  /**\n   * Will hide the language expansion controls when set to `true`. All languages will be shown when set to `true`.\n   */\n  hideLanguageExpansionControls?: boolean;\n  /**\n   * Controls whether one or all languages are visible by default. Pass `true` to show all languages by default.\n   */\n  defaultExpandLanguages?: boolean;\n\n  /**\n   * Sets the focus on the first input when `true` is passed.\n   */\n  isAutofocussed?: boolean;\n  /**\n   * Disables all input fields.\n   */\n  isDisabled?: boolean;\n  /**\n   * Disables all input fields and shows them in read-only mode.\n   */\n  isReadOnly?: boolean;\n  /**\n   * Placeholders for each language. Object of the same shape as `value`.\n   */\n  placeholder?: {\n    [key: string]: string;\n  };\n  /**\n   * Horizontal size limit of the input fields.\n   */\n  horizontalConstraint?:\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n  /**\n   * Will apply the error state to each input without showing any error message.\n   */\n  hasError?: boolean;\n  /**\n   * Will apply the warning state to each input without showing any error message.\n   */\n  hasWarning?: boolean;\n  /**\n   * Used to show errors underneath the inputs of specific currencies. Pass an object whose key is a currency and whose value is the error to show for that key.\n   */\n  errors?: {\n    [key: string]: ReactNode;\n  };\n  /**\n   * Used to show warnings underneath the inputs of specific currencies. Pass an object whose key is a currency and whose value is the warning to show for that key.\n   */\n  warnings?: {\n    [key: string]: ReactNode;\n  };\n};\n\nconst expandedTranslationsReducer = (\n  state: TExpandedTranslationsReducerState,\n  action: TExpandedTranslationsReducerAction\n) => {\n  switch (action.type) {\n    case 'toggle':\n      return {\n        ...state,\n        [action.payload]: !state[action.payload as keyof typeof state],\n      };\n\n    case 'toggleAll': {\n      const newState = Object.keys(state).reduce((translations, locale) => {\n        return {\n          [locale]: true,\n          ...translations,\n        };\n      }, {});\n      return newState;\n    }\n    default:\n      return state;\n  }\n};\n\n// This component supports expanding/collapsing multiline inputs, but it also\n// supports showing/hiding the remaining languages.\n// These two features are both about opening/closing something, and so the code\n// can get quite confusing. We try to stick to expand/collapse for the\n// multiline inputs, while we use show/hide/open/close for the remaining\n// languages.\nconst LocalizedMultilineTextInput = (\n  props: TLocalizedMultilineTextInputProps\n) => {\n  const intl = useIntl();\n\n  const initialExpandedTranslationsState = Object.keys(props.value).reduce(\n    (translations, locale) => {\n      return {\n        [locale]: Boolean(props.defaultExpandMultilineText),\n        ...translations,\n      };\n    },\n    {}\n  );\n\n  const [expandedTranslationsState, expandedTranslationsDispatch] = useReducer<\n    (\n      prevState: TExpandedTranslationsReducerState,\n      action: TExpandedTranslationsReducerAction\n    ) => TState\n  >(expandedTranslationsReducer, initialExpandedTranslationsState);\n\n  const defaultExpansionState =\n    props.hideLanguageExpansionControls ||\n    props.defaultExpandLanguages ||\n    // useToggleState's default is `true`, but we want `false`\n    false;\n\n  const [areLanguagesOpened, toggleLanguages] = useToggleState(\n    defaultExpansionState\n  );\n\n  const toggleLanguage = useCallback(\n    (language) => {\n      expandedTranslationsDispatch({ type: 'toggle', payload: language });\n    },\n    [expandedTranslationsDispatch]\n  );\n\n  const languages: Array<string> = sortLanguages(\n    props.selectedLanguage,\n    Object.keys(props.value)\n  );\n\n  const hasErrorInRemainingLanguages =\n    props.hasError ||\n    getHasErrorOnRemainingLanguages(props.errors, props.selectedLanguage);\n  const hasWarningInRemainingLanguages =\n    props.hasWarning ||\n    getHasWarningOnRemainingLanguages(props.warnings, props.selectedLanguage);\n\n  if (hasErrorInRemainingLanguages || hasWarningInRemainingLanguages) {\n    if (!areLanguagesOpened) {\n      // this update within render replaces the old `getDerivedStateFromProps` functionality\n      // https://reactjs.org/docs/hooks-faq.html#how-do-i-implement-getderivedstatefromprops\n      toggleLanguages();\n    }\n  }\n\n  const onLocalizedInputToggle = useCallback(\n    () => toggleLanguages(),\n    [toggleLanguages]\n  );\n\n  const shouldRenderLanguagesButton =\n    languages.length > 1 && !props.hideLanguageExpansionControls;\n\n  if (!props.isReadOnly) {\n    warning(\n      typeof props.onChange === 'function',\n      'LocalizedMultilineTextInput: \"onChange\" is required when isReadOnly is not true'\n    );\n  }\n\n  if (props.hideLanguageExpansionControls) {\n    warning(\n      typeof props.hideLanguageExpansionControls === 'boolean',\n      'LocalizedMultilineTextInput: \"defaultExpandLanguages\" does not have any effect when \"hideLanguageExpansionControls\" is set.'\n    );\n  }\n\n  return (\n    <Constraints.Horizontal max={props.horizontalConstraint}>\n      <Stack scale=\"xs\">\n        <Stack scale=\"s\">\n          {languages.map((language, index) => {\n            const isFirstLanguage = index === 0;\n            if (!isFirstLanguage && !areLanguagesOpened) return null;\n            const isLastLanguage = index === languages.length - 1;\n\n            const hasLanguagesControl =\n              (isFirstLanguage && !areLanguagesOpened) || isLastLanguage;\n\n            return (\n              <TranslationInput\n                key={language}\n                autoComplete={props.autoComplete}\n                id={LocalizedMultilineTextInput.getId(props.id, language)}\n                name={LocalizedMultilineTextInput.getName(props.name, language)}\n                value={props.value[language]}\n                onChange={props.onChange}\n                language={language}\n                isCollapsed={!expandedTranslationsState[language]}\n                onToggle={() => toggleLanguage(language)}\n                placeholder={\n                  props.placeholder ? props.placeholder[language] : undefined\n                }\n                onBlur={props.onBlur}\n                onFocus={props.onFocus}\n                isAutofocussed={index === 0 && props.isAutofocussed}\n                isDisabled={props.isDisabled}\n                isReadOnly={props.isReadOnly}\n                hasError={Boolean(\n                  props.hasError || (props.errors && props.errors[language])\n                )}\n                hasWarning={Boolean(\n                  props.hasWarning ||\n                    (props.warnings && props.warnings[language])\n                )}\n                intl={intl}\n                warning={props.warnings && props.warnings[language]}\n                error={props.errors && props.errors[language]}\n                hasLanguagesControl={hasLanguagesControl}\n                {...createLocalizedDataAttributes(props, language)}\n                /* ARIA */\n                aria-invalid={props['aria-invalid']}\n                aria-errormessage={props['aria-errormessage']}\n              />\n            );\n          })}\n        </Stack>\n        {shouldRenderLanguagesButton && (\n          <div\n            css={css`\n              align-self: flex-start;\n            `}\n          >\n            <LocalizedInputToggle\n              isOpen={areLanguagesOpened}\n              onClick={onLocalizedInputToggle}\n              isDisabled={\n                areLanguagesOpened &&\n                Boolean(\n                  hasErrorInRemainingLanguages || hasWarningInRemainingLanguages\n                )\n              }\n              remainingLocalizations={languages.length - 1}\n            />\n          </div>\n        )}\n      </Stack>\n    </Constraints.Horizontal>\n  );\n};\n\nLocalizedMultilineTextInput.displayName = 'LocalizedMultilineTextInput';\n\nLocalizedMultilineTextInput.RequiredValueErrorMessage =\n  RequiredValueErrorMessage;\n\nLocalizedMultilineTextInput.getId = getId;\n\nLocalizedMultilineTextInput.getName = getName;\n\nLocalizedMultilineTextInput.defaultProps = {\n  horizontalConstraint: 'scale',\n};\n\nLocalizedMultilineTextInput.createLocalizedString = createLocalizedString;\n\nLocalizedMultilineTextInput.isEmpty = isEmpty;\n\nLocalizedMultilineTextInput.omitEmptyTranslations = omitEmptyTranslations;\n\nLocalizedMultilineTextInput.isTouched = isTouched;\n\nexport default LocalizedMultilineTextInput;\n"]} */",
|
|
372
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
373
|
-
};
|
|
374
|
-
|
|
375
368
|
var LocalizedMultilineTextInput = function LocalizedMultilineTextInput(props) {
|
|
376
369
|
var _context2;
|
|
377
370
|
|
|
@@ -465,14 +458,11 @@ var LocalizedMultilineTextInput = function LocalizedMultilineTextInput(props) {
|
|
|
465
458
|
"aria-errormessage": props['aria-errormessage']
|
|
466
459
|
}), language);
|
|
467
460
|
})
|
|
468
|
-
}), shouldRenderLanguagesButton && jsxRuntime.jsx(
|
|
469
|
-
|
|
470
|
-
|
|
471
|
-
|
|
472
|
-
|
|
473
|
-
isDisabled: areLanguagesOpened && Boolean(hasErrorInRemainingLanguages || hasWarningInRemainingLanguages),
|
|
474
|
-
remainingLocalizations: languages.length - 1
|
|
475
|
-
})
|
|
461
|
+
}), shouldRenderLanguagesButton && jsxRuntime.jsx(inputUtils.LocalizedInputToggle, {
|
|
462
|
+
isOpen: areLanguagesOpened,
|
|
463
|
+
onClick: onLocalizedInputToggle,
|
|
464
|
+
isDisabled: areLanguagesOpened && Boolean(hasErrorInRemainingLanguages || hasWarningInRemainingLanguages),
|
|
465
|
+
remainingLocalizations: languages.length - 1
|
|
476
466
|
})]
|
|
477
467
|
})
|
|
478
468
|
});
|
|
@@ -516,7 +506,7 @@ LocalizedMultilineTextInput.isTouched = localizedUtils.isTouched;
|
|
|
516
506
|
var LocalizedMultilineTextInput$1 = LocalizedMultilineTextInput;
|
|
517
507
|
|
|
518
508
|
// NOTE: This string will be replaced on build time with the package version.
|
|
519
|
-
var version = "15.
|
|
509
|
+
var version = "15.10.0";
|
|
520
510
|
|
|
521
511
|
exports["default"] = LocalizedMultilineTextInput$1;
|
|
522
512
|
exports.version = version;
|