@commercetools-uikit/localized-multiline-text-input 19.22.0 → 19.22.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -61,8 +61,7 @@ var _ref$1 = process.env.NODE_ENV === "production" ? {
61
61
  styles: "overflow:hidden"
62
62
  } : {
63
63
  name: "1h6gnzr-baseStyles",
64
- styles: "overflow:hidden;label:baseStyles;",
65
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRyYW5zbGF0aW9uLWlucHV0LnN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF1QlMiLCJmaWxlIjoidHJhbnNsYXRpb24taW5wdXQuc3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5cbi8vIE5PVEU6IG9yZGVyIGlzIGltcG9ydGFudCBoZXJlXG4vLyAqIGEgZGlzYWJsZWQtZmllbGQgY3VycmVudGx5IGRvZXMgbm90IGRpc3BsYXkgd2FybmluZy9lcnJvci1zdGF0ZXMgc28gaXQgdGFrZXMgcHJlY2VkZW5jZVxuLy8gKiBhIHJlYWRvbmx5LWZpZWxkIGNhbm5vdCBiZSBjaGFuZ2VkLCBidXQgaXQgbWlnaHQgYmUgcmVsZXZhbnQgZm9yIHZhbGlkYXRpb24sIHNvIGVycm9yIGFuZCB3YXJuaW5nIGFyZSBjaGVja2VkIGZpcnN0XG4vLyBob3cgeW91IGNhbiBpbnRlcmFjdCB3aXRoIHRoZSBmaWVsZCBpcyBjb250cm9sbGVkIHNlcGFyYXRlbHkgYnkgdGhlIHByb3BzLCB0aGlzIG9ubHkgaW5mbHVlbmNlcyB2aXN1YWxzXG5cbnR5cGUgVFRyYW5zbGF0aW9uSW5wdXRTdHlsZXNQcm9wcyA9IHtcbiAgaXNDb2xsYXBzZWQ/OiBib29sZWFuO1xuICBpc0NvbmRlbnNlZD86IGJvb2xlYW47XG4gIGlzRGlzYWJsZWQ/OiBib29sZWFuO1xuICBpc1JlYWRPbmx5PzogYm9vbGVhbjtcbn07XG5cbmNvbnN0IGdldFRleHRhcmVhU3R5bGVzID0gKHByb3BzOiBUVHJhbnNsYXRpb25JbnB1dFN0eWxlc1Byb3BzKSA9PiB7XG4gIGNvbnN0IGJhc2VTdHlsZXMgPSBbXG4gICAgY3NzYFxuICAgICAgYm9yZGVyLXRvcC1sZWZ0LXJhZGl1czogMCAhaW1wb3J0YW50O1xuICAgICAgYm9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogMCAhaW1wb3J0YW50O1xuICAgIGAsXG4gICAgcHJvcHMuaXNDb2xsYXBzZWQgJiZcbiAgICAgIGNzc2BcbiAgICAgICAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgICAgIGAsXG4gIF07XG4gIHJldHVybiBiYXNlU3R5bGVzO1xufTtcblxuY29uc3QgZ2V0TGFuZ3VhZ2VMYWJlbEJhY2tncm91bmRDb2xvciA9IChcbiAgcHJvcHM6IFRUcmFuc2xhdGlvbklucHV0U3R5bGVzUHJvcHNcbikgPT4ge1xuICBpZiAocHJvcHMuaXNEaXNhYmxlZCkge1xuICAgIHJldHVybiBkZXNpZ25Ub2tlbnMuYmFja2dyb3VuZENvbG9yRm9yTG9jYWxpemVkSW5wdXRMYWJlbFdoZW5EaXNhYmxlZDtcbiAgfVxuICBpZiAocHJvcHMuaXNSZWFkT25seSkge1xuICAgIHJldHVybiBkZXNpZ25Ub2tlbnMuYmFja2dyb3VuZENvbG9yRm9yTG9jYWxpemVkSW5wdXRMYWJlbFdoZW5SZWFkb25seTtcbiAgfVxuICByZXR1cm4gZGVzaWduVG9rZW5zLmJhY2tncm91bmRDb2xvckZvckxvY2FsaXplZElucHV0TGFiZWw7XG59O1xuXG5jb25zdCBnZXRMYW5ndWFnZUxhYmVsQm9yZGVyQ29sb3IgPSAocHJvcHM6IFRUcmFuc2xhdGlvbklucHV0U3R5bGVzUHJvcHMpID0+IHtcbiAgaWYgKHByb3BzLmlzRGlzYWJsZWQpIHtcbiAgICByZXR1cm4gZGVzaWduVG9rZW5zLmJvcmRlckNvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWQ7XG4gIH1cbiAgcmV0dXJuIHByb3BzLmlzUmVhZE9ubHlcbiAgICA/IGRlc2lnblRva2Vucy5jb2xvclN1cmZhY2VcbiAgICA6IGRlc2lnblRva2Vucy5jb2xvck5ldXRyYWw7XG59O1xuXG5jb25zdCBnZXRMYW5ndWFnZUxhYmVsU3R5bGVzID0gKHByb3BzOiBUVHJhbnNsYXRpb25JbnB1dFN0eWxlc1Byb3BzKSA9PiB7XG4gIHJldHVybiBjc3NgXG4gICAgLyogYXZvaWQgd3JhcHBpbmcgbGFiZWwgb250byBuZXcgbGluZXMgKi9cbiAgICBmbGV4OiAxIDAgYXV0bztcbiAgICBjb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsNjB9O1xuICAgIGN1cnNvcjogJHtwcm9wcy5pc0Rpc2FibGVkID8gJ25vdC1hbGxvd2VkJyA6ICdkZWZhdWx0J307XG4gICAgbGluZS1oZWlnaHQ6IGNhbGMoXG4gICAgICAke3Byb3BzLmlzQ29uZGVuc2VkXG4gICAgICAgICAgPyBkZXNpZ25Ub2tlbnMuaGVpZ2h0Rm9ySW5wdXRBc1NtYWxsXG4gICAgICAgICAgOiBkZXNpZ25Ub2tlbnMuaGVpZ2h0Rm9ySW5wdXR9IC0gMiAqICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czF9XG4gICAgKTtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke2dldExhbmd1YWdlTGFiZWxCYWNrZ3JvdW5kQ29sb3IocHJvcHMpfTtcbiAgICBib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAke2Rlc2lnblRva2Vucy5ib3JkZXJSYWRpdXNGb3JJbnB1dH07XG4gICAgYm9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzRm9ySW5wdXR9O1xuICAgIGJvcmRlcjogMXB4ICR7Z2V0TGFuZ3VhZ2VMYWJlbEJvcmRlckNvbG9yKHByb3BzKX0gc29saWQ7XG4gICAgcGFkZGluZzogMCAke2Rlc2lnblRva2Vucy5zcGFjaW5nMjV9O1xuICAgIGZvbnQtc2l6ZTogJHtwcm9wcy5pc0NvbmRlbnNlZFxuICAgICAgPyBkZXNpZ25Ub2tlbnMuZm9udFNpemUyMFxuICAgICAgOiBkZXNpZ25Ub2tlbnMuZm9udFNpemUzMH07XG4gICAgdHJhbnNpdGlvbjogYm9yZGVyLWNvbG9yICR7ZGVzaWduVG9rZW5zLnRyYW5zaXRpb25TdGFuZGFyZH0sXG4gICAgICBiYWNrZ3JvdW5kLWNvbG9yICR7ZGVzaWduVG9rZW5zLnRyYW5zaXRpb25TdGFuZGFyZH0sXG4gICAgICBjb2xvciAke2Rlc2lnblRva2Vucy50cmFuc2l0aW9uU3RhbmRhcmR9O1xuICAgIGJvcmRlci1yaWdodDogMDtcbiAgICBib3gtc2hhZG93OiBub25lO1xuICAgIGFwcGVhcmFuY2U6IG5vbmU7XG4gIGA7XG59O1xuXG5jb25zdCBUb2dnbGVCdXR0b25XcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgZmxleDogMDtcbiAgZGlzcGxheTogZmxleDtcbmA7XG5cbmV4cG9ydCB7IGdldFRleHRhcmVhU3R5bGVzLCBnZXRMYW5ndWFnZUxhYmVsU3R5bGVzLCBUb2dnbGVCdXR0b25XcmFwcGVyIH07XG4iXX0= */",
64
+ styles: "overflow:hidden;label:baseStyles;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRyYW5zbGF0aW9uLWlucHV0LnN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF1QlMiLCJmaWxlIjoidHJhbnNsYXRpb24taW5wdXQuc3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5cbi8vIE5PVEU6IG9yZGVyIGlzIGltcG9ydGFudCBoZXJlXG4vLyAqIGEgZGlzYWJsZWQtZmllbGQgY3VycmVudGx5IGRvZXMgbm90IGRpc3BsYXkgd2FybmluZy9lcnJvci1zdGF0ZXMgc28gaXQgdGFrZXMgcHJlY2VkZW5jZVxuLy8gKiBhIHJlYWRvbmx5LWZpZWxkIGNhbm5vdCBiZSBjaGFuZ2VkLCBidXQgaXQgbWlnaHQgYmUgcmVsZXZhbnQgZm9yIHZhbGlkYXRpb24sIHNvIGVycm9yIGFuZCB3YXJuaW5nIGFyZSBjaGVja2VkIGZpcnN0XG4vLyBob3cgeW91IGNhbiBpbnRlcmFjdCB3aXRoIHRoZSBmaWVsZCBpcyBjb250cm9sbGVkIHNlcGFyYXRlbHkgYnkgdGhlIHByb3BzLCB0aGlzIG9ubHkgaW5mbHVlbmNlcyB2aXN1YWxzXG5cbnR5cGUgVFRyYW5zbGF0aW9uSW5wdXRTdHlsZXNQcm9wcyA9IHtcbiAgaXNDb2xsYXBzZWQ/OiBib29sZWFuO1xuICBpc0NvbmRlbnNlZD86IGJvb2xlYW47XG4gIGlzRGlzYWJsZWQ/OiBib29sZWFuO1xuICBpc1JlYWRPbmx5PzogYm9vbGVhbjtcbn07XG5cbmNvbnN0IGdldFRleHRhcmVhU3R5bGVzID0gKHByb3BzOiBUVHJhbnNsYXRpb25JbnB1dFN0eWxlc1Byb3BzKSA9PiB7XG4gIGNvbnN0IGJhc2VTdHlsZXMgPSBbXG4gICAgY3NzYFxuICAgICAgYm9yZGVyLXRvcC1sZWZ0LXJhZGl1czogMCAhaW1wb3J0YW50O1xuICAgICAgYm9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogMCAhaW1wb3J0YW50O1xuICAgIGAsXG4gICAgcHJvcHMuaXNDb2xsYXBzZWQgJiZcbiAgICAgIGNzc2BcbiAgICAgICAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgICAgIGAsXG4gIF07XG4gIHJldHVybiBiYXNlU3R5bGVzO1xufTtcblxuY29uc3QgZ2V0TGFuZ3VhZ2VMYWJlbEJhY2tncm91bmRDb2xvciA9IChcbiAgcHJvcHM6IFRUcmFuc2xhdGlvbklucHV0U3R5bGVzUHJvcHNcbikgPT4ge1xuICBpZiAocHJvcHMuaXNEaXNhYmxlZCkge1xuICAgIHJldHVybiBkZXNpZ25Ub2tlbnMuYmFja2dyb3VuZENvbG9yRm9yTG9jYWxpemVkSW5wdXRMYWJlbFdoZW5EaXNhYmxlZDtcbiAgfVxuICBpZiAocHJvcHMuaXNSZWFkT25seSkge1xuICAgIHJldHVybiBkZXNpZ25Ub2tlbnMuYmFja2dyb3VuZENvbG9yRm9yTG9jYWxpemVkSW5wdXRMYWJlbFdoZW5SZWFkb25seTtcbiAgfVxuICByZXR1cm4gZGVzaWduVG9rZW5zLmJhY2tncm91bmRDb2xvckZvckxvY2FsaXplZElucHV0TGFiZWw7XG59O1xuXG5jb25zdCBnZXRMYW5ndWFnZUxhYmVsQm9yZGVyQ29sb3IgPSAocHJvcHM6IFRUcmFuc2xhdGlvbklucHV0U3R5bGVzUHJvcHMpID0+IHtcbiAgaWYgKHByb3BzLmlzRGlzYWJsZWQpIHtcbiAgICByZXR1cm4gZGVzaWduVG9rZW5zLmJvcmRlckNvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWQ7XG4gIH1cbiAgcmV0dXJuIHByb3BzLmlzUmVhZE9ubHlcbiAgICA/IGRlc2lnblRva2Vucy5jb2xvclN1cmZhY2VcbiAgICA6IGRlc2lnblRva2Vucy5jb2xvck5ldXRyYWw7XG59O1xuXG5jb25zdCBnZXRMYW5ndWFnZUxhYmVsU3R5bGVzID0gKHByb3BzOiBUVHJhbnNsYXRpb25JbnB1dFN0eWxlc1Byb3BzKSA9PiB7XG4gIHJldHVybiBjc3NgXG4gICAgLyogYXZvaWQgd3JhcHBpbmcgbGFiZWwgb250byBuZXcgbGluZXMgKi9cbiAgICBmbGV4OiAxIDAgYXV0bztcbiAgICBjb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsNjB9O1xuICAgIGN1cnNvcjogJHtwcm9wcy5pc0Rpc2FibGVkID8gJ25vdC1hbGxvd2VkJyA6ICdkZWZhdWx0J307XG4gICAgbGluZS1oZWlnaHQ6IGNhbGMoXG4gICAgICAke3Byb3BzLmlzQ29uZGVuc2VkXG4gICAgICAgICAgPyBkZXNpZ25Ub2tlbnMuaGVpZ2h0Rm9ySW5wdXRBc1NtYWxsXG4gICAgICAgICAgOiBkZXNpZ25Ub2tlbnMuaGVpZ2h0Rm9ySW5wdXR9IC0gMiAqICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czF9XG4gICAgKTtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke2dldExhbmd1YWdlTGFiZWxCYWNrZ3JvdW5kQ29sb3IocHJvcHMpfTtcbiAgICBib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAke2Rlc2lnblRva2Vucy5ib3JkZXJSYWRpdXNGb3JJbnB1dH07XG4gICAgYm9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzRm9ySW5wdXR9O1xuICAgIGJvcmRlcjogMXB4ICR7Z2V0TGFuZ3VhZ2VMYWJlbEJvcmRlckNvbG9yKHByb3BzKX0gc29saWQ7XG4gICAgcGFkZGluZzogMCAke2Rlc2lnblRva2Vucy5zcGFjaW5nMjV9O1xuICAgIGZvbnQtc2l6ZTogJHtwcm9wcy5pc0NvbmRlbnNlZFxuICAgICAgPyBkZXNpZ25Ub2tlbnMuZm9udFNpemUyMFxuICAgICAgOiBkZXNpZ25Ub2tlbnMuZm9udFNpemUzMH07XG4gICAgdHJhbnNpdGlvbjogYm9yZGVyLWNvbG9yICR7ZGVzaWduVG9rZW5zLnRyYW5zaXRpb25TdGFuZGFyZH0sXG4gICAgICBiYWNrZ3JvdW5kLWNvbG9yICR7ZGVzaWduVG9rZW5zLnRyYW5zaXRpb25TdGFuZGFyZH0sXG4gICAgICBjb2xvciAke2Rlc2lnblRva2Vucy50cmFuc2l0aW9uU3RhbmRhcmR9O1xuICAgIGJvcmRlci1yaWdodDogMDtcbiAgICBib3gtc2hhZG93OiBub25lO1xuICAgIGFwcGVhcmFuY2U6IG5vbmU7XG4gIGA7XG59O1xuXG5jb25zdCBUb2dnbGVCdXR0b25XcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgZmxleDogMDtcbiAgZGlzcGxheTogZmxleDtcbmA7XG5cbmV4cG9ydCB7IGdldFRleHRhcmVhU3R5bGVzLCBnZXRMYW5ndWFnZUxhYmVsU3R5bGVzLCBUb2dnbGVCdXR0b25XcmFwcGVyIH07XG4iXX0= */",
66
65
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
67
66
  };
68
67
  var _ref2 = process.env.NODE_ENV === "production" ? {
@@ -70,8 +69,7 @@ var _ref2 = process.env.NODE_ENV === "production" ? {
70
69
  styles: "border-top-left-radius:0!important;border-bottom-left-radius:0!important"
71
70
  } : {
72
71
  name: "pb9fe4-baseStyles",
73
- styles: "border-top-left-radius:0!important;border-bottom-left-radius:0!important;label:baseStyles;",
74
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRyYW5zbGF0aW9uLWlucHV0LnN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFrQk8iLCJmaWxlIjoidHJhbnNsYXRpb24taW5wdXQuc3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5cbi8vIE5PVEU6IG9yZGVyIGlzIGltcG9ydGFudCBoZXJlXG4vLyAqIGEgZGlzYWJsZWQtZmllbGQgY3VycmVudGx5IGRvZXMgbm90IGRpc3BsYXkgd2FybmluZy9lcnJvci1zdGF0ZXMgc28gaXQgdGFrZXMgcHJlY2VkZW5jZVxuLy8gKiBhIHJlYWRvbmx5LWZpZWxkIGNhbm5vdCBiZSBjaGFuZ2VkLCBidXQgaXQgbWlnaHQgYmUgcmVsZXZhbnQgZm9yIHZhbGlkYXRpb24sIHNvIGVycm9yIGFuZCB3YXJuaW5nIGFyZSBjaGVja2VkIGZpcnN0XG4vLyBob3cgeW91IGNhbiBpbnRlcmFjdCB3aXRoIHRoZSBmaWVsZCBpcyBjb250cm9sbGVkIHNlcGFyYXRlbHkgYnkgdGhlIHByb3BzLCB0aGlzIG9ubHkgaW5mbHVlbmNlcyB2aXN1YWxzXG5cbnR5cGUgVFRyYW5zbGF0aW9uSW5wdXRTdHlsZXNQcm9wcyA9IHtcbiAgaXNDb2xsYXBzZWQ/OiBib29sZWFuO1xuICBpc0NvbmRlbnNlZD86IGJvb2xlYW47XG4gIGlzRGlzYWJsZWQ/OiBib29sZWFuO1xuICBpc1JlYWRPbmx5PzogYm9vbGVhbjtcbn07XG5cbmNvbnN0IGdldFRleHRhcmVhU3R5bGVzID0gKHByb3BzOiBUVHJhbnNsYXRpb25JbnB1dFN0eWxlc1Byb3BzKSA9PiB7XG4gIGNvbnN0IGJhc2VTdHlsZXMgPSBbXG4gICAgY3NzYFxuICAgICAgYm9yZGVyLXRvcC1sZWZ0LXJhZGl1czogMCAhaW1wb3J0YW50O1xuICAgICAgYm9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogMCAhaW1wb3J0YW50O1xuICAgIGAsXG4gICAgcHJvcHMuaXNDb2xsYXBzZWQgJiZcbiAgICAgIGNzc2BcbiAgICAgICAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgICAgIGAsXG4gIF07XG4gIHJldHVybiBiYXNlU3R5bGVzO1xufTtcblxuY29uc3QgZ2V0TGFuZ3VhZ2VMYWJlbEJhY2tncm91bmRDb2xvciA9IChcbiAgcHJvcHM6IFRUcmFuc2xhdGlvbklucHV0U3R5bGVzUHJvcHNcbikgPT4ge1xuICBpZiAocHJvcHMuaXNEaXNhYmxlZCkge1xuICAgIHJldHVybiBkZXNpZ25Ub2tlbnMuYmFja2dyb3VuZENvbG9yRm9yTG9jYWxpemVkSW5wdXRMYWJlbFdoZW5EaXNhYmxlZDtcbiAgfVxuICBpZiAocHJvcHMuaXNSZWFkT25seSkge1xuICAgIHJldHVybiBkZXNpZ25Ub2tlbnMuYmFja2dyb3VuZENvbG9yRm9yTG9jYWxpemVkSW5wdXRMYWJlbFdoZW5SZWFkb25seTtcbiAgfVxuICByZXR1cm4gZGVzaWduVG9rZW5zLmJhY2tncm91bmRDb2xvckZvckxvY2FsaXplZElucHV0TGFiZWw7XG59O1xuXG5jb25zdCBnZXRMYW5ndWFnZUxhYmVsQm9yZGVyQ29sb3IgPSAocHJvcHM6IFRUcmFuc2xhdGlvbklucHV0U3R5bGVzUHJvcHMpID0+IHtcbiAgaWYgKHByb3BzLmlzRGlzYWJsZWQpIHtcbiAgICByZXR1cm4gZGVzaWduVG9rZW5zLmJvcmRlckNvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWQ7XG4gIH1cbiAgcmV0dXJuIHByb3BzLmlzUmVhZE9ubHlcbiAgICA/IGRlc2lnblRva2Vucy5jb2xvclN1cmZhY2VcbiAgICA6IGRlc2lnblRva2Vucy5jb2xvck5ldXRyYWw7XG59O1xuXG5jb25zdCBnZXRMYW5ndWFnZUxhYmVsU3R5bGVzID0gKHByb3BzOiBUVHJhbnNsYXRpb25JbnB1dFN0eWxlc1Byb3BzKSA9PiB7XG4gIHJldHVybiBjc3NgXG4gICAgLyogYXZvaWQgd3JhcHBpbmcgbGFiZWwgb250byBuZXcgbGluZXMgKi9cbiAgICBmbGV4OiAxIDAgYXV0bztcbiAgICBjb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsNjB9O1xuICAgIGN1cnNvcjogJHtwcm9wcy5pc0Rpc2FibGVkID8gJ25vdC1hbGxvd2VkJyA6ICdkZWZhdWx0J307XG4gICAgbGluZS1oZWlnaHQ6IGNhbGMoXG4gICAgICAke3Byb3BzLmlzQ29uZGVuc2VkXG4gICAgICAgICAgPyBkZXNpZ25Ub2tlbnMuaGVpZ2h0Rm9ySW5wdXRBc1NtYWxsXG4gICAgICAgICAgOiBkZXNpZ25Ub2tlbnMuaGVpZ2h0Rm9ySW5wdXR9IC0gMiAqICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czF9XG4gICAgKTtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke2dldExhbmd1YWdlTGFiZWxCYWNrZ3JvdW5kQ29sb3IocHJvcHMpfTtcbiAgICBib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAke2Rlc2lnblRva2Vucy5ib3JkZXJSYWRpdXNGb3JJbnB1dH07XG4gICAgYm9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzRm9ySW5wdXR9O1xuICAgIGJvcmRlcjogMXB4ICR7Z2V0TGFuZ3VhZ2VMYWJlbEJvcmRlckNvbG9yKHByb3BzKX0gc29saWQ7XG4gICAgcGFkZGluZzogMCAke2Rlc2lnblRva2Vucy5zcGFjaW5nMjV9O1xuICAgIGZvbnQtc2l6ZTogJHtwcm9wcy5pc0NvbmRlbnNlZFxuICAgICAgPyBkZXNpZ25Ub2tlbnMuZm9udFNpemUyMFxuICAgICAgOiBkZXNpZ25Ub2tlbnMuZm9udFNpemUzMH07XG4gICAgdHJhbnNpdGlvbjogYm9yZGVyLWNvbG9yICR7ZGVzaWduVG9rZW5zLnRyYW5zaXRpb25TdGFuZGFyZH0sXG4gICAgICBiYWNrZ3JvdW5kLWNvbG9yICR7ZGVzaWduVG9rZW5zLnRyYW5zaXRpb25TdGFuZGFyZH0sXG4gICAgICBjb2xvciAke2Rlc2lnblRva2Vucy50cmFuc2l0aW9uU3RhbmRhcmR9O1xuICAgIGJvcmRlci1yaWdodDogMDtcbiAgICBib3gtc2hhZG93OiBub25lO1xuICAgIGFwcGVhcmFuY2U6IG5vbmU7XG4gIGA7XG59O1xuXG5jb25zdCBUb2dnbGVCdXR0b25XcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgZmxleDogMDtcbiAgZGlzcGxheTogZmxleDtcbmA7XG5cbmV4cG9ydCB7IGdldFRleHRhcmVhU3R5bGVzLCBnZXRMYW5ndWFnZUxhYmVsU3R5bGVzLCBUb2dnbGVCdXR0b25XcmFwcGVyIH07XG4iXX0= */",
72
+ styles: "border-top-left-radius:0!important;border-bottom-left-radius:0!important;label:baseStyles;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRyYW5zbGF0aW9uLWlucHV0LnN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFrQk8iLCJmaWxlIjoidHJhbnNsYXRpb24taW5wdXQuc3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5cbi8vIE5PVEU6IG9yZGVyIGlzIGltcG9ydGFudCBoZXJlXG4vLyAqIGEgZGlzYWJsZWQtZmllbGQgY3VycmVudGx5IGRvZXMgbm90IGRpc3BsYXkgd2FybmluZy9lcnJvci1zdGF0ZXMgc28gaXQgdGFrZXMgcHJlY2VkZW5jZVxuLy8gKiBhIHJlYWRvbmx5LWZpZWxkIGNhbm5vdCBiZSBjaGFuZ2VkLCBidXQgaXQgbWlnaHQgYmUgcmVsZXZhbnQgZm9yIHZhbGlkYXRpb24sIHNvIGVycm9yIGFuZCB3YXJuaW5nIGFyZSBjaGVja2VkIGZpcnN0XG4vLyBob3cgeW91IGNhbiBpbnRlcmFjdCB3aXRoIHRoZSBmaWVsZCBpcyBjb250cm9sbGVkIHNlcGFyYXRlbHkgYnkgdGhlIHByb3BzLCB0aGlzIG9ubHkgaW5mbHVlbmNlcyB2aXN1YWxzXG5cbnR5cGUgVFRyYW5zbGF0aW9uSW5wdXRTdHlsZXNQcm9wcyA9IHtcbiAgaXNDb2xsYXBzZWQ/OiBib29sZWFuO1xuICBpc0NvbmRlbnNlZD86IGJvb2xlYW47XG4gIGlzRGlzYWJsZWQ/OiBib29sZWFuO1xuICBpc1JlYWRPbmx5PzogYm9vbGVhbjtcbn07XG5cbmNvbnN0IGdldFRleHRhcmVhU3R5bGVzID0gKHByb3BzOiBUVHJhbnNsYXRpb25JbnB1dFN0eWxlc1Byb3BzKSA9PiB7XG4gIGNvbnN0IGJhc2VTdHlsZXMgPSBbXG4gICAgY3NzYFxuICAgICAgYm9yZGVyLXRvcC1sZWZ0LXJhZGl1czogMCAhaW1wb3J0YW50O1xuICAgICAgYm9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogMCAhaW1wb3J0YW50O1xuICAgIGAsXG4gICAgcHJvcHMuaXNDb2xsYXBzZWQgJiZcbiAgICAgIGNzc2BcbiAgICAgICAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgICAgIGAsXG4gIF07XG4gIHJldHVybiBiYXNlU3R5bGVzO1xufTtcblxuY29uc3QgZ2V0TGFuZ3VhZ2VMYWJlbEJhY2tncm91bmRDb2xvciA9IChcbiAgcHJvcHM6IFRUcmFuc2xhdGlvbklucHV0U3R5bGVzUHJvcHNcbikgPT4ge1xuICBpZiAocHJvcHMuaXNEaXNhYmxlZCkge1xuICAgIHJldHVybiBkZXNpZ25Ub2tlbnMuYmFja2dyb3VuZENvbG9yRm9yTG9jYWxpemVkSW5wdXRMYWJlbFdoZW5EaXNhYmxlZDtcbiAgfVxuICBpZiAocHJvcHMuaXNSZWFkT25seSkge1xuICAgIHJldHVybiBkZXNpZ25Ub2tlbnMuYmFja2dyb3VuZENvbG9yRm9yTG9jYWxpemVkSW5wdXRMYWJlbFdoZW5SZWFkb25seTtcbiAgfVxuICByZXR1cm4gZGVzaWduVG9rZW5zLmJhY2tncm91bmRDb2xvckZvckxvY2FsaXplZElucHV0TGFiZWw7XG59O1xuXG5jb25zdCBnZXRMYW5ndWFnZUxhYmVsQm9yZGVyQ29sb3IgPSAocHJvcHM6IFRUcmFuc2xhdGlvbklucHV0U3R5bGVzUHJvcHMpID0+IHtcbiAgaWYgKHByb3BzLmlzRGlzYWJsZWQpIHtcbiAgICByZXR1cm4gZGVzaWduVG9rZW5zLmJvcmRlckNvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWQ7XG4gIH1cbiAgcmV0dXJuIHByb3BzLmlzUmVhZE9ubHlcbiAgICA/IGRlc2lnblRva2Vucy5jb2xvclN1cmZhY2VcbiAgICA6IGRlc2lnblRva2Vucy5jb2xvck5ldXRyYWw7XG59O1xuXG5jb25zdCBnZXRMYW5ndWFnZUxhYmVsU3R5bGVzID0gKHByb3BzOiBUVHJhbnNsYXRpb25JbnB1dFN0eWxlc1Byb3BzKSA9PiB7XG4gIHJldHVybiBjc3NgXG4gICAgLyogYXZvaWQgd3JhcHBpbmcgbGFiZWwgb250byBuZXcgbGluZXMgKi9cbiAgICBmbGV4OiAxIDAgYXV0bztcbiAgICBjb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsNjB9O1xuICAgIGN1cnNvcjogJHtwcm9wcy5pc0Rpc2FibGVkID8gJ25vdC1hbGxvd2VkJyA6ICdkZWZhdWx0J307XG4gICAgbGluZS1oZWlnaHQ6IGNhbGMoXG4gICAgICAke3Byb3BzLmlzQ29uZGVuc2VkXG4gICAgICAgICAgPyBkZXNpZ25Ub2tlbnMuaGVpZ2h0Rm9ySW5wdXRBc1NtYWxsXG4gICAgICAgICAgOiBkZXNpZ25Ub2tlbnMuaGVpZ2h0Rm9ySW5wdXR9IC0gMiAqICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czF9XG4gICAgKTtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke2dldExhbmd1YWdlTGFiZWxCYWNrZ3JvdW5kQ29sb3IocHJvcHMpfTtcbiAgICBib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAke2Rlc2lnblRva2Vucy5ib3JkZXJSYWRpdXNGb3JJbnB1dH07XG4gICAgYm9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzRm9ySW5wdXR9O1xuICAgIGJvcmRlcjogMXB4ICR7Z2V0TGFuZ3VhZ2VMYWJlbEJvcmRlckNvbG9yKHByb3BzKX0gc29saWQ7XG4gICAgcGFkZGluZzogMCAke2Rlc2lnblRva2Vucy5zcGFjaW5nMjV9O1xuICAgIGZvbnQtc2l6ZTogJHtwcm9wcy5pc0NvbmRlbnNlZFxuICAgICAgPyBkZXNpZ25Ub2tlbnMuZm9udFNpemUyMFxuICAgICAgOiBkZXNpZ25Ub2tlbnMuZm9udFNpemUzMH07XG4gICAgdHJhbnNpdGlvbjogYm9yZGVyLWNvbG9yICR7ZGVzaWduVG9rZW5zLnRyYW5zaXRpb25TdGFuZGFyZH0sXG4gICAgICBiYWNrZ3JvdW5kLWNvbG9yICR7ZGVzaWduVG9rZW5zLnRyYW5zaXRpb25TdGFuZGFyZH0sXG4gICAgICBjb2xvciAke2Rlc2lnblRva2Vucy50cmFuc2l0aW9uU3RhbmRhcmR9O1xuICAgIGJvcmRlci1yaWdodDogMDtcbiAgICBib3gtc2hhZG93OiBub25lO1xuICAgIGFwcGVhcmFuY2U6IG5vbmU7XG4gIGA7XG59O1xuXG5jb25zdCBUb2dnbGVCdXR0b25XcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgZmxleDogMDtcbiAgZGlzcGxheTogZmxleDtcbmA7XG5cbmV4cG9ydCB7IGdldFRleHRhcmVhU3R5bGVzLCBnZXRMYW5ndWFnZUxhYmVsU3R5bGVzLCBUb2dnbGVCdXR0b25XcmFwcGVyIH07XG4iXX0= */",
75
73
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
76
74
  };
77
75
  const getTextareaStyles = props => {
@@ -106,8 +104,7 @@ const ToggleButtonWrapper = /*#__PURE__*/_styled__default["default"]("div", proc
106
104
  styles: "flex:0;display:flex"
107
105
  } : {
108
106
  name: "ejz79s",
109
- styles: "flex:0;display:flex",
110
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRyYW5zbGF0aW9uLWlucHV0LnN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUErRXNDIiwiZmlsZSI6InRyYW5zbGF0aW9uLWlucHV0LnN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGRlc2lnblRva2VucyB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuXG4vLyBOT1RFOiBvcmRlciBpcyBpbXBvcnRhbnQgaGVyZVxuLy8gKiBhIGRpc2FibGVkLWZpZWxkIGN1cnJlbnRseSBkb2VzIG5vdCBkaXNwbGF5IHdhcm5pbmcvZXJyb3Itc3RhdGVzIHNvIGl0IHRha2VzIHByZWNlZGVuY2Vcbi8vICogYSByZWFkb25seS1maWVsZCBjYW5ub3QgYmUgY2hhbmdlZCwgYnV0IGl0IG1pZ2h0IGJlIHJlbGV2YW50IGZvciB2YWxpZGF0aW9uLCBzbyBlcnJvciBhbmQgd2FybmluZyBhcmUgY2hlY2tlZCBmaXJzdFxuLy8gaG93IHlvdSBjYW4gaW50ZXJhY3Qgd2l0aCB0aGUgZmllbGQgaXMgY29udHJvbGxlZCBzZXBhcmF0ZWx5IGJ5IHRoZSBwcm9wcywgdGhpcyBvbmx5IGluZmx1ZW5jZXMgdmlzdWFsc1xuXG50eXBlIFRUcmFuc2xhdGlvbklucHV0U3R5bGVzUHJvcHMgPSB7XG4gIGlzQ29sbGFwc2VkPzogYm9vbGVhbjtcbiAgaXNDb25kZW5zZWQ/OiBib29sZWFuO1xuICBpc0Rpc2FibGVkPzogYm9vbGVhbjtcbiAgaXNSZWFkT25seT86IGJvb2xlYW47XG59O1xuXG5jb25zdCBnZXRUZXh0YXJlYVN0eWxlcyA9IChwcm9wczogVFRyYW5zbGF0aW9uSW5wdXRTdHlsZXNQcm9wcykgPT4ge1xuICBjb25zdCBiYXNlU3R5bGVzID0gW1xuICAgIGNzc2BcbiAgICAgIGJvcmRlci10b3AtbGVmdC1yYWRpdXM6IDAgIWltcG9ydGFudDtcbiAgICAgIGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6IDAgIWltcG9ydGFudDtcbiAgICBgLFxuICAgIHByb3BzLmlzQ29sbGFwc2VkICYmXG4gICAgICBjc3NgXG4gICAgICAgIG92ZXJmbG93OiBoaWRkZW47XG4gICAgICBgLFxuICBdO1xuICByZXR1cm4gYmFzZVN0eWxlcztcbn07XG5cbmNvbnN0IGdldExhbmd1YWdlTGFiZWxCYWNrZ3JvdW5kQ29sb3IgPSAoXG4gIHByb3BzOiBUVHJhbnNsYXRpb25JbnB1dFN0eWxlc1Byb3BzXG4pID0+IHtcbiAgaWYgKHByb3BzLmlzRGlzYWJsZWQpIHtcbiAgICByZXR1cm4gZGVzaWduVG9rZW5zLmJhY2tncm91bmRDb2xvckZvckxvY2FsaXplZElucHV0TGFiZWxXaGVuRGlzYWJsZWQ7XG4gIH1cbiAgaWYgKHByb3BzLmlzUmVhZE9ubHkpIHtcbiAgICByZXR1cm4gZGVzaWduVG9rZW5zLmJhY2tncm91bmRDb2xvckZvckxvY2FsaXplZElucHV0TGFiZWxXaGVuUmVhZG9ubHk7XG4gIH1cbiAgcmV0dXJuIGRlc2lnblRva2Vucy5iYWNrZ3JvdW5kQ29sb3JGb3JMb2NhbGl6ZWRJbnB1dExhYmVsO1xufTtcblxuY29uc3QgZ2V0TGFuZ3VhZ2VMYWJlbEJvcmRlckNvbG9yID0gKHByb3BzOiBUVHJhbnNsYXRpb25JbnB1dFN0eWxlc1Byb3BzKSA9PiB7XG4gIGlmIChwcm9wcy5pc0Rpc2FibGVkKSB7XG4gICAgcmV0dXJuIGRlc2lnblRva2Vucy5ib3JkZXJDb2xvckZvcklucHV0V2hlbkRpc2FibGVkO1xuICB9XG4gIHJldHVybiBwcm9wcy5pc1JlYWRPbmx5XG4gICAgPyBkZXNpZ25Ub2tlbnMuY29sb3JTdXJmYWNlXG4gICAgOiBkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsO1xufTtcblxuY29uc3QgZ2V0TGFuZ3VhZ2VMYWJlbFN0eWxlcyA9IChwcm9wczogVFRyYW5zbGF0aW9uSW5wdXRTdHlsZXNQcm9wcykgPT4ge1xuICByZXR1cm4gY3NzYFxuICAgIC8qIGF2b2lkIHdyYXBwaW5nIGxhYmVsIG9udG8gbmV3IGxpbmVzICovXG4gICAgZmxleDogMSAwIGF1dG87XG4gICAgY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yTmV1dHJhbDYwfTtcbiAgICBjdXJzb3I6ICR7cHJvcHMuaXNEaXNhYmxlZCA/ICdub3QtYWxsb3dlZCcgOiAnZGVmYXVsdCd9O1xuICAgIGxpbmUtaGVpZ2h0OiBjYWxjKFxuICAgICAgJHtwcm9wcy5pc0NvbmRlbnNlZFxuICAgICAgICAgID8gZGVzaWduVG9rZW5zLmhlaWdodEZvcklucHV0QXNTbWFsbFxuICAgICAgICAgIDogZGVzaWduVG9rZW5zLmhlaWdodEZvcklucHV0fSAtIDIgKiAke2Rlc2lnblRva2Vucy5ib3JkZXJSYWRpdXMxfVxuICAgICk7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHtnZXRMYW5ndWFnZUxhYmVsQmFja2dyb3VuZENvbG9yKHByb3BzKX07XG4gICAgYm9yZGVyLXRvcC1sZWZ0LXJhZGl1czogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzRm9ySW5wdXR9O1xuICAgIGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6ICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1c0ZvcklucHV0fTtcbiAgICBib3JkZXI6IDFweCAke2dldExhbmd1YWdlTGFiZWxCb3JkZXJDb2xvcihwcm9wcyl9IHNvbGlkO1xuICAgIHBhZGRpbmc6IDAgJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzI1fTtcbiAgICBmb250LXNpemU6ICR7cHJvcHMuaXNDb25kZW5zZWRcbiAgICAgID8gZGVzaWduVG9rZW5zLmZvbnRTaXplMjBcbiAgICAgIDogZGVzaWduVG9rZW5zLmZvbnRTaXplMzB9O1xuICAgIHRyYW5zaXRpb246IGJvcmRlci1jb2xvciAke2Rlc2lnblRva2Vucy50cmFuc2l0aW9uU3RhbmRhcmR9LFxuICAgICAgYmFja2dyb3VuZC1jb2xvciAke2Rlc2lnblRva2Vucy50cmFuc2l0aW9uU3RhbmRhcmR9LFxuICAgICAgY29sb3IgJHtkZXNpZ25Ub2tlbnMudHJhbnNpdGlvblN0YW5kYXJkfTtcbiAgICBib3JkZXItcmlnaHQ6IDA7XG4gICAgYm94LXNoYWRvdzogbm9uZTtcbiAgICBhcHBlYXJhbmNlOiBub25lO1xuICBgO1xufTtcblxuY29uc3QgVG9nZ2xlQnV0dG9uV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIGZsZXg6IDA7XG4gIGRpc3BsYXk6IGZsZXg7XG5gO1xuXG5leHBvcnQgeyBnZXRUZXh0YXJlYVN0eWxlcywgZ2V0TGFuZ3VhZ2VMYWJlbFN0eWxlcywgVG9nZ2xlQnV0dG9uV3JhcHBlciB9O1xuIl19 */",
107
+ styles: "flex:0;display:flex/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRyYW5zbGF0aW9uLWlucHV0LnN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUErRXNDIiwiZmlsZSI6InRyYW5zbGF0aW9uLWlucHV0LnN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGRlc2lnblRva2VucyB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuXG4vLyBOT1RFOiBvcmRlciBpcyBpbXBvcnRhbnQgaGVyZVxuLy8gKiBhIGRpc2FibGVkLWZpZWxkIGN1cnJlbnRseSBkb2VzIG5vdCBkaXNwbGF5IHdhcm5pbmcvZXJyb3Itc3RhdGVzIHNvIGl0IHRha2VzIHByZWNlZGVuY2Vcbi8vICogYSByZWFkb25seS1maWVsZCBjYW5ub3QgYmUgY2hhbmdlZCwgYnV0IGl0IG1pZ2h0IGJlIHJlbGV2YW50IGZvciB2YWxpZGF0aW9uLCBzbyBlcnJvciBhbmQgd2FybmluZyBhcmUgY2hlY2tlZCBmaXJzdFxuLy8gaG93IHlvdSBjYW4gaW50ZXJhY3Qgd2l0aCB0aGUgZmllbGQgaXMgY29udHJvbGxlZCBzZXBhcmF0ZWx5IGJ5IHRoZSBwcm9wcywgdGhpcyBvbmx5IGluZmx1ZW5jZXMgdmlzdWFsc1xuXG50eXBlIFRUcmFuc2xhdGlvbklucHV0U3R5bGVzUHJvcHMgPSB7XG4gIGlzQ29sbGFwc2VkPzogYm9vbGVhbjtcbiAgaXNDb25kZW5zZWQ/OiBib29sZWFuO1xuICBpc0Rpc2FibGVkPzogYm9vbGVhbjtcbiAgaXNSZWFkT25seT86IGJvb2xlYW47XG59O1xuXG5jb25zdCBnZXRUZXh0YXJlYVN0eWxlcyA9IChwcm9wczogVFRyYW5zbGF0aW9uSW5wdXRTdHlsZXNQcm9wcykgPT4ge1xuICBjb25zdCBiYXNlU3R5bGVzID0gW1xuICAgIGNzc2BcbiAgICAgIGJvcmRlci10b3AtbGVmdC1yYWRpdXM6IDAgIWltcG9ydGFudDtcbiAgICAgIGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6IDAgIWltcG9ydGFudDtcbiAgICBgLFxuICAgIHByb3BzLmlzQ29sbGFwc2VkICYmXG4gICAgICBjc3NgXG4gICAgICAgIG92ZXJmbG93OiBoaWRkZW47XG4gICAgICBgLFxuICBdO1xuICByZXR1cm4gYmFzZVN0eWxlcztcbn07XG5cbmNvbnN0IGdldExhbmd1YWdlTGFiZWxCYWNrZ3JvdW5kQ29sb3IgPSAoXG4gIHByb3BzOiBUVHJhbnNsYXRpb25JbnB1dFN0eWxlc1Byb3BzXG4pID0+IHtcbiAgaWYgKHByb3BzLmlzRGlzYWJsZWQpIHtcbiAgICByZXR1cm4gZGVzaWduVG9rZW5zLmJhY2tncm91bmRDb2xvckZvckxvY2FsaXplZElucHV0TGFiZWxXaGVuRGlzYWJsZWQ7XG4gIH1cbiAgaWYgKHByb3BzLmlzUmVhZE9ubHkpIHtcbiAgICByZXR1cm4gZGVzaWduVG9rZW5zLmJhY2tncm91bmRDb2xvckZvckxvY2FsaXplZElucHV0TGFiZWxXaGVuUmVhZG9ubHk7XG4gIH1cbiAgcmV0dXJuIGRlc2lnblRva2Vucy5iYWNrZ3JvdW5kQ29sb3JGb3JMb2NhbGl6ZWRJbnB1dExhYmVsO1xufTtcblxuY29uc3QgZ2V0TGFuZ3VhZ2VMYWJlbEJvcmRlckNvbG9yID0gKHByb3BzOiBUVHJhbnNsYXRpb25JbnB1dFN0eWxlc1Byb3BzKSA9PiB7XG4gIGlmIChwcm9wcy5pc0Rpc2FibGVkKSB7XG4gICAgcmV0dXJuIGRlc2lnblRva2Vucy5ib3JkZXJDb2xvckZvcklucHV0V2hlbkRpc2FibGVkO1xuICB9XG4gIHJldHVybiBwcm9wcy5pc1JlYWRPbmx5XG4gICAgPyBkZXNpZ25Ub2tlbnMuY29sb3JTdXJmYWNlXG4gICAgOiBkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsO1xufTtcblxuY29uc3QgZ2V0TGFuZ3VhZ2VMYWJlbFN0eWxlcyA9IChwcm9wczogVFRyYW5zbGF0aW9uSW5wdXRTdHlsZXNQcm9wcykgPT4ge1xuICByZXR1cm4gY3NzYFxuICAgIC8qIGF2b2lkIHdyYXBwaW5nIGxhYmVsIG9udG8gbmV3IGxpbmVzICovXG4gICAgZmxleDogMSAwIGF1dG87XG4gICAgY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yTmV1dHJhbDYwfTtcbiAgICBjdXJzb3I6ICR7cHJvcHMuaXNEaXNhYmxlZCA/ICdub3QtYWxsb3dlZCcgOiAnZGVmYXVsdCd9O1xuICAgIGxpbmUtaGVpZ2h0OiBjYWxjKFxuICAgICAgJHtwcm9wcy5pc0NvbmRlbnNlZFxuICAgICAgICAgID8gZGVzaWduVG9rZW5zLmhlaWdodEZvcklucHV0QXNTbWFsbFxuICAgICAgICAgIDogZGVzaWduVG9rZW5zLmhlaWdodEZvcklucHV0fSAtIDIgKiAke2Rlc2lnblRva2Vucy5ib3JkZXJSYWRpdXMxfVxuICAgICk7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHtnZXRMYW5ndWFnZUxhYmVsQmFja2dyb3VuZENvbG9yKHByb3BzKX07XG4gICAgYm9yZGVyLXRvcC1sZWZ0LXJhZGl1czogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzRm9ySW5wdXR9O1xuICAgIGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6ICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1c0ZvcklucHV0fTtcbiAgICBib3JkZXI6IDFweCAke2dldExhbmd1YWdlTGFiZWxCb3JkZXJDb2xvcihwcm9wcyl9IHNvbGlkO1xuICAgIHBhZGRpbmc6IDAgJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzI1fTtcbiAgICBmb250LXNpemU6ICR7cHJvcHMuaXNDb25kZW5zZWRcbiAgICAgID8gZGVzaWduVG9rZW5zLmZvbnRTaXplMjBcbiAgICAgIDogZGVzaWduVG9rZW5zLmZvbnRTaXplMzB9O1xuICAgIHRyYW5zaXRpb246IGJvcmRlci1jb2xvciAke2Rlc2lnblRva2Vucy50cmFuc2l0aW9uU3RhbmRhcmR9LFxuICAgICAgYmFja2dyb3VuZC1jb2xvciAke2Rlc2lnblRva2Vucy50cmFuc2l0aW9uU3RhbmRhcmR9LFxuICAgICAgY29sb3IgJHtkZXNpZ25Ub2tlbnMudHJhbnNpdGlvblN0YW5kYXJkfTtcbiAgICBib3JkZXItcmlnaHQ6IDA7XG4gICAgYm94LXNoYWRvdzogbm9uZTtcbiAgICBhcHBlYXJhbmNlOiBub25lO1xuICBgO1xufTtcblxuY29uc3QgVG9nZ2xlQnV0dG9uV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIGZsZXg6IDA7XG4gIGRpc3BsYXk6IGZsZXg7XG5gO1xuXG5leHBvcnQgeyBnZXRUZXh0YXJlYVN0eWxlcywgZ2V0TGFuZ3VhZ2VMYWJlbFN0eWxlcywgVG9nZ2xlQnV0dG9uV3JhcHBlciB9O1xuIl19 */",
111
108
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
112
109
  });
113
110
 
@@ -125,8 +122,7 @@ const LeftColumn = /*#__PURE__*/_styled__default["default"]("div", process.env.N
125
122
  styles: "flex:1"
126
123
  } : {
127
124
  name: "82a6rk",
128
- styles: "flex:1",
129
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["translation-input.tsx"],"names":[],"mappings":"AAiF6B","file":"translation-input.tsx","sourcesContent":["import {\n  useState,\n  useCallback,\n  type ChangeEventHandler,\n  type FocusEventHandler,\n  type ReactNode,\n} from 'react';\nimport { MessageDescriptor } from 'react-intl';\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  AdditionalInfoMessage,\n  ErrorMessage,\n  WarningMessage,\n} from '@commercetools-uikit/messages';\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  additionalInfo?:\n    | string\n    | ReactNode\n    | (MessageDescriptor & {\n        values: Record<string, ReactNode>;\n      });\n  id?: string;\n  name?: string;\n  autoComplete?: string;\n  value: string;\n  onBlur?: FocusEventHandler<HTMLLocalizedTextAreaElement>;\n  isCondensed?: boolean;\n  isDisabled?: boolean;\n  placeholder?: string;\n  hasWarning?: boolean;\n  hasError?: boolean;\n  isReadOnly?: boolean;\n  isAutofocussed?: boolean;\n  cacheMeasurements?: 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 = ({\n  cacheMeasurements = true,\n  ...props\n}: TranslationInputProps) => {\n  const [inputHasSeveralRows, setInputHasSeveralRows] = useState(false);\n\n  const handleHeightChange = useCallback(\n    (_, rowCount) => {\n      // This checks if the content in the textarea is greater than one row. If it is, then the toggle button will be shown.\n      // This is to prevent the toggle button from showing when there is not enough content to expand/collapse.\n      setInputHasSeveralRows(rowCount > 1);\n    },\n    [setInputHasSeveralRows]\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  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 && inputHasSeveralRows && !props.hasLanguagesControl) ||\n    props.error ||\n    props.warning ||\n    (props.additionalInfo && !props.isCollapsed);\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          {props.language.toUpperCase()}\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          isCondensed={props.isCondensed}\n          isReadOnly={props.isReadOnly}\n          isAutofocussed={props.isAutofocussed}\n          cacheMeasurements={cacheMeasurements}\n          isOpen={!props.isCollapsed}\n          {...filterDataAttributes({\n            cacheMeasurements,\n            ...props,\n          })}\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 margin 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                <ErrorMessage>{props.error}</ErrorMessage>\n              </LeftColumn>\n            );\n          if (props.warning)\n            return (\n              <LeftColumn>\n                <WarningMessage>{props.warning}</WarningMessage>\n              </LeftColumn>\n            );\n          return null;\n        })()}\n        {!props.isCollapsed && inputHasSeveralRows && (\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      {props.additionalInfo && (\n        <Row>\n          <LeftColumn>\n            <AdditionalInfoMessage message={props.additionalInfo} />\n          </LeftColumn>\n        </Row>\n      )}\n    </Stack>\n  );\n};\n\nTranslationInput.displayName = 'TranslationInput';\n\nexport default TranslationInput;\n"]} */",
125
+ styles: "flex:1/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["translation-input.tsx"],"names":[],"mappings":"AAiF6B","file":"translation-input.tsx","sourcesContent":["import {\n  useState,\n  useCallback,\n  type ChangeEventHandler,\n  type FocusEventHandler,\n  type ReactNode,\n} from 'react';\nimport { MessageDescriptor } from 'react-intl';\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  AdditionalInfoMessage,\n  ErrorMessage,\n  WarningMessage,\n} from '@commercetools-uikit/messages';\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  additionalInfo?:\n    | string\n    | ReactNode\n    | (MessageDescriptor & {\n        values: Record<string, ReactNode>;\n      });\n  id?: string;\n  name?: string;\n  autoComplete?: string;\n  value: string;\n  onBlur?: FocusEventHandler<HTMLLocalizedTextAreaElement>;\n  isCondensed?: boolean;\n  isDisabled?: boolean;\n  placeholder?: string;\n  hasWarning?: boolean;\n  hasError?: boolean;\n  isReadOnly?: boolean;\n  isAutofocussed?: boolean;\n  cacheMeasurements?: 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 = ({\n  cacheMeasurements = true,\n  ...props\n}: TranslationInputProps) => {\n  const [inputHasSeveralRows, setInputHasSeveralRows] = useState(false);\n\n  const handleHeightChange = useCallback(\n    (_, rowCount) => {\n      // This checks if the content in the textarea is greater than one row. If it is, then the toggle button will be shown.\n      // This is to prevent the toggle button from showing when there is not enough content to expand/collapse.\n      setInputHasSeveralRows(rowCount > 1);\n    },\n    [setInputHasSeveralRows]\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  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 && inputHasSeveralRows && !props.hasLanguagesControl) ||\n    props.error ||\n    props.warning ||\n    (props.additionalInfo && !props.isCollapsed);\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          {props.language.toUpperCase()}\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          isCondensed={props.isCondensed}\n          isReadOnly={props.isReadOnly}\n          isAutofocussed={props.isAutofocussed}\n          cacheMeasurements={cacheMeasurements}\n          isOpen={!props.isCollapsed}\n          {...filterDataAttributes({\n            cacheMeasurements,\n            ...props,\n          })}\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 margin 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                <ErrorMessage>{props.error}</ErrorMessage>\n              </LeftColumn>\n            );\n          if (props.warning)\n            return (\n              <LeftColumn>\n                <WarningMessage>{props.warning}</WarningMessage>\n              </LeftColumn>\n            );\n          return null;\n        })()}\n        {!props.isCollapsed && inputHasSeveralRows && (\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      {props.additionalInfo && (\n        <Row>\n          <LeftColumn>\n            <AdditionalInfoMessage message={props.additionalInfo} />\n          </LeftColumn>\n        </Row>\n      )}\n    </Stack>\n  );\n};\n\nTranslationInput.displayName = 'TranslationInput';\n\nexport default TranslationInput;\n"]} */",
130
126
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
131
127
  });
132
128
  const RightColumn = /*#__PURE__*/_styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
@@ -139,8 +135,7 @@ const RightColumn = /*#__PURE__*/_styled__default["default"]("div", process.env.
139
135
  styles: "position:relative;flex:0;display:flex;align-items:flex-start"
140
136
  } : {
141
137
  name: "1m04uhl",
142
- styles: "position:relative;flex:0;display:flex;align-items:flex-start",
143
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["translation-input.tsx"],"names":[],"mappings":"AAqF8B","file":"translation-input.tsx","sourcesContent":["import {\n  useState,\n  useCallback,\n  type ChangeEventHandler,\n  type FocusEventHandler,\n  type ReactNode,\n} from 'react';\nimport { MessageDescriptor } from 'react-intl';\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  AdditionalInfoMessage,\n  ErrorMessage,\n  WarningMessage,\n} from '@commercetools-uikit/messages';\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  additionalInfo?:\n    | string\n    | ReactNode\n    | (MessageDescriptor & {\n        values: Record<string, ReactNode>;\n      });\n  id?: string;\n  name?: string;\n  autoComplete?: string;\n  value: string;\n  onBlur?: FocusEventHandler<HTMLLocalizedTextAreaElement>;\n  isCondensed?: boolean;\n  isDisabled?: boolean;\n  placeholder?: string;\n  hasWarning?: boolean;\n  hasError?: boolean;\n  isReadOnly?: boolean;\n  isAutofocussed?: boolean;\n  cacheMeasurements?: 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 = ({\n  cacheMeasurements = true,\n  ...props\n}: TranslationInputProps) => {\n  const [inputHasSeveralRows, setInputHasSeveralRows] = useState(false);\n\n  const handleHeightChange = useCallback(\n    (_, rowCount) => {\n      // This checks if the content in the textarea is greater than one row. If it is, then the toggle button will be shown.\n      // This is to prevent the toggle button from showing when there is not enough content to expand/collapse.\n      setInputHasSeveralRows(rowCount > 1);\n    },\n    [setInputHasSeveralRows]\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  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 && inputHasSeveralRows && !props.hasLanguagesControl) ||\n    props.error ||\n    props.warning ||\n    (props.additionalInfo && !props.isCollapsed);\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          {props.language.toUpperCase()}\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          isCondensed={props.isCondensed}\n          isReadOnly={props.isReadOnly}\n          isAutofocussed={props.isAutofocussed}\n          cacheMeasurements={cacheMeasurements}\n          isOpen={!props.isCollapsed}\n          {...filterDataAttributes({\n            cacheMeasurements,\n            ...props,\n          })}\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 margin 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                <ErrorMessage>{props.error}</ErrorMessage>\n              </LeftColumn>\n            );\n          if (props.warning)\n            return (\n              <LeftColumn>\n                <WarningMessage>{props.warning}</WarningMessage>\n              </LeftColumn>\n            );\n          return null;\n        })()}\n        {!props.isCollapsed && inputHasSeveralRows && (\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      {props.additionalInfo && (\n        <Row>\n          <LeftColumn>\n            <AdditionalInfoMessage message={props.additionalInfo} />\n          </LeftColumn>\n        </Row>\n      )}\n    </Stack>\n  );\n};\n\nTranslationInput.displayName = 'TranslationInput';\n\nexport default TranslationInput;\n"]} */",
138
+ styles: "position:relative;flex:0;display:flex;align-items:flex-start/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["translation-input.tsx"],"names":[],"mappings":"AAqF8B","file":"translation-input.tsx","sourcesContent":["import {\n  useState,\n  useCallback,\n  type ChangeEventHandler,\n  type FocusEventHandler,\n  type ReactNode,\n} from 'react';\nimport { MessageDescriptor } from 'react-intl';\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  AdditionalInfoMessage,\n  ErrorMessage,\n  WarningMessage,\n} from '@commercetools-uikit/messages';\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  additionalInfo?:\n    | string\n    | ReactNode\n    | (MessageDescriptor & {\n        values: Record<string, ReactNode>;\n      });\n  id?: string;\n  name?: string;\n  autoComplete?: string;\n  value: string;\n  onBlur?: FocusEventHandler<HTMLLocalizedTextAreaElement>;\n  isCondensed?: boolean;\n  isDisabled?: boolean;\n  placeholder?: string;\n  hasWarning?: boolean;\n  hasError?: boolean;\n  isReadOnly?: boolean;\n  isAutofocussed?: boolean;\n  cacheMeasurements?: 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 = ({\n  cacheMeasurements = true,\n  ...props\n}: TranslationInputProps) => {\n  const [inputHasSeveralRows, setInputHasSeveralRows] = useState(false);\n\n  const handleHeightChange = useCallback(\n    (_, rowCount) => {\n      // This checks if the content in the textarea is greater than one row. If it is, then the toggle button will be shown.\n      // This is to prevent the toggle button from showing when there is not enough content to expand/collapse.\n      setInputHasSeveralRows(rowCount > 1);\n    },\n    [setInputHasSeveralRows]\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  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 && inputHasSeveralRows && !props.hasLanguagesControl) ||\n    props.error ||\n    props.warning ||\n    (props.additionalInfo && !props.isCollapsed);\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          {props.language.toUpperCase()}\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          isCondensed={props.isCondensed}\n          isReadOnly={props.isReadOnly}\n          isAutofocussed={props.isAutofocussed}\n          cacheMeasurements={cacheMeasurements}\n          isOpen={!props.isCollapsed}\n          {...filterDataAttributes({\n            cacheMeasurements,\n            ...props,\n          })}\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 margin 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                <ErrorMessage>{props.error}</ErrorMessage>\n              </LeftColumn>\n            );\n          if (props.warning)\n            return (\n              <LeftColumn>\n                <WarningMessage>{props.warning}</WarningMessage>\n              </LeftColumn>\n            );\n          return null;\n        })()}\n        {!props.isCollapsed && inputHasSeveralRows && (\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      {props.additionalInfo && (\n        <Row>\n          <LeftColumn>\n            <AdditionalInfoMessage message={props.additionalInfo} />\n          </LeftColumn>\n        </Row>\n      )}\n    </Stack>\n  );\n};\n\nTranslationInput.displayName = 'TranslationInput';\n\nexport default TranslationInput;\n"]} */",
144
139
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
145
140
  });
146
141
  const Row = /*#__PURE__*/_styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
@@ -153,8 +148,7 @@ const Row = /*#__PURE__*/_styled__default["default"]("div", process.env.NODE_ENV
153
148
  styles: "display:flex;justify-content:flex-end"
154
149
  } : {
155
150
  name: "skgbeu",
156
- styles: "display:flex;justify-content:flex-end",
157
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["translation-input.tsx"],"names":[],"mappings":"AA4FsB","file":"translation-input.tsx","sourcesContent":["import {\n  useState,\n  useCallback,\n  type ChangeEventHandler,\n  type FocusEventHandler,\n  type ReactNode,\n} from 'react';\nimport { MessageDescriptor } from 'react-intl';\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  AdditionalInfoMessage,\n  ErrorMessage,\n  WarningMessage,\n} from '@commercetools-uikit/messages';\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  additionalInfo?:\n    | string\n    | ReactNode\n    | (MessageDescriptor & {\n        values: Record<string, ReactNode>;\n      });\n  id?: string;\n  name?: string;\n  autoComplete?: string;\n  value: string;\n  onBlur?: FocusEventHandler<HTMLLocalizedTextAreaElement>;\n  isCondensed?: boolean;\n  isDisabled?: boolean;\n  placeholder?: string;\n  hasWarning?: boolean;\n  hasError?: boolean;\n  isReadOnly?: boolean;\n  isAutofocussed?: boolean;\n  cacheMeasurements?: 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 = ({\n  cacheMeasurements = true,\n  ...props\n}: TranslationInputProps) => {\n  const [inputHasSeveralRows, setInputHasSeveralRows] = useState(false);\n\n  const handleHeightChange = useCallback(\n    (_, rowCount) => {\n      // This checks if the content in the textarea is greater than one row. If it is, then the toggle button will be shown.\n      // This is to prevent the toggle button from showing when there is not enough content to expand/collapse.\n      setInputHasSeveralRows(rowCount > 1);\n    },\n    [setInputHasSeveralRows]\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  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 && inputHasSeveralRows && !props.hasLanguagesControl) ||\n    props.error ||\n    props.warning ||\n    (props.additionalInfo && !props.isCollapsed);\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          {props.language.toUpperCase()}\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          isCondensed={props.isCondensed}\n          isReadOnly={props.isReadOnly}\n          isAutofocussed={props.isAutofocussed}\n          cacheMeasurements={cacheMeasurements}\n          isOpen={!props.isCollapsed}\n          {...filterDataAttributes({\n            cacheMeasurements,\n            ...props,\n          })}\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 margin 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                <ErrorMessage>{props.error}</ErrorMessage>\n              </LeftColumn>\n            );\n          if (props.warning)\n            return (\n              <LeftColumn>\n                <WarningMessage>{props.warning}</WarningMessage>\n              </LeftColumn>\n            );\n          return null;\n        })()}\n        {!props.isCollapsed && inputHasSeveralRows && (\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      {props.additionalInfo && (\n        <Row>\n          <LeftColumn>\n            <AdditionalInfoMessage message={props.additionalInfo} />\n          </LeftColumn>\n        </Row>\n      )}\n    </Stack>\n  );\n};\n\nTranslationInput.displayName = 'TranslationInput';\n\nexport default TranslationInput;\n"]} */",
151
+ styles: "display:flex;justify-content:flex-end/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["translation-input.tsx"],"names":[],"mappings":"AA4FsB","file":"translation-input.tsx","sourcesContent":["import {\n  useState,\n  useCallback,\n  type ChangeEventHandler,\n  type FocusEventHandler,\n  type ReactNode,\n} from 'react';\nimport { MessageDescriptor } from 'react-intl';\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  AdditionalInfoMessage,\n  ErrorMessage,\n  WarningMessage,\n} from '@commercetools-uikit/messages';\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  additionalInfo?:\n    | string\n    | ReactNode\n    | (MessageDescriptor & {\n        values: Record<string, ReactNode>;\n      });\n  id?: string;\n  name?: string;\n  autoComplete?: string;\n  value: string;\n  onBlur?: FocusEventHandler<HTMLLocalizedTextAreaElement>;\n  isCondensed?: boolean;\n  isDisabled?: boolean;\n  placeholder?: string;\n  hasWarning?: boolean;\n  hasError?: boolean;\n  isReadOnly?: boolean;\n  isAutofocussed?: boolean;\n  cacheMeasurements?: 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 = ({\n  cacheMeasurements = true,\n  ...props\n}: TranslationInputProps) => {\n  const [inputHasSeveralRows, setInputHasSeveralRows] = useState(false);\n\n  const handleHeightChange = useCallback(\n    (_, rowCount) => {\n      // This checks if the content in the textarea is greater than one row. If it is, then the toggle button will be shown.\n      // This is to prevent the toggle button from showing when there is not enough content to expand/collapse.\n      setInputHasSeveralRows(rowCount > 1);\n    },\n    [setInputHasSeveralRows]\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  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 && inputHasSeveralRows && !props.hasLanguagesControl) ||\n    props.error ||\n    props.warning ||\n    (props.additionalInfo && !props.isCollapsed);\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          {props.language.toUpperCase()}\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          isCondensed={props.isCondensed}\n          isReadOnly={props.isReadOnly}\n          isAutofocussed={props.isAutofocussed}\n          cacheMeasurements={cacheMeasurements}\n          isOpen={!props.isCollapsed}\n          {...filterDataAttributes({\n            cacheMeasurements,\n            ...props,\n          })}\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 margin 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                <ErrorMessage>{props.error}</ErrorMessage>\n              </LeftColumn>\n            );\n          if (props.warning)\n            return (\n              <LeftColumn>\n                <WarningMessage>{props.warning}</WarningMessage>\n              </LeftColumn>\n            );\n          return null;\n        })()}\n        {!props.isCollapsed && inputHasSeveralRows && (\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      {props.additionalInfo && (\n        <Row>\n          <LeftColumn>\n            <AdditionalInfoMessage message={props.additionalInfo} />\n          </LeftColumn>\n        </Row>\n      )}\n    </Stack>\n  );\n};\n\nTranslationInput.displayName = 'TranslationInput';\n\nexport default TranslationInput;\n"]} */",
158
152
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
159
153
  });
160
154
  var _ref = process.env.NODE_ENV === "production" ? {
@@ -162,8 +156,7 @@ var _ref = process.env.NODE_ENV === "production" ? {
162
156
  styles: "width:100%;position:relative;display:flex"
163
157
  } : {
164
158
  name: "1r0st9p-TranslationInput",
165
- styles: "width:100%;position:relative;display:flex;label:TranslationInput;",
166
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["translation-input.tsx"],"names":[],"mappings":"AAsKgB","file":"translation-input.tsx","sourcesContent":["import {\n  useState,\n  useCallback,\n  type ChangeEventHandler,\n  type FocusEventHandler,\n  type ReactNode,\n} from 'react';\nimport { MessageDescriptor } from 'react-intl';\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  AdditionalInfoMessage,\n  ErrorMessage,\n  WarningMessage,\n} from '@commercetools-uikit/messages';\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  additionalInfo?:\n    | string\n    | ReactNode\n    | (MessageDescriptor & {\n        values: Record<string, ReactNode>;\n      });\n  id?: string;\n  name?: string;\n  autoComplete?: string;\n  value: string;\n  onBlur?: FocusEventHandler<HTMLLocalizedTextAreaElement>;\n  isCondensed?: boolean;\n  isDisabled?: boolean;\n  placeholder?: string;\n  hasWarning?: boolean;\n  hasError?: boolean;\n  isReadOnly?: boolean;\n  isAutofocussed?: boolean;\n  cacheMeasurements?: 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 = ({\n  cacheMeasurements = true,\n  ...props\n}: TranslationInputProps) => {\n  const [inputHasSeveralRows, setInputHasSeveralRows] = useState(false);\n\n  const handleHeightChange = useCallback(\n    (_, rowCount) => {\n      // This checks if the content in the textarea is greater than one row. If it is, then the toggle button will be shown.\n      // This is to prevent the toggle button from showing when there is not enough content to expand/collapse.\n      setInputHasSeveralRows(rowCount > 1);\n    },\n    [setInputHasSeveralRows]\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  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 && inputHasSeveralRows && !props.hasLanguagesControl) ||\n    props.error ||\n    props.warning ||\n    (props.additionalInfo && !props.isCollapsed);\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          {props.language.toUpperCase()}\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          isCondensed={props.isCondensed}\n          isReadOnly={props.isReadOnly}\n          isAutofocussed={props.isAutofocussed}\n          cacheMeasurements={cacheMeasurements}\n          isOpen={!props.isCollapsed}\n          {...filterDataAttributes({\n            cacheMeasurements,\n            ...props,\n          })}\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 margin 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                <ErrorMessage>{props.error}</ErrorMessage>\n              </LeftColumn>\n            );\n          if (props.warning)\n            return (\n              <LeftColumn>\n                <WarningMessage>{props.warning}</WarningMessage>\n              </LeftColumn>\n            );\n          return null;\n        })()}\n        {!props.isCollapsed && inputHasSeveralRows && (\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      {props.additionalInfo && (\n        <Row>\n          <LeftColumn>\n            <AdditionalInfoMessage message={props.additionalInfo} />\n          </LeftColumn>\n        </Row>\n      )}\n    </Stack>\n  );\n};\n\nTranslationInput.displayName = 'TranslationInput';\n\nexport default TranslationInput;\n"]} */",
159
+ styles: "width:100%;position:relative;display:flex;label:TranslationInput;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["translation-input.tsx"],"names":[],"mappings":"AAsKgB","file":"translation-input.tsx","sourcesContent":["import {\n  useState,\n  useCallback,\n  type ChangeEventHandler,\n  type FocusEventHandler,\n  type ReactNode,\n} from 'react';\nimport { MessageDescriptor } from 'react-intl';\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  AdditionalInfoMessage,\n  ErrorMessage,\n  WarningMessage,\n} from '@commercetools-uikit/messages';\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  additionalInfo?:\n    | string\n    | ReactNode\n    | (MessageDescriptor & {\n        values: Record<string, ReactNode>;\n      });\n  id?: string;\n  name?: string;\n  autoComplete?: string;\n  value: string;\n  onBlur?: FocusEventHandler<HTMLLocalizedTextAreaElement>;\n  isCondensed?: boolean;\n  isDisabled?: boolean;\n  placeholder?: string;\n  hasWarning?: boolean;\n  hasError?: boolean;\n  isReadOnly?: boolean;\n  isAutofocussed?: boolean;\n  cacheMeasurements?: 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 = ({\n  cacheMeasurements = true,\n  ...props\n}: TranslationInputProps) => {\n  const [inputHasSeveralRows, setInputHasSeveralRows] = useState(false);\n\n  const handleHeightChange = useCallback(\n    (_, rowCount) => {\n      // This checks if the content in the textarea is greater than one row. If it is, then the toggle button will be shown.\n      // This is to prevent the toggle button from showing when there is not enough content to expand/collapse.\n      setInputHasSeveralRows(rowCount > 1);\n    },\n    [setInputHasSeveralRows]\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  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 && inputHasSeveralRows && !props.hasLanguagesControl) ||\n    props.error ||\n    props.warning ||\n    (props.additionalInfo && !props.isCollapsed);\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          {props.language.toUpperCase()}\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          isCondensed={props.isCondensed}\n          isReadOnly={props.isReadOnly}\n          isAutofocussed={props.isAutofocussed}\n          cacheMeasurements={cacheMeasurements}\n          isOpen={!props.isCollapsed}\n          {...filterDataAttributes({\n            cacheMeasurements,\n            ...props,\n          })}\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 margin 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                <ErrorMessage>{props.error}</ErrorMessage>\n              </LeftColumn>\n            );\n          if (props.warning)\n            return (\n              <LeftColumn>\n                <WarningMessage>{props.warning}</WarningMessage>\n              </LeftColumn>\n            );\n          return null;\n        })()}\n        {!props.isCollapsed && inputHasSeveralRows && (\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      {props.additionalInfo && (\n        <Row>\n          <LeftColumn>\n            <AdditionalInfoMessage message={props.additionalInfo} />\n          </LeftColumn>\n        </Row>\n      )}\n    </Stack>\n  );\n};\n\nTranslationInput.displayName = 'TranslationInput';\n\nexport default TranslationInput;\n"]} */",
167
160
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
168
161
  };
169
162
  const TranslationInput = _ref2 => {
@@ -505,7 +498,7 @@ LocalizedMultilineTextInput.isTouched = localizedUtils.isTouched;
505
498
  var LocalizedMultilineTextInput$1 = LocalizedMultilineTextInput;
506
499
 
507
500
  // NOTE: This string will be replaced on build time with the package version.
508
- var version = "19.22.0";
501
+ var version = "19.22.2";
509
502
 
510
503
  exports["default"] = LocalizedMultilineTextInput$1;
511
504
  exports.version = version;
@@ -390,7 +390,7 @@ LocalizedMultilineTextInput.isTouched = localizedUtils.isTouched;
390
390
  var LocalizedMultilineTextInput$1 = LocalizedMultilineTextInput;
391
391
 
392
392
  // NOTE: This string will be replaced on build time with the package version.
393
- var version = "19.22.0";
393
+ var version = "19.22.2";
394
394
 
395
395
  exports["default"] = LocalizedMultilineTextInput$1;
396
396
  exports.version = version;
@@ -39,8 +39,7 @@ var _ref$1 = process.env.NODE_ENV === "production" ? {
39
39
  styles: "overflow:hidden"
40
40
  } : {
41
41
  name: "1h6gnzr-baseStyles",
42
- styles: "overflow:hidden;label:baseStyles;",
43
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRyYW5zbGF0aW9uLWlucHV0LnN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF1QlMiLCJmaWxlIjoidHJhbnNsYXRpb24taW5wdXQuc3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5cbi8vIE5PVEU6IG9yZGVyIGlzIGltcG9ydGFudCBoZXJlXG4vLyAqIGEgZGlzYWJsZWQtZmllbGQgY3VycmVudGx5IGRvZXMgbm90IGRpc3BsYXkgd2FybmluZy9lcnJvci1zdGF0ZXMgc28gaXQgdGFrZXMgcHJlY2VkZW5jZVxuLy8gKiBhIHJlYWRvbmx5LWZpZWxkIGNhbm5vdCBiZSBjaGFuZ2VkLCBidXQgaXQgbWlnaHQgYmUgcmVsZXZhbnQgZm9yIHZhbGlkYXRpb24sIHNvIGVycm9yIGFuZCB3YXJuaW5nIGFyZSBjaGVja2VkIGZpcnN0XG4vLyBob3cgeW91IGNhbiBpbnRlcmFjdCB3aXRoIHRoZSBmaWVsZCBpcyBjb250cm9sbGVkIHNlcGFyYXRlbHkgYnkgdGhlIHByb3BzLCB0aGlzIG9ubHkgaW5mbHVlbmNlcyB2aXN1YWxzXG5cbnR5cGUgVFRyYW5zbGF0aW9uSW5wdXRTdHlsZXNQcm9wcyA9IHtcbiAgaXNDb2xsYXBzZWQ/OiBib29sZWFuO1xuICBpc0NvbmRlbnNlZD86IGJvb2xlYW47XG4gIGlzRGlzYWJsZWQ/OiBib29sZWFuO1xuICBpc1JlYWRPbmx5PzogYm9vbGVhbjtcbn07XG5cbmNvbnN0IGdldFRleHRhcmVhU3R5bGVzID0gKHByb3BzOiBUVHJhbnNsYXRpb25JbnB1dFN0eWxlc1Byb3BzKSA9PiB7XG4gIGNvbnN0IGJhc2VTdHlsZXMgPSBbXG4gICAgY3NzYFxuICAgICAgYm9yZGVyLXRvcC1sZWZ0LXJhZGl1czogMCAhaW1wb3J0YW50O1xuICAgICAgYm9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogMCAhaW1wb3J0YW50O1xuICAgIGAsXG4gICAgcHJvcHMuaXNDb2xsYXBzZWQgJiZcbiAgICAgIGNzc2BcbiAgICAgICAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgICAgIGAsXG4gIF07XG4gIHJldHVybiBiYXNlU3R5bGVzO1xufTtcblxuY29uc3QgZ2V0TGFuZ3VhZ2VMYWJlbEJhY2tncm91bmRDb2xvciA9IChcbiAgcHJvcHM6IFRUcmFuc2xhdGlvbklucHV0U3R5bGVzUHJvcHNcbikgPT4ge1xuICBpZiAocHJvcHMuaXNEaXNhYmxlZCkge1xuICAgIHJldHVybiBkZXNpZ25Ub2tlbnMuYmFja2dyb3VuZENvbG9yRm9yTG9jYWxpemVkSW5wdXRMYWJlbFdoZW5EaXNhYmxlZDtcbiAgfVxuICBpZiAocHJvcHMuaXNSZWFkT25seSkge1xuICAgIHJldHVybiBkZXNpZ25Ub2tlbnMuYmFja2dyb3VuZENvbG9yRm9yTG9jYWxpemVkSW5wdXRMYWJlbFdoZW5SZWFkb25seTtcbiAgfVxuICByZXR1cm4gZGVzaWduVG9rZW5zLmJhY2tncm91bmRDb2xvckZvckxvY2FsaXplZElucHV0TGFiZWw7XG59O1xuXG5jb25zdCBnZXRMYW5ndWFnZUxhYmVsQm9yZGVyQ29sb3IgPSAocHJvcHM6IFRUcmFuc2xhdGlvbklucHV0U3R5bGVzUHJvcHMpID0+IHtcbiAgaWYgKHByb3BzLmlzRGlzYWJsZWQpIHtcbiAgICByZXR1cm4gZGVzaWduVG9rZW5zLmJvcmRlckNvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWQ7XG4gIH1cbiAgcmV0dXJuIHByb3BzLmlzUmVhZE9ubHlcbiAgICA/IGRlc2lnblRva2Vucy5jb2xvclN1cmZhY2VcbiAgICA6IGRlc2lnblRva2Vucy5jb2xvck5ldXRyYWw7XG59O1xuXG5jb25zdCBnZXRMYW5ndWFnZUxhYmVsU3R5bGVzID0gKHByb3BzOiBUVHJhbnNsYXRpb25JbnB1dFN0eWxlc1Byb3BzKSA9PiB7XG4gIHJldHVybiBjc3NgXG4gICAgLyogYXZvaWQgd3JhcHBpbmcgbGFiZWwgb250byBuZXcgbGluZXMgKi9cbiAgICBmbGV4OiAxIDAgYXV0bztcbiAgICBjb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsNjB9O1xuICAgIGN1cnNvcjogJHtwcm9wcy5pc0Rpc2FibGVkID8gJ25vdC1hbGxvd2VkJyA6ICdkZWZhdWx0J307XG4gICAgbGluZS1oZWlnaHQ6IGNhbGMoXG4gICAgICAke3Byb3BzLmlzQ29uZGVuc2VkXG4gICAgICAgICAgPyBkZXNpZ25Ub2tlbnMuaGVpZ2h0Rm9ySW5wdXRBc1NtYWxsXG4gICAgICAgICAgOiBkZXNpZ25Ub2tlbnMuaGVpZ2h0Rm9ySW5wdXR9IC0gMiAqICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czF9XG4gICAgKTtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke2dldExhbmd1YWdlTGFiZWxCYWNrZ3JvdW5kQ29sb3IocHJvcHMpfTtcbiAgICBib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAke2Rlc2lnblRva2Vucy5ib3JkZXJSYWRpdXNGb3JJbnB1dH07XG4gICAgYm9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzRm9ySW5wdXR9O1xuICAgIGJvcmRlcjogMXB4ICR7Z2V0TGFuZ3VhZ2VMYWJlbEJvcmRlckNvbG9yKHByb3BzKX0gc29saWQ7XG4gICAgcGFkZGluZzogMCAke2Rlc2lnblRva2Vucy5zcGFjaW5nMjV9O1xuICAgIGZvbnQtc2l6ZTogJHtwcm9wcy5pc0NvbmRlbnNlZFxuICAgICAgPyBkZXNpZ25Ub2tlbnMuZm9udFNpemUyMFxuICAgICAgOiBkZXNpZ25Ub2tlbnMuZm9udFNpemUzMH07XG4gICAgdHJhbnNpdGlvbjogYm9yZGVyLWNvbG9yICR7ZGVzaWduVG9rZW5zLnRyYW5zaXRpb25TdGFuZGFyZH0sXG4gICAgICBiYWNrZ3JvdW5kLWNvbG9yICR7ZGVzaWduVG9rZW5zLnRyYW5zaXRpb25TdGFuZGFyZH0sXG4gICAgICBjb2xvciAke2Rlc2lnblRva2Vucy50cmFuc2l0aW9uU3RhbmRhcmR9O1xuICAgIGJvcmRlci1yaWdodDogMDtcbiAgICBib3gtc2hhZG93OiBub25lO1xuICAgIGFwcGVhcmFuY2U6IG5vbmU7XG4gIGA7XG59O1xuXG5jb25zdCBUb2dnbGVCdXR0b25XcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgZmxleDogMDtcbiAgZGlzcGxheTogZmxleDtcbmA7XG5cbmV4cG9ydCB7IGdldFRleHRhcmVhU3R5bGVzLCBnZXRMYW5ndWFnZUxhYmVsU3R5bGVzLCBUb2dnbGVCdXR0b25XcmFwcGVyIH07XG4iXX0= */",
42
+ styles: "overflow:hidden;label:baseStyles;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRyYW5zbGF0aW9uLWlucHV0LnN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF1QlMiLCJmaWxlIjoidHJhbnNsYXRpb24taW5wdXQuc3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5cbi8vIE5PVEU6IG9yZGVyIGlzIGltcG9ydGFudCBoZXJlXG4vLyAqIGEgZGlzYWJsZWQtZmllbGQgY3VycmVudGx5IGRvZXMgbm90IGRpc3BsYXkgd2FybmluZy9lcnJvci1zdGF0ZXMgc28gaXQgdGFrZXMgcHJlY2VkZW5jZVxuLy8gKiBhIHJlYWRvbmx5LWZpZWxkIGNhbm5vdCBiZSBjaGFuZ2VkLCBidXQgaXQgbWlnaHQgYmUgcmVsZXZhbnQgZm9yIHZhbGlkYXRpb24sIHNvIGVycm9yIGFuZCB3YXJuaW5nIGFyZSBjaGVja2VkIGZpcnN0XG4vLyBob3cgeW91IGNhbiBpbnRlcmFjdCB3aXRoIHRoZSBmaWVsZCBpcyBjb250cm9sbGVkIHNlcGFyYXRlbHkgYnkgdGhlIHByb3BzLCB0aGlzIG9ubHkgaW5mbHVlbmNlcyB2aXN1YWxzXG5cbnR5cGUgVFRyYW5zbGF0aW9uSW5wdXRTdHlsZXNQcm9wcyA9IHtcbiAgaXNDb2xsYXBzZWQ/OiBib29sZWFuO1xuICBpc0NvbmRlbnNlZD86IGJvb2xlYW47XG4gIGlzRGlzYWJsZWQ/OiBib29sZWFuO1xuICBpc1JlYWRPbmx5PzogYm9vbGVhbjtcbn07XG5cbmNvbnN0IGdldFRleHRhcmVhU3R5bGVzID0gKHByb3BzOiBUVHJhbnNsYXRpb25JbnB1dFN0eWxlc1Byb3BzKSA9PiB7XG4gIGNvbnN0IGJhc2VTdHlsZXMgPSBbXG4gICAgY3NzYFxuICAgICAgYm9yZGVyLXRvcC1sZWZ0LXJhZGl1czogMCAhaW1wb3J0YW50O1xuICAgICAgYm9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogMCAhaW1wb3J0YW50O1xuICAgIGAsXG4gICAgcHJvcHMuaXNDb2xsYXBzZWQgJiZcbiAgICAgIGNzc2BcbiAgICAgICAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgICAgIGAsXG4gIF07XG4gIHJldHVybiBiYXNlU3R5bGVzO1xufTtcblxuY29uc3QgZ2V0TGFuZ3VhZ2VMYWJlbEJhY2tncm91bmRDb2xvciA9IChcbiAgcHJvcHM6IFRUcmFuc2xhdGlvbklucHV0U3R5bGVzUHJvcHNcbikgPT4ge1xuICBpZiAocHJvcHMuaXNEaXNhYmxlZCkge1xuICAgIHJldHVybiBkZXNpZ25Ub2tlbnMuYmFja2dyb3VuZENvbG9yRm9yTG9jYWxpemVkSW5wdXRMYWJlbFdoZW5EaXNhYmxlZDtcbiAgfVxuICBpZiAocHJvcHMuaXNSZWFkT25seSkge1xuICAgIHJldHVybiBkZXNpZ25Ub2tlbnMuYmFja2dyb3VuZENvbG9yRm9yTG9jYWxpemVkSW5wdXRMYWJlbFdoZW5SZWFkb25seTtcbiAgfVxuICByZXR1cm4gZGVzaWduVG9rZW5zLmJhY2tncm91bmRDb2xvckZvckxvY2FsaXplZElucHV0TGFiZWw7XG59O1xuXG5jb25zdCBnZXRMYW5ndWFnZUxhYmVsQm9yZGVyQ29sb3IgPSAocHJvcHM6IFRUcmFuc2xhdGlvbklucHV0U3R5bGVzUHJvcHMpID0+IHtcbiAgaWYgKHByb3BzLmlzRGlzYWJsZWQpIHtcbiAgICByZXR1cm4gZGVzaWduVG9rZW5zLmJvcmRlckNvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWQ7XG4gIH1cbiAgcmV0dXJuIHByb3BzLmlzUmVhZE9ubHlcbiAgICA/IGRlc2lnblRva2Vucy5jb2xvclN1cmZhY2VcbiAgICA6IGRlc2lnblRva2Vucy5jb2xvck5ldXRyYWw7XG59O1xuXG5jb25zdCBnZXRMYW5ndWFnZUxhYmVsU3R5bGVzID0gKHByb3BzOiBUVHJhbnNsYXRpb25JbnB1dFN0eWxlc1Byb3BzKSA9PiB7XG4gIHJldHVybiBjc3NgXG4gICAgLyogYXZvaWQgd3JhcHBpbmcgbGFiZWwgb250byBuZXcgbGluZXMgKi9cbiAgICBmbGV4OiAxIDAgYXV0bztcbiAgICBjb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsNjB9O1xuICAgIGN1cnNvcjogJHtwcm9wcy5pc0Rpc2FibGVkID8gJ25vdC1hbGxvd2VkJyA6ICdkZWZhdWx0J307XG4gICAgbGluZS1oZWlnaHQ6IGNhbGMoXG4gICAgICAke3Byb3BzLmlzQ29uZGVuc2VkXG4gICAgICAgICAgPyBkZXNpZ25Ub2tlbnMuaGVpZ2h0Rm9ySW5wdXRBc1NtYWxsXG4gICAgICAgICAgOiBkZXNpZ25Ub2tlbnMuaGVpZ2h0Rm9ySW5wdXR9IC0gMiAqICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czF9XG4gICAgKTtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke2dldExhbmd1YWdlTGFiZWxCYWNrZ3JvdW5kQ29sb3IocHJvcHMpfTtcbiAgICBib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAke2Rlc2lnblRva2Vucy5ib3JkZXJSYWRpdXNGb3JJbnB1dH07XG4gICAgYm9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzRm9ySW5wdXR9O1xuICAgIGJvcmRlcjogMXB4ICR7Z2V0TGFuZ3VhZ2VMYWJlbEJvcmRlckNvbG9yKHByb3BzKX0gc29saWQ7XG4gICAgcGFkZGluZzogMCAke2Rlc2lnblRva2Vucy5zcGFjaW5nMjV9O1xuICAgIGZvbnQtc2l6ZTogJHtwcm9wcy5pc0NvbmRlbnNlZFxuICAgICAgPyBkZXNpZ25Ub2tlbnMuZm9udFNpemUyMFxuICAgICAgOiBkZXNpZ25Ub2tlbnMuZm9udFNpemUzMH07XG4gICAgdHJhbnNpdGlvbjogYm9yZGVyLWNvbG9yICR7ZGVzaWduVG9rZW5zLnRyYW5zaXRpb25TdGFuZGFyZH0sXG4gICAgICBiYWNrZ3JvdW5kLWNvbG9yICR7ZGVzaWduVG9rZW5zLnRyYW5zaXRpb25TdGFuZGFyZH0sXG4gICAgICBjb2xvciAke2Rlc2lnblRva2Vucy50cmFuc2l0aW9uU3RhbmRhcmR9O1xuICAgIGJvcmRlci1yaWdodDogMDtcbiAgICBib3gtc2hhZG93OiBub25lO1xuICAgIGFwcGVhcmFuY2U6IG5vbmU7XG4gIGA7XG59O1xuXG5jb25zdCBUb2dnbGVCdXR0b25XcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgZmxleDogMDtcbiAgZGlzcGxheTogZmxleDtcbmA7XG5cbmV4cG9ydCB7IGdldFRleHRhcmVhU3R5bGVzLCBnZXRMYW5ndWFnZUxhYmVsU3R5bGVzLCBUb2dnbGVCdXR0b25XcmFwcGVyIH07XG4iXX0= */",
44
43
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
45
44
  };
46
45
  var _ref2 = process.env.NODE_ENV === "production" ? {
@@ -48,8 +47,7 @@ var _ref2 = process.env.NODE_ENV === "production" ? {
48
47
  styles: "border-top-left-radius:0!important;border-bottom-left-radius:0!important"
49
48
  } : {
50
49
  name: "pb9fe4-baseStyles",
51
- styles: "border-top-left-radius:0!important;border-bottom-left-radius:0!important;label:baseStyles;",
52
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRyYW5zbGF0aW9uLWlucHV0LnN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFrQk8iLCJmaWxlIjoidHJhbnNsYXRpb24taW5wdXQuc3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5cbi8vIE5PVEU6IG9yZGVyIGlzIGltcG9ydGFudCBoZXJlXG4vLyAqIGEgZGlzYWJsZWQtZmllbGQgY3VycmVudGx5IGRvZXMgbm90IGRpc3BsYXkgd2FybmluZy9lcnJvci1zdGF0ZXMgc28gaXQgdGFrZXMgcHJlY2VkZW5jZVxuLy8gKiBhIHJlYWRvbmx5LWZpZWxkIGNhbm5vdCBiZSBjaGFuZ2VkLCBidXQgaXQgbWlnaHQgYmUgcmVsZXZhbnQgZm9yIHZhbGlkYXRpb24sIHNvIGVycm9yIGFuZCB3YXJuaW5nIGFyZSBjaGVja2VkIGZpcnN0XG4vLyBob3cgeW91IGNhbiBpbnRlcmFjdCB3aXRoIHRoZSBmaWVsZCBpcyBjb250cm9sbGVkIHNlcGFyYXRlbHkgYnkgdGhlIHByb3BzLCB0aGlzIG9ubHkgaW5mbHVlbmNlcyB2aXN1YWxzXG5cbnR5cGUgVFRyYW5zbGF0aW9uSW5wdXRTdHlsZXNQcm9wcyA9IHtcbiAgaXNDb2xsYXBzZWQ/OiBib29sZWFuO1xuICBpc0NvbmRlbnNlZD86IGJvb2xlYW47XG4gIGlzRGlzYWJsZWQ/OiBib29sZWFuO1xuICBpc1JlYWRPbmx5PzogYm9vbGVhbjtcbn07XG5cbmNvbnN0IGdldFRleHRhcmVhU3R5bGVzID0gKHByb3BzOiBUVHJhbnNsYXRpb25JbnB1dFN0eWxlc1Byb3BzKSA9PiB7XG4gIGNvbnN0IGJhc2VTdHlsZXMgPSBbXG4gICAgY3NzYFxuICAgICAgYm9yZGVyLXRvcC1sZWZ0LXJhZGl1czogMCAhaW1wb3J0YW50O1xuICAgICAgYm9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogMCAhaW1wb3J0YW50O1xuICAgIGAsXG4gICAgcHJvcHMuaXNDb2xsYXBzZWQgJiZcbiAgICAgIGNzc2BcbiAgICAgICAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgICAgIGAsXG4gIF07XG4gIHJldHVybiBiYXNlU3R5bGVzO1xufTtcblxuY29uc3QgZ2V0TGFuZ3VhZ2VMYWJlbEJhY2tncm91bmRDb2xvciA9IChcbiAgcHJvcHM6IFRUcmFuc2xhdGlvbklucHV0U3R5bGVzUHJvcHNcbikgPT4ge1xuICBpZiAocHJvcHMuaXNEaXNhYmxlZCkge1xuICAgIHJldHVybiBkZXNpZ25Ub2tlbnMuYmFja2dyb3VuZENvbG9yRm9yTG9jYWxpemVkSW5wdXRMYWJlbFdoZW5EaXNhYmxlZDtcbiAgfVxuICBpZiAocHJvcHMuaXNSZWFkT25seSkge1xuICAgIHJldHVybiBkZXNpZ25Ub2tlbnMuYmFja2dyb3VuZENvbG9yRm9yTG9jYWxpemVkSW5wdXRMYWJlbFdoZW5SZWFkb25seTtcbiAgfVxuICByZXR1cm4gZGVzaWduVG9rZW5zLmJhY2tncm91bmRDb2xvckZvckxvY2FsaXplZElucHV0TGFiZWw7XG59O1xuXG5jb25zdCBnZXRMYW5ndWFnZUxhYmVsQm9yZGVyQ29sb3IgPSAocHJvcHM6IFRUcmFuc2xhdGlvbklucHV0U3R5bGVzUHJvcHMpID0+IHtcbiAgaWYgKHByb3BzLmlzRGlzYWJsZWQpIHtcbiAgICByZXR1cm4gZGVzaWduVG9rZW5zLmJvcmRlckNvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWQ7XG4gIH1cbiAgcmV0dXJuIHByb3BzLmlzUmVhZE9ubHlcbiAgICA/IGRlc2lnblRva2Vucy5jb2xvclN1cmZhY2VcbiAgICA6IGRlc2lnblRva2Vucy5jb2xvck5ldXRyYWw7XG59O1xuXG5jb25zdCBnZXRMYW5ndWFnZUxhYmVsU3R5bGVzID0gKHByb3BzOiBUVHJhbnNsYXRpb25JbnB1dFN0eWxlc1Byb3BzKSA9PiB7XG4gIHJldHVybiBjc3NgXG4gICAgLyogYXZvaWQgd3JhcHBpbmcgbGFiZWwgb250byBuZXcgbGluZXMgKi9cbiAgICBmbGV4OiAxIDAgYXV0bztcbiAgICBjb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsNjB9O1xuICAgIGN1cnNvcjogJHtwcm9wcy5pc0Rpc2FibGVkID8gJ25vdC1hbGxvd2VkJyA6ICdkZWZhdWx0J307XG4gICAgbGluZS1oZWlnaHQ6IGNhbGMoXG4gICAgICAke3Byb3BzLmlzQ29uZGVuc2VkXG4gICAgICAgICAgPyBkZXNpZ25Ub2tlbnMuaGVpZ2h0Rm9ySW5wdXRBc1NtYWxsXG4gICAgICAgICAgOiBkZXNpZ25Ub2tlbnMuaGVpZ2h0Rm9ySW5wdXR9IC0gMiAqICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czF9XG4gICAgKTtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke2dldExhbmd1YWdlTGFiZWxCYWNrZ3JvdW5kQ29sb3IocHJvcHMpfTtcbiAgICBib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAke2Rlc2lnblRva2Vucy5ib3JkZXJSYWRpdXNGb3JJbnB1dH07XG4gICAgYm9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzRm9ySW5wdXR9O1xuICAgIGJvcmRlcjogMXB4ICR7Z2V0TGFuZ3VhZ2VMYWJlbEJvcmRlckNvbG9yKHByb3BzKX0gc29saWQ7XG4gICAgcGFkZGluZzogMCAke2Rlc2lnblRva2Vucy5zcGFjaW5nMjV9O1xuICAgIGZvbnQtc2l6ZTogJHtwcm9wcy5pc0NvbmRlbnNlZFxuICAgICAgPyBkZXNpZ25Ub2tlbnMuZm9udFNpemUyMFxuICAgICAgOiBkZXNpZ25Ub2tlbnMuZm9udFNpemUzMH07XG4gICAgdHJhbnNpdGlvbjogYm9yZGVyLWNvbG9yICR7ZGVzaWduVG9rZW5zLnRyYW5zaXRpb25TdGFuZGFyZH0sXG4gICAgICBiYWNrZ3JvdW5kLWNvbG9yICR7ZGVzaWduVG9rZW5zLnRyYW5zaXRpb25TdGFuZGFyZH0sXG4gICAgICBjb2xvciAke2Rlc2lnblRva2Vucy50cmFuc2l0aW9uU3RhbmRhcmR9O1xuICAgIGJvcmRlci1yaWdodDogMDtcbiAgICBib3gtc2hhZG93OiBub25lO1xuICAgIGFwcGVhcmFuY2U6IG5vbmU7XG4gIGA7XG59O1xuXG5jb25zdCBUb2dnbGVCdXR0b25XcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgZmxleDogMDtcbiAgZGlzcGxheTogZmxleDtcbmA7XG5cbmV4cG9ydCB7IGdldFRleHRhcmVhU3R5bGVzLCBnZXRMYW5ndWFnZUxhYmVsU3R5bGVzLCBUb2dnbGVCdXR0b25XcmFwcGVyIH07XG4iXX0= */",
50
+ styles: "border-top-left-radius:0!important;border-bottom-left-radius:0!important;label:baseStyles;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRyYW5zbGF0aW9uLWlucHV0LnN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFrQk8iLCJmaWxlIjoidHJhbnNsYXRpb24taW5wdXQuc3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5cbi8vIE5PVEU6IG9yZGVyIGlzIGltcG9ydGFudCBoZXJlXG4vLyAqIGEgZGlzYWJsZWQtZmllbGQgY3VycmVudGx5IGRvZXMgbm90IGRpc3BsYXkgd2FybmluZy9lcnJvci1zdGF0ZXMgc28gaXQgdGFrZXMgcHJlY2VkZW5jZVxuLy8gKiBhIHJlYWRvbmx5LWZpZWxkIGNhbm5vdCBiZSBjaGFuZ2VkLCBidXQgaXQgbWlnaHQgYmUgcmVsZXZhbnQgZm9yIHZhbGlkYXRpb24sIHNvIGVycm9yIGFuZCB3YXJuaW5nIGFyZSBjaGVja2VkIGZpcnN0XG4vLyBob3cgeW91IGNhbiBpbnRlcmFjdCB3aXRoIHRoZSBmaWVsZCBpcyBjb250cm9sbGVkIHNlcGFyYXRlbHkgYnkgdGhlIHByb3BzLCB0aGlzIG9ubHkgaW5mbHVlbmNlcyB2aXN1YWxzXG5cbnR5cGUgVFRyYW5zbGF0aW9uSW5wdXRTdHlsZXNQcm9wcyA9IHtcbiAgaXNDb2xsYXBzZWQ/OiBib29sZWFuO1xuICBpc0NvbmRlbnNlZD86IGJvb2xlYW47XG4gIGlzRGlzYWJsZWQ/OiBib29sZWFuO1xuICBpc1JlYWRPbmx5PzogYm9vbGVhbjtcbn07XG5cbmNvbnN0IGdldFRleHRhcmVhU3R5bGVzID0gKHByb3BzOiBUVHJhbnNsYXRpb25JbnB1dFN0eWxlc1Byb3BzKSA9PiB7XG4gIGNvbnN0IGJhc2VTdHlsZXMgPSBbXG4gICAgY3NzYFxuICAgICAgYm9yZGVyLXRvcC1sZWZ0LXJhZGl1czogMCAhaW1wb3J0YW50O1xuICAgICAgYm9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogMCAhaW1wb3J0YW50O1xuICAgIGAsXG4gICAgcHJvcHMuaXNDb2xsYXBzZWQgJiZcbiAgICAgIGNzc2BcbiAgICAgICAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgICAgIGAsXG4gIF07XG4gIHJldHVybiBiYXNlU3R5bGVzO1xufTtcblxuY29uc3QgZ2V0TGFuZ3VhZ2VMYWJlbEJhY2tncm91bmRDb2xvciA9IChcbiAgcHJvcHM6IFRUcmFuc2xhdGlvbklucHV0U3R5bGVzUHJvcHNcbikgPT4ge1xuICBpZiAocHJvcHMuaXNEaXNhYmxlZCkge1xuICAgIHJldHVybiBkZXNpZ25Ub2tlbnMuYmFja2dyb3VuZENvbG9yRm9yTG9jYWxpemVkSW5wdXRMYWJlbFdoZW5EaXNhYmxlZDtcbiAgfVxuICBpZiAocHJvcHMuaXNSZWFkT25seSkge1xuICAgIHJldHVybiBkZXNpZ25Ub2tlbnMuYmFja2dyb3VuZENvbG9yRm9yTG9jYWxpemVkSW5wdXRMYWJlbFdoZW5SZWFkb25seTtcbiAgfVxuICByZXR1cm4gZGVzaWduVG9rZW5zLmJhY2tncm91bmRDb2xvckZvckxvY2FsaXplZElucHV0TGFiZWw7XG59O1xuXG5jb25zdCBnZXRMYW5ndWFnZUxhYmVsQm9yZGVyQ29sb3IgPSAocHJvcHM6IFRUcmFuc2xhdGlvbklucHV0U3R5bGVzUHJvcHMpID0+IHtcbiAgaWYgKHByb3BzLmlzRGlzYWJsZWQpIHtcbiAgICByZXR1cm4gZGVzaWduVG9rZW5zLmJvcmRlckNvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWQ7XG4gIH1cbiAgcmV0dXJuIHByb3BzLmlzUmVhZE9ubHlcbiAgICA/IGRlc2lnblRva2Vucy5jb2xvclN1cmZhY2VcbiAgICA6IGRlc2lnblRva2Vucy5jb2xvck5ldXRyYWw7XG59O1xuXG5jb25zdCBnZXRMYW5ndWFnZUxhYmVsU3R5bGVzID0gKHByb3BzOiBUVHJhbnNsYXRpb25JbnB1dFN0eWxlc1Byb3BzKSA9PiB7XG4gIHJldHVybiBjc3NgXG4gICAgLyogYXZvaWQgd3JhcHBpbmcgbGFiZWwgb250byBuZXcgbGluZXMgKi9cbiAgICBmbGV4OiAxIDAgYXV0bztcbiAgICBjb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsNjB9O1xuICAgIGN1cnNvcjogJHtwcm9wcy5pc0Rpc2FibGVkID8gJ25vdC1hbGxvd2VkJyA6ICdkZWZhdWx0J307XG4gICAgbGluZS1oZWlnaHQ6IGNhbGMoXG4gICAgICAke3Byb3BzLmlzQ29uZGVuc2VkXG4gICAgICAgICAgPyBkZXNpZ25Ub2tlbnMuaGVpZ2h0Rm9ySW5wdXRBc1NtYWxsXG4gICAgICAgICAgOiBkZXNpZ25Ub2tlbnMuaGVpZ2h0Rm9ySW5wdXR9IC0gMiAqICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czF9XG4gICAgKTtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke2dldExhbmd1YWdlTGFiZWxCYWNrZ3JvdW5kQ29sb3IocHJvcHMpfTtcbiAgICBib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAke2Rlc2lnblRva2Vucy5ib3JkZXJSYWRpdXNGb3JJbnB1dH07XG4gICAgYm9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzRm9ySW5wdXR9O1xuICAgIGJvcmRlcjogMXB4ICR7Z2V0TGFuZ3VhZ2VMYWJlbEJvcmRlckNvbG9yKHByb3BzKX0gc29saWQ7XG4gICAgcGFkZGluZzogMCAke2Rlc2lnblRva2Vucy5zcGFjaW5nMjV9O1xuICAgIGZvbnQtc2l6ZTogJHtwcm9wcy5pc0NvbmRlbnNlZFxuICAgICAgPyBkZXNpZ25Ub2tlbnMuZm9udFNpemUyMFxuICAgICAgOiBkZXNpZ25Ub2tlbnMuZm9udFNpemUzMH07XG4gICAgdHJhbnNpdGlvbjogYm9yZGVyLWNvbG9yICR7ZGVzaWduVG9rZW5zLnRyYW5zaXRpb25TdGFuZGFyZH0sXG4gICAgICBiYWNrZ3JvdW5kLWNvbG9yICR7ZGVzaWduVG9rZW5zLnRyYW5zaXRpb25TdGFuZGFyZH0sXG4gICAgICBjb2xvciAke2Rlc2lnblRva2Vucy50cmFuc2l0aW9uU3RhbmRhcmR9O1xuICAgIGJvcmRlci1yaWdodDogMDtcbiAgICBib3gtc2hhZG93OiBub25lO1xuICAgIGFwcGVhcmFuY2U6IG5vbmU7XG4gIGA7XG59O1xuXG5jb25zdCBUb2dnbGVCdXR0b25XcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgZmxleDogMDtcbiAgZGlzcGxheTogZmxleDtcbmA7XG5cbmV4cG9ydCB7IGdldFRleHRhcmVhU3R5bGVzLCBnZXRMYW5ndWFnZUxhYmVsU3R5bGVzLCBUb2dnbGVCdXR0b25XcmFwcGVyIH07XG4iXX0= */",
53
51
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
54
52
  };
55
53
  const getTextareaStyles = props => {
@@ -84,8 +82,7 @@ const ToggleButtonWrapper = /*#__PURE__*/_styled("div", process.env.NODE_ENV ===
84
82
  styles: "flex:0;display:flex"
85
83
  } : {
86
84
  name: "ejz79s",
87
- styles: "flex:0;display:flex",
88
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRyYW5zbGF0aW9uLWlucHV0LnN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUErRXNDIiwiZmlsZSI6InRyYW5zbGF0aW9uLWlucHV0LnN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGRlc2lnblRva2VucyB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuXG4vLyBOT1RFOiBvcmRlciBpcyBpbXBvcnRhbnQgaGVyZVxuLy8gKiBhIGRpc2FibGVkLWZpZWxkIGN1cnJlbnRseSBkb2VzIG5vdCBkaXNwbGF5IHdhcm5pbmcvZXJyb3Itc3RhdGVzIHNvIGl0IHRha2VzIHByZWNlZGVuY2Vcbi8vICogYSByZWFkb25seS1maWVsZCBjYW5ub3QgYmUgY2hhbmdlZCwgYnV0IGl0IG1pZ2h0IGJlIHJlbGV2YW50IGZvciB2YWxpZGF0aW9uLCBzbyBlcnJvciBhbmQgd2FybmluZyBhcmUgY2hlY2tlZCBmaXJzdFxuLy8gaG93IHlvdSBjYW4gaW50ZXJhY3Qgd2l0aCB0aGUgZmllbGQgaXMgY29udHJvbGxlZCBzZXBhcmF0ZWx5IGJ5IHRoZSBwcm9wcywgdGhpcyBvbmx5IGluZmx1ZW5jZXMgdmlzdWFsc1xuXG50eXBlIFRUcmFuc2xhdGlvbklucHV0U3R5bGVzUHJvcHMgPSB7XG4gIGlzQ29sbGFwc2VkPzogYm9vbGVhbjtcbiAgaXNDb25kZW5zZWQ/OiBib29sZWFuO1xuICBpc0Rpc2FibGVkPzogYm9vbGVhbjtcbiAgaXNSZWFkT25seT86IGJvb2xlYW47XG59O1xuXG5jb25zdCBnZXRUZXh0YXJlYVN0eWxlcyA9IChwcm9wczogVFRyYW5zbGF0aW9uSW5wdXRTdHlsZXNQcm9wcykgPT4ge1xuICBjb25zdCBiYXNlU3R5bGVzID0gW1xuICAgIGNzc2BcbiAgICAgIGJvcmRlci10b3AtbGVmdC1yYWRpdXM6IDAgIWltcG9ydGFudDtcbiAgICAgIGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6IDAgIWltcG9ydGFudDtcbiAgICBgLFxuICAgIHByb3BzLmlzQ29sbGFwc2VkICYmXG4gICAgICBjc3NgXG4gICAgICAgIG92ZXJmbG93OiBoaWRkZW47XG4gICAgICBgLFxuICBdO1xuICByZXR1cm4gYmFzZVN0eWxlcztcbn07XG5cbmNvbnN0IGdldExhbmd1YWdlTGFiZWxCYWNrZ3JvdW5kQ29sb3IgPSAoXG4gIHByb3BzOiBUVHJhbnNsYXRpb25JbnB1dFN0eWxlc1Byb3BzXG4pID0+IHtcbiAgaWYgKHByb3BzLmlzRGlzYWJsZWQpIHtcbiAgICByZXR1cm4gZGVzaWduVG9rZW5zLmJhY2tncm91bmRDb2xvckZvckxvY2FsaXplZElucHV0TGFiZWxXaGVuRGlzYWJsZWQ7XG4gIH1cbiAgaWYgKHByb3BzLmlzUmVhZE9ubHkpIHtcbiAgICByZXR1cm4gZGVzaWduVG9rZW5zLmJhY2tncm91bmRDb2xvckZvckxvY2FsaXplZElucHV0TGFiZWxXaGVuUmVhZG9ubHk7XG4gIH1cbiAgcmV0dXJuIGRlc2lnblRva2Vucy5iYWNrZ3JvdW5kQ29sb3JGb3JMb2NhbGl6ZWRJbnB1dExhYmVsO1xufTtcblxuY29uc3QgZ2V0TGFuZ3VhZ2VMYWJlbEJvcmRlckNvbG9yID0gKHByb3BzOiBUVHJhbnNsYXRpb25JbnB1dFN0eWxlc1Byb3BzKSA9PiB7XG4gIGlmIChwcm9wcy5pc0Rpc2FibGVkKSB7XG4gICAgcmV0dXJuIGRlc2lnblRva2Vucy5ib3JkZXJDb2xvckZvcklucHV0V2hlbkRpc2FibGVkO1xuICB9XG4gIHJldHVybiBwcm9wcy5pc1JlYWRPbmx5XG4gICAgPyBkZXNpZ25Ub2tlbnMuY29sb3JTdXJmYWNlXG4gICAgOiBkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsO1xufTtcblxuY29uc3QgZ2V0TGFuZ3VhZ2VMYWJlbFN0eWxlcyA9IChwcm9wczogVFRyYW5zbGF0aW9uSW5wdXRTdHlsZXNQcm9wcykgPT4ge1xuICByZXR1cm4gY3NzYFxuICAgIC8qIGF2b2lkIHdyYXBwaW5nIGxhYmVsIG9udG8gbmV3IGxpbmVzICovXG4gICAgZmxleDogMSAwIGF1dG87XG4gICAgY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yTmV1dHJhbDYwfTtcbiAgICBjdXJzb3I6ICR7cHJvcHMuaXNEaXNhYmxlZCA/ICdub3QtYWxsb3dlZCcgOiAnZGVmYXVsdCd9O1xuICAgIGxpbmUtaGVpZ2h0OiBjYWxjKFxuICAgICAgJHtwcm9wcy5pc0NvbmRlbnNlZFxuICAgICAgICAgID8gZGVzaWduVG9rZW5zLmhlaWdodEZvcklucHV0QXNTbWFsbFxuICAgICAgICAgIDogZGVzaWduVG9rZW5zLmhlaWdodEZvcklucHV0fSAtIDIgKiAke2Rlc2lnblRva2Vucy5ib3JkZXJSYWRpdXMxfVxuICAgICk7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHtnZXRMYW5ndWFnZUxhYmVsQmFja2dyb3VuZENvbG9yKHByb3BzKX07XG4gICAgYm9yZGVyLXRvcC1sZWZ0LXJhZGl1czogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzRm9ySW5wdXR9O1xuICAgIGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6ICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1c0ZvcklucHV0fTtcbiAgICBib3JkZXI6IDFweCAke2dldExhbmd1YWdlTGFiZWxCb3JkZXJDb2xvcihwcm9wcyl9IHNvbGlkO1xuICAgIHBhZGRpbmc6IDAgJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzI1fTtcbiAgICBmb250LXNpemU6ICR7cHJvcHMuaXNDb25kZW5zZWRcbiAgICAgID8gZGVzaWduVG9rZW5zLmZvbnRTaXplMjBcbiAgICAgIDogZGVzaWduVG9rZW5zLmZvbnRTaXplMzB9O1xuICAgIHRyYW5zaXRpb246IGJvcmRlci1jb2xvciAke2Rlc2lnblRva2Vucy50cmFuc2l0aW9uU3RhbmRhcmR9LFxuICAgICAgYmFja2dyb3VuZC1jb2xvciAke2Rlc2lnblRva2Vucy50cmFuc2l0aW9uU3RhbmRhcmR9LFxuICAgICAgY29sb3IgJHtkZXNpZ25Ub2tlbnMudHJhbnNpdGlvblN0YW5kYXJkfTtcbiAgICBib3JkZXItcmlnaHQ6IDA7XG4gICAgYm94LXNoYWRvdzogbm9uZTtcbiAgICBhcHBlYXJhbmNlOiBub25lO1xuICBgO1xufTtcblxuY29uc3QgVG9nZ2xlQnV0dG9uV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIGZsZXg6IDA7XG4gIGRpc3BsYXk6IGZsZXg7XG5gO1xuXG5leHBvcnQgeyBnZXRUZXh0YXJlYVN0eWxlcywgZ2V0TGFuZ3VhZ2VMYWJlbFN0eWxlcywgVG9nZ2xlQnV0dG9uV3JhcHBlciB9O1xuIl19 */",
85
+ styles: "flex:0;display:flex/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRyYW5zbGF0aW9uLWlucHV0LnN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUErRXNDIiwiZmlsZSI6InRyYW5zbGF0aW9uLWlucHV0LnN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGRlc2lnblRva2VucyB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuXG4vLyBOT1RFOiBvcmRlciBpcyBpbXBvcnRhbnQgaGVyZVxuLy8gKiBhIGRpc2FibGVkLWZpZWxkIGN1cnJlbnRseSBkb2VzIG5vdCBkaXNwbGF5IHdhcm5pbmcvZXJyb3Itc3RhdGVzIHNvIGl0IHRha2VzIHByZWNlZGVuY2Vcbi8vICogYSByZWFkb25seS1maWVsZCBjYW5ub3QgYmUgY2hhbmdlZCwgYnV0IGl0IG1pZ2h0IGJlIHJlbGV2YW50IGZvciB2YWxpZGF0aW9uLCBzbyBlcnJvciBhbmQgd2FybmluZyBhcmUgY2hlY2tlZCBmaXJzdFxuLy8gaG93IHlvdSBjYW4gaW50ZXJhY3Qgd2l0aCB0aGUgZmllbGQgaXMgY29udHJvbGxlZCBzZXBhcmF0ZWx5IGJ5IHRoZSBwcm9wcywgdGhpcyBvbmx5IGluZmx1ZW5jZXMgdmlzdWFsc1xuXG50eXBlIFRUcmFuc2xhdGlvbklucHV0U3R5bGVzUHJvcHMgPSB7XG4gIGlzQ29sbGFwc2VkPzogYm9vbGVhbjtcbiAgaXNDb25kZW5zZWQ/OiBib29sZWFuO1xuICBpc0Rpc2FibGVkPzogYm9vbGVhbjtcbiAgaXNSZWFkT25seT86IGJvb2xlYW47XG59O1xuXG5jb25zdCBnZXRUZXh0YXJlYVN0eWxlcyA9IChwcm9wczogVFRyYW5zbGF0aW9uSW5wdXRTdHlsZXNQcm9wcykgPT4ge1xuICBjb25zdCBiYXNlU3R5bGVzID0gW1xuICAgIGNzc2BcbiAgICAgIGJvcmRlci10b3AtbGVmdC1yYWRpdXM6IDAgIWltcG9ydGFudDtcbiAgICAgIGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6IDAgIWltcG9ydGFudDtcbiAgICBgLFxuICAgIHByb3BzLmlzQ29sbGFwc2VkICYmXG4gICAgICBjc3NgXG4gICAgICAgIG92ZXJmbG93OiBoaWRkZW47XG4gICAgICBgLFxuICBdO1xuICByZXR1cm4gYmFzZVN0eWxlcztcbn07XG5cbmNvbnN0IGdldExhbmd1YWdlTGFiZWxCYWNrZ3JvdW5kQ29sb3IgPSAoXG4gIHByb3BzOiBUVHJhbnNsYXRpb25JbnB1dFN0eWxlc1Byb3BzXG4pID0+IHtcbiAgaWYgKHByb3BzLmlzRGlzYWJsZWQpIHtcbiAgICByZXR1cm4gZGVzaWduVG9rZW5zLmJhY2tncm91bmRDb2xvckZvckxvY2FsaXplZElucHV0TGFiZWxXaGVuRGlzYWJsZWQ7XG4gIH1cbiAgaWYgKHByb3BzLmlzUmVhZE9ubHkpIHtcbiAgICByZXR1cm4gZGVzaWduVG9rZW5zLmJhY2tncm91bmRDb2xvckZvckxvY2FsaXplZElucHV0TGFiZWxXaGVuUmVhZG9ubHk7XG4gIH1cbiAgcmV0dXJuIGRlc2lnblRva2Vucy5iYWNrZ3JvdW5kQ29sb3JGb3JMb2NhbGl6ZWRJbnB1dExhYmVsO1xufTtcblxuY29uc3QgZ2V0TGFuZ3VhZ2VMYWJlbEJvcmRlckNvbG9yID0gKHByb3BzOiBUVHJhbnNsYXRpb25JbnB1dFN0eWxlc1Byb3BzKSA9PiB7XG4gIGlmIChwcm9wcy5pc0Rpc2FibGVkKSB7XG4gICAgcmV0dXJuIGRlc2lnblRva2Vucy5ib3JkZXJDb2xvckZvcklucHV0V2hlbkRpc2FibGVkO1xuICB9XG4gIHJldHVybiBwcm9wcy5pc1JlYWRPbmx5XG4gICAgPyBkZXNpZ25Ub2tlbnMuY29sb3JTdXJmYWNlXG4gICAgOiBkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsO1xufTtcblxuY29uc3QgZ2V0TGFuZ3VhZ2VMYWJlbFN0eWxlcyA9IChwcm9wczogVFRyYW5zbGF0aW9uSW5wdXRTdHlsZXNQcm9wcykgPT4ge1xuICByZXR1cm4gY3NzYFxuICAgIC8qIGF2b2lkIHdyYXBwaW5nIGxhYmVsIG9udG8gbmV3IGxpbmVzICovXG4gICAgZmxleDogMSAwIGF1dG87XG4gICAgY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yTmV1dHJhbDYwfTtcbiAgICBjdXJzb3I6ICR7cHJvcHMuaXNEaXNhYmxlZCA/ICdub3QtYWxsb3dlZCcgOiAnZGVmYXVsdCd9O1xuICAgIGxpbmUtaGVpZ2h0OiBjYWxjKFxuICAgICAgJHtwcm9wcy5pc0NvbmRlbnNlZFxuICAgICAgICAgID8gZGVzaWduVG9rZW5zLmhlaWdodEZvcklucHV0QXNTbWFsbFxuICAgICAgICAgIDogZGVzaWduVG9rZW5zLmhlaWdodEZvcklucHV0fSAtIDIgKiAke2Rlc2lnblRva2Vucy5ib3JkZXJSYWRpdXMxfVxuICAgICk7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHtnZXRMYW5ndWFnZUxhYmVsQmFja2dyb3VuZENvbG9yKHByb3BzKX07XG4gICAgYm9yZGVyLXRvcC1sZWZ0LXJhZGl1czogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzRm9ySW5wdXR9O1xuICAgIGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6ICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1c0ZvcklucHV0fTtcbiAgICBib3JkZXI6IDFweCAke2dldExhbmd1YWdlTGFiZWxCb3JkZXJDb2xvcihwcm9wcyl9IHNvbGlkO1xuICAgIHBhZGRpbmc6IDAgJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzI1fTtcbiAgICBmb250LXNpemU6ICR7cHJvcHMuaXNDb25kZW5zZWRcbiAgICAgID8gZGVzaWduVG9rZW5zLmZvbnRTaXplMjBcbiAgICAgIDogZGVzaWduVG9rZW5zLmZvbnRTaXplMzB9O1xuICAgIHRyYW5zaXRpb246IGJvcmRlci1jb2xvciAke2Rlc2lnblRva2Vucy50cmFuc2l0aW9uU3RhbmRhcmR9LFxuICAgICAgYmFja2dyb3VuZC1jb2xvciAke2Rlc2lnblRva2Vucy50cmFuc2l0aW9uU3RhbmRhcmR9LFxuICAgICAgY29sb3IgJHtkZXNpZ25Ub2tlbnMudHJhbnNpdGlvblN0YW5kYXJkfTtcbiAgICBib3JkZXItcmlnaHQ6IDA7XG4gICAgYm94LXNoYWRvdzogbm9uZTtcbiAgICBhcHBlYXJhbmNlOiBub25lO1xuICBgO1xufTtcblxuY29uc3QgVG9nZ2xlQnV0dG9uV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIGZsZXg6IDA7XG4gIGRpc3BsYXk6IGZsZXg7XG5gO1xuXG5leHBvcnQgeyBnZXRUZXh0YXJlYVN0eWxlcywgZ2V0TGFuZ3VhZ2VMYWJlbFN0eWxlcywgVG9nZ2xlQnV0dG9uV3JhcHBlciB9O1xuIl19 */",
89
86
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
90
87
  });
91
88
 
@@ -103,8 +100,7 @@ const LeftColumn = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "product
103
100
  styles: "flex:1"
104
101
  } : {
105
102
  name: "82a6rk",
106
- styles: "flex:1",
107
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["translation-input.tsx"],"names":[],"mappings":"AAiF6B","file":"translation-input.tsx","sourcesContent":["import {\n  useState,\n  useCallback,\n  type ChangeEventHandler,\n  type FocusEventHandler,\n  type ReactNode,\n} from 'react';\nimport { MessageDescriptor } from 'react-intl';\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  AdditionalInfoMessage,\n  ErrorMessage,\n  WarningMessage,\n} from '@commercetools-uikit/messages';\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  additionalInfo?:\n    | string\n    | ReactNode\n    | (MessageDescriptor & {\n        values: Record<string, ReactNode>;\n      });\n  id?: string;\n  name?: string;\n  autoComplete?: string;\n  value: string;\n  onBlur?: FocusEventHandler<HTMLLocalizedTextAreaElement>;\n  isCondensed?: boolean;\n  isDisabled?: boolean;\n  placeholder?: string;\n  hasWarning?: boolean;\n  hasError?: boolean;\n  isReadOnly?: boolean;\n  isAutofocussed?: boolean;\n  cacheMeasurements?: 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 = ({\n  cacheMeasurements = true,\n  ...props\n}: TranslationInputProps) => {\n  const [inputHasSeveralRows, setInputHasSeveralRows] = useState(false);\n\n  const handleHeightChange = useCallback(\n    (_, rowCount) => {\n      // This checks if the content in the textarea is greater than one row. If it is, then the toggle button will be shown.\n      // This is to prevent the toggle button from showing when there is not enough content to expand/collapse.\n      setInputHasSeveralRows(rowCount > 1);\n    },\n    [setInputHasSeveralRows]\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  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 && inputHasSeveralRows && !props.hasLanguagesControl) ||\n    props.error ||\n    props.warning ||\n    (props.additionalInfo && !props.isCollapsed);\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          {props.language.toUpperCase()}\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          isCondensed={props.isCondensed}\n          isReadOnly={props.isReadOnly}\n          isAutofocussed={props.isAutofocussed}\n          cacheMeasurements={cacheMeasurements}\n          isOpen={!props.isCollapsed}\n          {...filterDataAttributes({\n            cacheMeasurements,\n            ...props,\n          })}\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 margin 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                <ErrorMessage>{props.error}</ErrorMessage>\n              </LeftColumn>\n            );\n          if (props.warning)\n            return (\n              <LeftColumn>\n                <WarningMessage>{props.warning}</WarningMessage>\n              </LeftColumn>\n            );\n          return null;\n        })()}\n        {!props.isCollapsed && inputHasSeveralRows && (\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      {props.additionalInfo && (\n        <Row>\n          <LeftColumn>\n            <AdditionalInfoMessage message={props.additionalInfo} />\n          </LeftColumn>\n        </Row>\n      )}\n    </Stack>\n  );\n};\n\nTranslationInput.displayName = 'TranslationInput';\n\nexport default TranslationInput;\n"]} */",
103
+ styles: "flex:1/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["translation-input.tsx"],"names":[],"mappings":"AAiF6B","file":"translation-input.tsx","sourcesContent":["import {\n  useState,\n  useCallback,\n  type ChangeEventHandler,\n  type FocusEventHandler,\n  type ReactNode,\n} from 'react';\nimport { MessageDescriptor } from 'react-intl';\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  AdditionalInfoMessage,\n  ErrorMessage,\n  WarningMessage,\n} from '@commercetools-uikit/messages';\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  additionalInfo?:\n    | string\n    | ReactNode\n    | (MessageDescriptor & {\n        values: Record<string, ReactNode>;\n      });\n  id?: string;\n  name?: string;\n  autoComplete?: string;\n  value: string;\n  onBlur?: FocusEventHandler<HTMLLocalizedTextAreaElement>;\n  isCondensed?: boolean;\n  isDisabled?: boolean;\n  placeholder?: string;\n  hasWarning?: boolean;\n  hasError?: boolean;\n  isReadOnly?: boolean;\n  isAutofocussed?: boolean;\n  cacheMeasurements?: 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 = ({\n  cacheMeasurements = true,\n  ...props\n}: TranslationInputProps) => {\n  const [inputHasSeveralRows, setInputHasSeveralRows] = useState(false);\n\n  const handleHeightChange = useCallback(\n    (_, rowCount) => {\n      // This checks if the content in the textarea is greater than one row. If it is, then the toggle button will be shown.\n      // This is to prevent the toggle button from showing when there is not enough content to expand/collapse.\n      setInputHasSeveralRows(rowCount > 1);\n    },\n    [setInputHasSeveralRows]\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  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 && inputHasSeveralRows && !props.hasLanguagesControl) ||\n    props.error ||\n    props.warning ||\n    (props.additionalInfo && !props.isCollapsed);\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          {props.language.toUpperCase()}\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          isCondensed={props.isCondensed}\n          isReadOnly={props.isReadOnly}\n          isAutofocussed={props.isAutofocussed}\n          cacheMeasurements={cacheMeasurements}\n          isOpen={!props.isCollapsed}\n          {...filterDataAttributes({\n            cacheMeasurements,\n            ...props,\n          })}\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 margin 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                <ErrorMessage>{props.error}</ErrorMessage>\n              </LeftColumn>\n            );\n          if (props.warning)\n            return (\n              <LeftColumn>\n                <WarningMessage>{props.warning}</WarningMessage>\n              </LeftColumn>\n            );\n          return null;\n        })()}\n        {!props.isCollapsed && inputHasSeveralRows && (\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      {props.additionalInfo && (\n        <Row>\n          <LeftColumn>\n            <AdditionalInfoMessage message={props.additionalInfo} />\n          </LeftColumn>\n        </Row>\n      )}\n    </Stack>\n  );\n};\n\nTranslationInput.displayName = 'TranslationInput';\n\nexport default TranslationInput;\n"]} */",
108
104
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
109
105
  });
110
106
  const RightColumn = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
@@ -117,8 +113,7 @@ const RightColumn = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "produc
117
113
  styles: "position:relative;flex:0;display:flex;align-items:flex-start"
118
114
  } : {
119
115
  name: "1m04uhl",
120
- styles: "position:relative;flex:0;display:flex;align-items:flex-start",
121
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["translation-input.tsx"],"names":[],"mappings":"AAqF8B","file":"translation-input.tsx","sourcesContent":["import {\n  useState,\n  useCallback,\n  type ChangeEventHandler,\n  type FocusEventHandler,\n  type ReactNode,\n} from 'react';\nimport { MessageDescriptor } from 'react-intl';\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  AdditionalInfoMessage,\n  ErrorMessage,\n  WarningMessage,\n} from '@commercetools-uikit/messages';\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  additionalInfo?:\n    | string\n    | ReactNode\n    | (MessageDescriptor & {\n        values: Record<string, ReactNode>;\n      });\n  id?: string;\n  name?: string;\n  autoComplete?: string;\n  value: string;\n  onBlur?: FocusEventHandler<HTMLLocalizedTextAreaElement>;\n  isCondensed?: boolean;\n  isDisabled?: boolean;\n  placeholder?: string;\n  hasWarning?: boolean;\n  hasError?: boolean;\n  isReadOnly?: boolean;\n  isAutofocussed?: boolean;\n  cacheMeasurements?: 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 = ({\n  cacheMeasurements = true,\n  ...props\n}: TranslationInputProps) => {\n  const [inputHasSeveralRows, setInputHasSeveralRows] = useState(false);\n\n  const handleHeightChange = useCallback(\n    (_, rowCount) => {\n      // This checks if the content in the textarea is greater than one row. If it is, then the toggle button will be shown.\n      // This is to prevent the toggle button from showing when there is not enough content to expand/collapse.\n      setInputHasSeveralRows(rowCount > 1);\n    },\n    [setInputHasSeveralRows]\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  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 && inputHasSeveralRows && !props.hasLanguagesControl) ||\n    props.error ||\n    props.warning ||\n    (props.additionalInfo && !props.isCollapsed);\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          {props.language.toUpperCase()}\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          isCondensed={props.isCondensed}\n          isReadOnly={props.isReadOnly}\n          isAutofocussed={props.isAutofocussed}\n          cacheMeasurements={cacheMeasurements}\n          isOpen={!props.isCollapsed}\n          {...filterDataAttributes({\n            cacheMeasurements,\n            ...props,\n          })}\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 margin 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                <ErrorMessage>{props.error}</ErrorMessage>\n              </LeftColumn>\n            );\n          if (props.warning)\n            return (\n              <LeftColumn>\n                <WarningMessage>{props.warning}</WarningMessage>\n              </LeftColumn>\n            );\n          return null;\n        })()}\n        {!props.isCollapsed && inputHasSeveralRows && (\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      {props.additionalInfo && (\n        <Row>\n          <LeftColumn>\n            <AdditionalInfoMessage message={props.additionalInfo} />\n          </LeftColumn>\n        </Row>\n      )}\n    </Stack>\n  );\n};\n\nTranslationInput.displayName = 'TranslationInput';\n\nexport default TranslationInput;\n"]} */",
116
+ styles: "position:relative;flex:0;display:flex;align-items:flex-start/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["translation-input.tsx"],"names":[],"mappings":"AAqF8B","file":"translation-input.tsx","sourcesContent":["import {\n  useState,\n  useCallback,\n  type ChangeEventHandler,\n  type FocusEventHandler,\n  type ReactNode,\n} from 'react';\nimport { MessageDescriptor } from 'react-intl';\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  AdditionalInfoMessage,\n  ErrorMessage,\n  WarningMessage,\n} from '@commercetools-uikit/messages';\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  additionalInfo?:\n    | string\n    | ReactNode\n    | (MessageDescriptor & {\n        values: Record<string, ReactNode>;\n      });\n  id?: string;\n  name?: string;\n  autoComplete?: string;\n  value: string;\n  onBlur?: FocusEventHandler<HTMLLocalizedTextAreaElement>;\n  isCondensed?: boolean;\n  isDisabled?: boolean;\n  placeholder?: string;\n  hasWarning?: boolean;\n  hasError?: boolean;\n  isReadOnly?: boolean;\n  isAutofocussed?: boolean;\n  cacheMeasurements?: 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 = ({\n  cacheMeasurements = true,\n  ...props\n}: TranslationInputProps) => {\n  const [inputHasSeveralRows, setInputHasSeveralRows] = useState(false);\n\n  const handleHeightChange = useCallback(\n    (_, rowCount) => {\n      // This checks if the content in the textarea is greater than one row. If it is, then the toggle button will be shown.\n      // This is to prevent the toggle button from showing when there is not enough content to expand/collapse.\n      setInputHasSeveralRows(rowCount > 1);\n    },\n    [setInputHasSeveralRows]\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  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 && inputHasSeveralRows && !props.hasLanguagesControl) ||\n    props.error ||\n    props.warning ||\n    (props.additionalInfo && !props.isCollapsed);\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          {props.language.toUpperCase()}\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          isCondensed={props.isCondensed}\n          isReadOnly={props.isReadOnly}\n          isAutofocussed={props.isAutofocussed}\n          cacheMeasurements={cacheMeasurements}\n          isOpen={!props.isCollapsed}\n          {...filterDataAttributes({\n            cacheMeasurements,\n            ...props,\n          })}\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 margin 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                <ErrorMessage>{props.error}</ErrorMessage>\n              </LeftColumn>\n            );\n          if (props.warning)\n            return (\n              <LeftColumn>\n                <WarningMessage>{props.warning}</WarningMessage>\n              </LeftColumn>\n            );\n          return null;\n        })()}\n        {!props.isCollapsed && inputHasSeveralRows && (\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      {props.additionalInfo && (\n        <Row>\n          <LeftColumn>\n            <AdditionalInfoMessage message={props.additionalInfo} />\n          </LeftColumn>\n        </Row>\n      )}\n    </Stack>\n  );\n};\n\nTranslationInput.displayName = 'TranslationInput';\n\nexport default TranslationInput;\n"]} */",
122
117
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
123
118
  });
124
119
  const Row = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
@@ -131,8 +126,7 @@ const Row = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ?
131
126
  styles: "display:flex;justify-content:flex-end"
132
127
  } : {
133
128
  name: "skgbeu",
134
- styles: "display:flex;justify-content:flex-end",
135
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["translation-input.tsx"],"names":[],"mappings":"AA4FsB","file":"translation-input.tsx","sourcesContent":["import {\n  useState,\n  useCallback,\n  type ChangeEventHandler,\n  type FocusEventHandler,\n  type ReactNode,\n} from 'react';\nimport { MessageDescriptor } from 'react-intl';\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  AdditionalInfoMessage,\n  ErrorMessage,\n  WarningMessage,\n} from '@commercetools-uikit/messages';\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  additionalInfo?:\n    | string\n    | ReactNode\n    | (MessageDescriptor & {\n        values: Record<string, ReactNode>;\n      });\n  id?: string;\n  name?: string;\n  autoComplete?: string;\n  value: string;\n  onBlur?: FocusEventHandler<HTMLLocalizedTextAreaElement>;\n  isCondensed?: boolean;\n  isDisabled?: boolean;\n  placeholder?: string;\n  hasWarning?: boolean;\n  hasError?: boolean;\n  isReadOnly?: boolean;\n  isAutofocussed?: boolean;\n  cacheMeasurements?: 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 = ({\n  cacheMeasurements = true,\n  ...props\n}: TranslationInputProps) => {\n  const [inputHasSeveralRows, setInputHasSeveralRows] = useState(false);\n\n  const handleHeightChange = useCallback(\n    (_, rowCount) => {\n      // This checks if the content in the textarea is greater than one row. If it is, then the toggle button will be shown.\n      // This is to prevent the toggle button from showing when there is not enough content to expand/collapse.\n      setInputHasSeveralRows(rowCount > 1);\n    },\n    [setInputHasSeveralRows]\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  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 && inputHasSeveralRows && !props.hasLanguagesControl) ||\n    props.error ||\n    props.warning ||\n    (props.additionalInfo && !props.isCollapsed);\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          {props.language.toUpperCase()}\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          isCondensed={props.isCondensed}\n          isReadOnly={props.isReadOnly}\n          isAutofocussed={props.isAutofocussed}\n          cacheMeasurements={cacheMeasurements}\n          isOpen={!props.isCollapsed}\n          {...filterDataAttributes({\n            cacheMeasurements,\n            ...props,\n          })}\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 margin 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                <ErrorMessage>{props.error}</ErrorMessage>\n              </LeftColumn>\n            );\n          if (props.warning)\n            return (\n              <LeftColumn>\n                <WarningMessage>{props.warning}</WarningMessage>\n              </LeftColumn>\n            );\n          return null;\n        })()}\n        {!props.isCollapsed && inputHasSeveralRows && (\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      {props.additionalInfo && (\n        <Row>\n          <LeftColumn>\n            <AdditionalInfoMessage message={props.additionalInfo} />\n          </LeftColumn>\n        </Row>\n      )}\n    </Stack>\n  );\n};\n\nTranslationInput.displayName = 'TranslationInput';\n\nexport default TranslationInput;\n"]} */",
129
+ styles: "display:flex;justify-content:flex-end/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["translation-input.tsx"],"names":[],"mappings":"AA4FsB","file":"translation-input.tsx","sourcesContent":["import {\n  useState,\n  useCallback,\n  type ChangeEventHandler,\n  type FocusEventHandler,\n  type ReactNode,\n} from 'react';\nimport { MessageDescriptor } from 'react-intl';\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  AdditionalInfoMessage,\n  ErrorMessage,\n  WarningMessage,\n} from '@commercetools-uikit/messages';\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  additionalInfo?:\n    | string\n    | ReactNode\n    | (MessageDescriptor & {\n        values: Record<string, ReactNode>;\n      });\n  id?: string;\n  name?: string;\n  autoComplete?: string;\n  value: string;\n  onBlur?: FocusEventHandler<HTMLLocalizedTextAreaElement>;\n  isCondensed?: boolean;\n  isDisabled?: boolean;\n  placeholder?: string;\n  hasWarning?: boolean;\n  hasError?: boolean;\n  isReadOnly?: boolean;\n  isAutofocussed?: boolean;\n  cacheMeasurements?: 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 = ({\n  cacheMeasurements = true,\n  ...props\n}: TranslationInputProps) => {\n  const [inputHasSeveralRows, setInputHasSeveralRows] = useState(false);\n\n  const handleHeightChange = useCallback(\n    (_, rowCount) => {\n      // This checks if the content in the textarea is greater than one row. If it is, then the toggle button will be shown.\n      // This is to prevent the toggle button from showing when there is not enough content to expand/collapse.\n      setInputHasSeveralRows(rowCount > 1);\n    },\n    [setInputHasSeveralRows]\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  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 && inputHasSeveralRows && !props.hasLanguagesControl) ||\n    props.error ||\n    props.warning ||\n    (props.additionalInfo && !props.isCollapsed);\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          {props.language.toUpperCase()}\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          isCondensed={props.isCondensed}\n          isReadOnly={props.isReadOnly}\n          isAutofocussed={props.isAutofocussed}\n          cacheMeasurements={cacheMeasurements}\n          isOpen={!props.isCollapsed}\n          {...filterDataAttributes({\n            cacheMeasurements,\n            ...props,\n          })}\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 margin 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                <ErrorMessage>{props.error}</ErrorMessage>\n              </LeftColumn>\n            );\n          if (props.warning)\n            return (\n              <LeftColumn>\n                <WarningMessage>{props.warning}</WarningMessage>\n              </LeftColumn>\n            );\n          return null;\n        })()}\n        {!props.isCollapsed && inputHasSeveralRows && (\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      {props.additionalInfo && (\n        <Row>\n          <LeftColumn>\n            <AdditionalInfoMessage message={props.additionalInfo} />\n          </LeftColumn>\n        </Row>\n      )}\n    </Stack>\n  );\n};\n\nTranslationInput.displayName = 'TranslationInput';\n\nexport default TranslationInput;\n"]} */",
136
130
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
137
131
  });
138
132
  var _ref = process.env.NODE_ENV === "production" ? {
@@ -140,8 +134,7 @@ var _ref = process.env.NODE_ENV === "production" ? {
140
134
  styles: "width:100%;position:relative;display:flex"
141
135
  } : {
142
136
  name: "1r0st9p-TranslationInput",
143
- styles: "width:100%;position:relative;display:flex;label:TranslationInput;",
144
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["translation-input.tsx"],"names":[],"mappings":"AAsKgB","file":"translation-input.tsx","sourcesContent":["import {\n  useState,\n  useCallback,\n  type ChangeEventHandler,\n  type FocusEventHandler,\n  type ReactNode,\n} from 'react';\nimport { MessageDescriptor } from 'react-intl';\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  AdditionalInfoMessage,\n  ErrorMessage,\n  WarningMessage,\n} from '@commercetools-uikit/messages';\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  additionalInfo?:\n    | string\n    | ReactNode\n    | (MessageDescriptor & {\n        values: Record<string, ReactNode>;\n      });\n  id?: string;\n  name?: string;\n  autoComplete?: string;\n  value: string;\n  onBlur?: FocusEventHandler<HTMLLocalizedTextAreaElement>;\n  isCondensed?: boolean;\n  isDisabled?: boolean;\n  placeholder?: string;\n  hasWarning?: boolean;\n  hasError?: boolean;\n  isReadOnly?: boolean;\n  isAutofocussed?: boolean;\n  cacheMeasurements?: 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 = ({\n  cacheMeasurements = true,\n  ...props\n}: TranslationInputProps) => {\n  const [inputHasSeveralRows, setInputHasSeveralRows] = useState(false);\n\n  const handleHeightChange = useCallback(\n    (_, rowCount) => {\n      // This checks if the content in the textarea is greater than one row. If it is, then the toggle button will be shown.\n      // This is to prevent the toggle button from showing when there is not enough content to expand/collapse.\n      setInputHasSeveralRows(rowCount > 1);\n    },\n    [setInputHasSeveralRows]\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  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 && inputHasSeveralRows && !props.hasLanguagesControl) ||\n    props.error ||\n    props.warning ||\n    (props.additionalInfo && !props.isCollapsed);\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          {props.language.toUpperCase()}\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          isCondensed={props.isCondensed}\n          isReadOnly={props.isReadOnly}\n          isAutofocussed={props.isAutofocussed}\n          cacheMeasurements={cacheMeasurements}\n          isOpen={!props.isCollapsed}\n          {...filterDataAttributes({\n            cacheMeasurements,\n            ...props,\n          })}\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 margin 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                <ErrorMessage>{props.error}</ErrorMessage>\n              </LeftColumn>\n            );\n          if (props.warning)\n            return (\n              <LeftColumn>\n                <WarningMessage>{props.warning}</WarningMessage>\n              </LeftColumn>\n            );\n          return null;\n        })()}\n        {!props.isCollapsed && inputHasSeveralRows && (\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      {props.additionalInfo && (\n        <Row>\n          <LeftColumn>\n            <AdditionalInfoMessage message={props.additionalInfo} />\n          </LeftColumn>\n        </Row>\n      )}\n    </Stack>\n  );\n};\n\nTranslationInput.displayName = 'TranslationInput';\n\nexport default TranslationInput;\n"]} */",
137
+ styles: "width:100%;position:relative;display:flex;label:TranslationInput;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["translation-input.tsx"],"names":[],"mappings":"AAsKgB","file":"translation-input.tsx","sourcesContent":["import {\n  useState,\n  useCallback,\n  type ChangeEventHandler,\n  type FocusEventHandler,\n  type ReactNode,\n} from 'react';\nimport { MessageDescriptor } from 'react-intl';\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  AdditionalInfoMessage,\n  ErrorMessage,\n  WarningMessage,\n} from '@commercetools-uikit/messages';\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  additionalInfo?:\n    | string\n    | ReactNode\n    | (MessageDescriptor & {\n        values: Record<string, ReactNode>;\n      });\n  id?: string;\n  name?: string;\n  autoComplete?: string;\n  value: string;\n  onBlur?: FocusEventHandler<HTMLLocalizedTextAreaElement>;\n  isCondensed?: boolean;\n  isDisabled?: boolean;\n  placeholder?: string;\n  hasWarning?: boolean;\n  hasError?: boolean;\n  isReadOnly?: boolean;\n  isAutofocussed?: boolean;\n  cacheMeasurements?: 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 = ({\n  cacheMeasurements = true,\n  ...props\n}: TranslationInputProps) => {\n  const [inputHasSeveralRows, setInputHasSeveralRows] = useState(false);\n\n  const handleHeightChange = useCallback(\n    (_, rowCount) => {\n      // This checks if the content in the textarea is greater than one row. If it is, then the toggle button will be shown.\n      // This is to prevent the toggle button from showing when there is not enough content to expand/collapse.\n      setInputHasSeveralRows(rowCount > 1);\n    },\n    [setInputHasSeveralRows]\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  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 && inputHasSeveralRows && !props.hasLanguagesControl) ||\n    props.error ||\n    props.warning ||\n    (props.additionalInfo && !props.isCollapsed);\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          {props.language.toUpperCase()}\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          isCondensed={props.isCondensed}\n          isReadOnly={props.isReadOnly}\n          isAutofocussed={props.isAutofocussed}\n          cacheMeasurements={cacheMeasurements}\n          isOpen={!props.isCollapsed}\n          {...filterDataAttributes({\n            cacheMeasurements,\n            ...props,\n          })}\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 margin 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                <ErrorMessage>{props.error}</ErrorMessage>\n              </LeftColumn>\n            );\n          if (props.warning)\n            return (\n              <LeftColumn>\n                <WarningMessage>{props.warning}</WarningMessage>\n              </LeftColumn>\n            );\n          return null;\n        })()}\n        {!props.isCollapsed && inputHasSeveralRows && (\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      {props.additionalInfo && (\n        <Row>\n          <LeftColumn>\n            <AdditionalInfoMessage message={props.additionalInfo} />\n          </LeftColumn>\n        </Row>\n      )}\n    </Stack>\n  );\n};\n\nTranslationInput.displayName = 'TranslationInput';\n\nexport default TranslationInput;\n"]} */",
145
138
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
146
139
  };
147
140
  const TranslationInput = _ref2 => {
@@ -483,6 +476,6 @@ LocalizedMultilineTextInput.isTouched = isTouched;
483
476
  var LocalizedMultilineTextInput$1 = LocalizedMultilineTextInput;
484
477
 
485
478
  // NOTE: This string will be replaced on build time with the package version.
486
- var version = "19.22.0";
479
+ var version = "19.22.2";
487
480
 
488
481
  export { LocalizedMultilineTextInput$1 as default, version };
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@commercetools-uikit/localized-multiline-text-input",
3
3
  "description": "A controlled text input component for localized multi-line strings with validation states.",
4
- "version": "19.22.0",
4
+ "version": "19.22.2",
5
5
  "bugs": "https://github.com/commercetools/ui-kit/issues",
6
6
  "repository": {
7
7
  "type": "git",
@@ -21,17 +21,17 @@
21
21
  "dependencies": {
22
22
  "@babel/runtime": "^7.20.13",
23
23
  "@babel/runtime-corejs3": "^7.20.13",
24
- "@commercetools-uikit/constraints": "19.22.0",
25
- "@commercetools-uikit/design-system": "19.22.0",
26
- "@commercetools-uikit/flat-button": "19.22.0",
27
- "@commercetools-uikit/hooks": "19.22.0",
28
- "@commercetools-uikit/icons": "19.22.0",
29
- "@commercetools-uikit/input-utils": "19.22.0",
30
- "@commercetools-uikit/localized-utils": "19.22.0",
31
- "@commercetools-uikit/messages": "19.22.0",
32
- "@commercetools-uikit/spacings-stack": "19.22.0",
33
- "@commercetools-uikit/text": "19.22.0",
34
- "@commercetools-uikit/utils": "19.22.0",
24
+ "@commercetools-uikit/constraints": "19.22.2",
25
+ "@commercetools-uikit/design-system": "19.22.2",
26
+ "@commercetools-uikit/flat-button": "19.22.2",
27
+ "@commercetools-uikit/hooks": "19.22.2",
28
+ "@commercetools-uikit/icons": "19.22.2",
29
+ "@commercetools-uikit/input-utils": "19.22.2",
30
+ "@commercetools-uikit/localized-utils": "19.22.2",
31
+ "@commercetools-uikit/messages": "19.22.2",
32
+ "@commercetools-uikit/spacings-stack": "19.22.2",
33
+ "@commercetools-uikit/text": "19.22.2",
34
+ "@commercetools-uikit/utils": "19.22.2",
35
35
  "@emotion/react": "^11.10.5",
36
36
  "@emotion/styled": "^11.10.5",
37
37
  "prop-types": "15.8.1",