@commercetools-uikit/localized-text-input 13.0.1 → 13.0.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.
- package/README.md +19 -19
- package/dist/commercetools-uikit-localized-text-input.cjs.d.ts +2 -0
- package/dist/commercetools-uikit-localized-text-input.cjs.dev.js +60 -138
- package/dist/commercetools-uikit-localized-text-input.cjs.prod.js +19 -13
- package/dist/commercetools-uikit-localized-text-input.esm.js +60 -136
- package/dist/declarations/src/index.d.ts +2 -0
- package/dist/declarations/src/localized-text-input.d.ts +50 -0
- package/dist/declarations/src/localized-text-input.styles.d.ts +4 -0
- package/dist/declarations/src/version.d.ts +2 -0
- package/package.json +12 -12
package/README.md
CHANGED
|
@@ -48,25 +48,25 @@ export default Example;
|
|
|
48
48
|
|
|
49
49
|
## Properties
|
|
50
50
|
|
|
51
|
-
| Props | Type
|
|
52
|
-
| ------------------------------- |
|
|
53
|
-
| `id` | `string`
|
|
54
|
-
| `name` | `string`
|
|
55
|
-
| `autoComplete` | `string`
|
|
56
|
-
| `value` | `
|
|
57
|
-
| `onChange` | `
|
|
58
|
-
| `selectedLanguage` | `string`
|
|
59
|
-
| `onBlur` | `
|
|
60
|
-
| `onFocus` | `
|
|
61
|
-
| `hideLanguageExpansionControls` | `
|
|
62
|
-
| `defaultExpandLanguages` | `
|
|
63
|
-
| `isAutofocussed` | `
|
|
64
|
-
| `isDisabled` | `
|
|
65
|
-
| `isReadOnly` | `
|
|
66
|
-
| `placeholder` | `
|
|
67
|
-
| `horizontalConstraint` | `
|
|
68
|
-
| `hasError` | `
|
|
69
|
-
| `errors` | `
|
|
51
|
+
| Props | Type | Required | Default | Description |
|
|
52
|
+
| ------------------------------- | ----------------------------------------------------------------------------------------------------------- | :------: | --------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
|
53
|
+
| `id` | `string` | | | |
|
|
54
|
+
| `name` | `string` | | | |
|
|
55
|
+
| `autoComplete` | `string` | | | |
|
|
56
|
+
| `value` | `Record` | ✅ | | then input doesn't accept a "languages" prop, instead all possible
languages have to exist (with empty or filled strings) on the value:
{ en: 'foo', de: '', es: '' } |
|
|
57
|
+
| `onChange` | `ChangeEventHandler` | | | Gets called when any input is changed. Is called with the change event of the changed input. |
|
|
58
|
+
| `selectedLanguage` | `string` | ✅ | | Specifies which language will be shown in case the `LocalizedTextInput` is collapsed. |
|
|
59
|
+
| `onBlur` | `FocusEventHandler` | | | Called when any field is blurred. Is called with the `event` of that field. |
|
|
60
|
+
| `onFocus` | `FocusEventHandler` | | | Called when any field is focussed. Is called with the `event` of that field. |
|
|
61
|
+
| `hideLanguageExpansionControls` | `boolean` | | | Will hide the language expansion controls when set to `true`. All languages will be shown when set to `true`. |
|
|
62
|
+
| `defaultExpandLanguages` | `boolean` | | | Controls whether one or all languages are visible by default |
|
|
63
|
+
| `isAutofocussed` | `boolean` | | | Focus the input field on initial render |
|
|
64
|
+
| `isDisabled` | `boolean` | | | Disables all input fields. |
|
|
65
|
+
| `isReadOnly` | `boolean` | | | Disables all input fields and shows them in read-only mode. |
|
|
66
|
+
| `placeholder` | `Record` | | | Placeholders for each language. Object of the same shape as `value`. |
|
|
67
|
+
| `horizontalConstraint` | `union`<br/>Possible values:<br/>`, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 'scale', 'auto'` | | `'scale'` | Horizontal size limit of the input fields. |
|
|
68
|
+
| `hasError` | `boolean` | | | Will apply the error state to each input without showing any error message. |
|
|
69
|
+
| `errors` | `Record` | | | Used to show errors underneath the inputs of specific currencies. Pass an object whose key is a currency and whose value is the error to show for that key. |
|
|
70
70
|
|
|
71
71
|
## `data-*` props
|
|
72
72
|
|
|
@@ -9,16 +9,12 @@ var _forEachInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/in
|
|
|
9
9
|
var _Object$getOwnPropertyDescriptors = require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptors');
|
|
10
10
|
var _Object$defineProperties = require('@babel/runtime-corejs3/core-js-stable/object/define-properties');
|
|
11
11
|
var _Object$defineProperty = require('@babel/runtime-corejs3/core-js-stable/object/define-property');
|
|
12
|
-
var _taggedTemplateLiteral = require('@babel/runtime-corejs3/helpers/taggedTemplateLiteral');
|
|
13
12
|
var _slicedToArray = require('@babel/runtime-corejs3/helpers/slicedToArray');
|
|
14
13
|
var _defineProperty = require('@babel/runtime-corejs3/helpers/defineProperty');
|
|
14
|
+
var _pt = require('prop-types');
|
|
15
15
|
var _Object$keys = require('@babel/runtime-corejs3/core-js-stable/object/keys');
|
|
16
16
|
var _mapInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/map');
|
|
17
|
-
var _concatInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/concat');
|
|
18
17
|
var react$1 = require('react');
|
|
19
|
-
var PropTypes = require('prop-types');
|
|
20
|
-
var requiredIf = require('react-required-if');
|
|
21
|
-
var commonTags = require('common-tags');
|
|
22
18
|
var reactIntl = require('react-intl');
|
|
23
19
|
var react = require('@emotion/react');
|
|
24
20
|
var hooks = require('@commercetools-uikit/hooks');
|
|
@@ -42,11 +38,9 @@ var _forEachInstanceProperty__default = /*#__PURE__*/_interopDefault(_forEachIns
|
|
|
42
38
|
var _Object$getOwnPropertyDescriptors__default = /*#__PURE__*/_interopDefault(_Object$getOwnPropertyDescriptors);
|
|
43
39
|
var _Object$defineProperties__default = /*#__PURE__*/_interopDefault(_Object$defineProperties);
|
|
44
40
|
var _Object$defineProperty__default = /*#__PURE__*/_interopDefault(_Object$defineProperty);
|
|
41
|
+
var _pt__default = /*#__PURE__*/_interopDefault(_pt);
|
|
45
42
|
var _Object$keys__default = /*#__PURE__*/_interopDefault(_Object$keys);
|
|
46
43
|
var _mapInstanceProperty__default = /*#__PURE__*/_interopDefault(_mapInstanceProperty);
|
|
47
|
-
var _concatInstanceProperty__default = /*#__PURE__*/_interopDefault(_concatInstanceProperty);
|
|
48
|
-
var PropTypes__default = /*#__PURE__*/_interopDefault(PropTypes);
|
|
49
|
-
var requiredIf__default = /*#__PURE__*/_interopDefault(requiredIf);
|
|
50
44
|
var Stack__default = /*#__PURE__*/_interopDefault(Stack);
|
|
51
45
|
var Constraints__default = /*#__PURE__*/_interopDefault(Constraints);
|
|
52
46
|
var Text__default = /*#__PURE__*/_interopDefault(Text);
|
|
@@ -67,7 +61,7 @@ var _ref$1 = process.env.NODE_ENV === "production" ? {
|
|
|
67
61
|
} : {
|
|
68
62
|
name: "bqcila-getLocalizedInputStyles",
|
|
69
63
|
styles: "border-top-left-radius:0;border-bottom-left-radius:0;border-style:solid;flex:auto;label:getLocalizedInputStyles;",
|
|
70
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
64
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImxvY2FsaXplZC10ZXh0LWlucHV0LnN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFXSyIsImZpbGUiOiJsb2NhbGl6ZWQtdGV4dC1pbnB1dC5zdHlsZXMudHMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjc3MsIHR5cGUgVGhlbWUgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQge1xuICBjdXN0b21Qcm9wZXJ0aWVzIGFzIHZhcnMsXG4gIGRlc2lnblRva2Vucyxcbn0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5cbi8vIE5PVEU6IG9yZGVyIGlzIGltcG9ydGFudCBoZXJlXG4vLyAqIGEgZGlzYWJsZWQtZmllbGQgY3VycmVudGx5IGRvZXMgbm90IGRpc3BsYXkgd2FybmluZy9lcnJvci1zdGF0ZXMgc28gaXQgdGFrZXMgcHJlY2VkZW5jZVxuLy8gKiBhIHJlYWRvbmx5LWZpZWxkIGNhbm5vdCBiZSBjaGFuZ2VkLCBidXQgaXQgbWlnaHQgYmUgcmVsZXZhbnQgZm9yIHZhbGlkYXRpb24sIHNvIGVycm9yIGFuZCB3YXJuaW5nIGFyZSBjaGVja2VkIGZpcnN0XG4vLyBob3cgeW91IGNhbiBpbnRlcmFjdCB3aXRoIHRoZSBmaWVsZCBpcyBjb250cm9sbGVkIHNlcGFyYXRlbHkgYnkgdGhlIHByb3BzLCB0aGlzIG9ubHkgaW5mbHVlbmNlcyB2aXN1YWxzXG5jb25zdCBnZXRMb2NhbGl6ZWRJbnB1dFN0eWxlcyA9ICgpID0+IFtcbiAgY3NzYFxuICAgIGJvcmRlci10b3AtbGVmdC1yYWRpdXM6IDA7XG4gICAgYm9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogMDtcbiAgICBib3JkZXItc3R5bGU6IHNvbGlkO1xuICAgIGZsZXg6IGF1dG87XG4gIGAsXG5dO1xuXG5jb25zdCBnZXRMYW5ndWFnZUxhYmVsU3R5bGVzID0gKF9wcm9wczogdW5rbm93biwgdGhlbWU6IFRoZW1lKSA9PiB7XG4gIGNvbnN0IG92ZXJ3cml0dGVuVmFycyA9IHtcbiAgICAuLi52YXJzLFxuICAgIC4uLnRoZW1lLFxuICB9O1xuXG4gIHJldHVybiBjc3NgXG4gICAgLyogYXZvaWQgd3JhcHBpbmcgbGFiZWwgb250byBuZXcgbGluZXMgKi9cbiAgICBmbGV4OiAxIDAgYXV0bztcbiAgICBib3gtc2l6aW5nOiBib3JkZXItYm94O1xuICAgIGNvbG9yOiAke292ZXJ3cml0dGVuVmFyc1tkZXNpZ25Ub2tlbnMuZm9udENvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWRdfTtcbiAgICBoZWlnaHQ6ICR7dmFycy5zaXplSGVpZ2h0SW5wdXR9O1xuICAgIGxpbmUtaGVpZ2h0OiAke3ZhcnMuc2l6ZUhlaWdodElucHV0fTtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke292ZXJ3cml0dGVuVmFyc1tcbiAgICAgIGRlc2lnblRva2Vucy5iYWNrZ3JvdW5kQ29sb3JGb3JJbnB1dFdoZW5EaXNhYmxlZFxuICAgIF19O1xuICAgIGJvcmRlci10b3AtbGVmdC1yYWRpdXM6ICR7b3ZlcndyaXR0ZW5WYXJzW1xuICAgICAgZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1c0ZvcklucHV0XG4gICAgXX07XG4gICAgYm9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogJHtvdmVyd3JpdHRlblZhcnNbXG4gICAgICBkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzRm9ySW5wdXRcbiAgICBdfTtcbiAgICBib3JkZXI6IDFweCAke292ZXJ3cml0dGVuVmFyc1tkZXNpZ25Ub2tlbnMuYm9yZGVyQ29sb3JGb3JJbnB1dFdoZW5EaXNhYmxlZF19XG4gICAgICBzb2xpZDtcbiAgICBwYWRkaW5nOiAwICR7dmFycy5zcGFjaW5nU307XG4gICAgdHJhbnNpdGlvbjogYm9yZGVyLWNvbG9yICR7dmFycy50cmFuc2l0aW9uU3RhbmRhcmR9LFxuICAgICAgYmFja2dyb3VuZC1jb2xvciAke3ZhcnMudHJhbnNpdGlvblN0YW5kYXJkfSxcbiAgICAgIGNvbG9yICR7dmFycy50cmFuc2l0aW9uU3RhbmRhcmR9O1xuICAgIGJvcmRlci1yaWdodDogMDtcbiAgICBib3gtc2hhZG93OiBub25lO1xuICAgIGFwcGVhcmFuY2U6IG5vbmU7XG4gIGA7XG59O1xuXG5leHBvcnQgeyBnZXRMb2NhbGl6ZWRJbnB1dFN0eWxlcywgZ2V0TGFuZ3VhZ2VMYWJlbFN0eWxlcyB9O1xuIl19 */",
|
|
71
65
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
|
|
72
66
|
};
|
|
73
67
|
|
|
@@ -75,17 +69,15 @@ var getLocalizedInputStyles = function getLocalizedInputStyles() {
|
|
|
75
69
|
return [_ref$1];
|
|
76
70
|
};
|
|
77
71
|
|
|
78
|
-
var getLanguageLabelStyles = function getLanguageLabelStyles(
|
|
72
|
+
var getLanguageLabelStyles = function getLanguageLabelStyles(_props, theme) {
|
|
79
73
|
var overwrittenVars = _objectSpread$1(_objectSpread$1({}, designSystem.customProperties), theme);
|
|
80
74
|
|
|
81
|
-
return /*#__PURE__*/react.css("flex:1 0 auto;box-sizing:border-box;color:", overwrittenVars[designSystem.designTokens.fontColorForInputWhenDisabled], ";height:", designSystem.customProperties.sizeHeightInput, ";line-height:", designSystem.customProperties.sizeHeightInput, ";background-color:", overwrittenVars[designSystem.designTokens.backgroundColorForInputWhenDisabled], ";border-top-left-radius:", overwrittenVars[designSystem.designTokens.borderRadiusForInput], ";border-bottom-left-radius:", overwrittenVars[designSystem.designTokens.borderRadiusForInput], ";border:1px ", overwrittenVars[designSystem.designTokens.borderColorForInputWhenDisabled], " solid;padding:0 ", designSystem.customProperties.spacingS, ";transition:border-color ", designSystem.customProperties.transitionStandard, ",background-color ", designSystem.customProperties.transitionStandard, ",color ", designSystem.customProperties.transitionStandard, ";border-right:0;box-shadow:none;appearance:none;" + (process.env.NODE_ENV === "production" ? "" : ";label:getLanguageLabelStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
75
|
+
return /*#__PURE__*/react.css("flex:1 0 auto;box-sizing:border-box;color:", overwrittenVars[designSystem.designTokens.fontColorForInputWhenDisabled], ";height:", designSystem.customProperties.sizeHeightInput, ";line-height:", designSystem.customProperties.sizeHeightInput, ";background-color:", overwrittenVars[designSystem.designTokens.backgroundColorForInputWhenDisabled], ";border-top-left-radius:", overwrittenVars[designSystem.designTokens.borderRadiusForInput], ";border-bottom-left-radius:", overwrittenVars[designSystem.designTokens.borderRadiusForInput], ";border:1px ", overwrittenVars[designSystem.designTokens.borderColorForInputWhenDisabled], " solid;padding:0 ", designSystem.customProperties.spacingS, ";transition:border-color ", designSystem.customProperties.transitionStandard, ",background-color ", designSystem.customProperties.transitionStandard, ",color ", designSystem.customProperties.transitionStandard, ";border-right:0;box-shadow:none;appearance:none;" + (process.env.NODE_ENV === "production" ? "" : ";label:getLanguageLabelStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImxvY2FsaXplZC10ZXh0LWlucHV0LnN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF5QlkiLCJmaWxlIjoibG9jYWxpemVkLXRleHQtaW5wdXQuc3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzLCB0eXBlIFRoZW1lIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHtcbiAgY3VzdG9tUHJvcGVydGllcyBhcyB2YXJzLFxuICBkZXNpZ25Ub2tlbnMsXG59IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuXG4vLyBOT1RFOiBvcmRlciBpcyBpbXBvcnRhbnQgaGVyZVxuLy8gKiBhIGRpc2FibGVkLWZpZWxkIGN1cnJlbnRseSBkb2VzIG5vdCBkaXNwbGF5IHdhcm5pbmcvZXJyb3Itc3RhdGVzIHNvIGl0IHRha2VzIHByZWNlZGVuY2Vcbi8vICogYSByZWFkb25seS1maWVsZCBjYW5ub3QgYmUgY2hhbmdlZCwgYnV0IGl0IG1pZ2h0IGJlIHJlbGV2YW50IGZvciB2YWxpZGF0aW9uLCBzbyBlcnJvciBhbmQgd2FybmluZyBhcmUgY2hlY2tlZCBmaXJzdFxuLy8gaG93IHlvdSBjYW4gaW50ZXJhY3Qgd2l0aCB0aGUgZmllbGQgaXMgY29udHJvbGxlZCBzZXBhcmF0ZWx5IGJ5IHRoZSBwcm9wcywgdGhpcyBvbmx5IGluZmx1ZW5jZXMgdmlzdWFsc1xuY29uc3QgZ2V0TG9jYWxpemVkSW5wdXRTdHlsZXMgPSAoKSA9PiBbXG4gIGNzc2BcbiAgICBib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAwO1xuICAgIGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6IDA7XG4gICAgYm9yZGVyLXN0eWxlOiBzb2xpZDtcbiAgICBmbGV4OiBhdXRvO1xuICBgLFxuXTtcblxuY29uc3QgZ2V0TGFuZ3VhZ2VMYWJlbFN0eWxlcyA9IChfcHJvcHM6IHVua25vd24sIHRoZW1lOiBUaGVtZSkgPT4ge1xuICBjb25zdCBvdmVyd3JpdHRlblZhcnMgPSB7XG4gICAgLi4udmFycyxcbiAgICAuLi50aGVtZSxcbiAgfTtcblxuICByZXR1cm4gY3NzYFxuICAgIC8qIGF2b2lkIHdyYXBwaW5nIGxhYmVsIG9udG8gbmV3IGxpbmVzICovXG4gICAgZmxleDogMSAwIGF1dG87XG4gICAgYm94LXNpemluZzogYm9yZGVyLWJveDtcbiAgICBjb2xvcjogJHtvdmVyd3JpdHRlblZhcnNbZGVzaWduVG9rZW5zLmZvbnRDb2xvckZvcklucHV0V2hlbkRpc2FibGVkXX07XG4gICAgaGVpZ2h0OiAke3ZhcnMuc2l6ZUhlaWdodElucHV0fTtcbiAgICBsaW5lLWhlaWdodDogJHt2YXJzLnNpemVIZWlnaHRJbnB1dH07XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHtvdmVyd3JpdHRlblZhcnNbXG4gICAgICBkZXNpZ25Ub2tlbnMuYmFja2dyb3VuZENvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWRcbiAgICBdfTtcbiAgICBib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAke292ZXJ3cml0dGVuVmFyc1tcbiAgICAgIGRlc2lnblRva2Vucy5ib3JkZXJSYWRpdXNGb3JJbnB1dFxuICAgIF19O1xuICAgIGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6ICR7b3ZlcndyaXR0ZW5WYXJzW1xuICAgICAgZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1c0ZvcklucHV0XG4gICAgXX07XG4gICAgYm9yZGVyOiAxcHggJHtvdmVyd3JpdHRlblZhcnNbZGVzaWduVG9rZW5zLmJvcmRlckNvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWRdfVxuICAgICAgc29saWQ7XG4gICAgcGFkZGluZzogMCAke3ZhcnMuc3BhY2luZ1N9O1xuICAgIHRyYW5zaXRpb246IGJvcmRlci1jb2xvciAke3ZhcnMudHJhbnNpdGlvblN0YW5kYXJkfSxcbiAgICAgIGJhY2tncm91bmQtY29sb3IgJHt2YXJzLnRyYW5zaXRpb25TdGFuZGFyZH0sXG4gICAgICBjb2xvciAke3ZhcnMudHJhbnNpdGlvblN0YW5kYXJkfTtcbiAgICBib3JkZXItcmlnaHQ6IDA7XG4gICAgYm94LXNoYWRvdzogbm9uZTtcbiAgICBhcHBlYXJhbmNlOiBub25lO1xuICBgO1xufTtcblxuZXhwb3J0IHsgZ2V0TG9jYWxpemVkSW5wdXRTdHlsZXMsIGdldExhbmd1YWdlTGFiZWxTdHlsZXMgfTtcbiJdfQ== */");
|
|
82
76
|
};
|
|
83
77
|
|
|
84
|
-
var _templateObject;
|
|
85
|
-
|
|
86
78
|
function ownKeys(object, enumerableOnly) { var keys = _Object$keys__default["default"](object); if (_Object$getOwnPropertySymbols__default["default"]) { var symbols = _Object$getOwnPropertySymbols__default["default"](object); enumerableOnly && (symbols = _filterInstanceProperty__default["default"](symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor__default["default"](object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
87
79
|
|
|
88
|
-
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var
|
|
80
|
+
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var _context, _context2; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty__default["default"](_context = ownKeys(Object(source), !0)).call(_context, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](target, _Object$getOwnPropertyDescriptors__default["default"](source)) : _forEachInstanceProperty__default["default"](_context2 = ownKeys(Object(source))).call(_context2, function (key) { _Object$defineProperty__default["default"](target, key, _Object$getOwnPropertyDescriptor__default["default"](source, key)); }); } return target; }
|
|
89
81
|
|
|
90
82
|
function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
91
83
|
var sequentialId = utils.createSequentialId('localized-text-input-');
|
|
@@ -96,7 +88,7 @@ var _ref = process.env.NODE_ENV === "production" ? {
|
|
|
96
88
|
} : {
|
|
97
89
|
name: "1ysn02y-LocalizedInput",
|
|
98
90
|
styles: "width:100%;position:relative;display:flex;label:LocalizedInput;",
|
|
99
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["localized-text-input.js"],"names":[],"mappings":"AA6Dc","file":"localized-text-input.js","sourcesContent":["import { useCallback } from 'react';\nimport PropTypes from 'prop-types';\nimport requiredIf from 'react-required-if';\nimport { oneLine } from 'common-tags';\nimport { FormattedMessage } from 'react-intl';\nimport { css, useTheme } from '@emotion/react';\nimport { useFieldId, useToggleState } from '@commercetools-uikit/hooks';\nimport { ErrorMessage } from '@commercetools-uikit/messages';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport Constraints from '@commercetools-uikit/constraints';\nimport Text from '@commercetools-uikit/text';\nimport {\n  sortLanguages,\n  createLocalizedDataAttributes,\n  getHasErrorOnRemainingLanguages,\n  isTouched,\n  omitEmptyTranslations,\n  isEmpty,\n  createLocalizedString,\n  getId,\n  getName,\n} from '@commercetools-uikit/localized-utils';\nimport { createSequentialId } from '@commercetools-uikit/utils';\nimport TextInput from '@commercetools-uikit/text-input';\nimport {\n  LocalizedInputToggle,\n  messagesLocalizedInput,\n} from '@commercetools-uikit/input-utils';\nimport {\n  getLocalizedInputStyles,\n  getLanguageLabelStyles,\n} from './localized-text-input.styles';\n\nconst sequentialId = createSequentialId('localized-text-input-');\n\nconst LocalizedInput = (props) => {\n  const { onChange } = props;\n  const handleChange = useCallback(\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      //\n      // eslint-disable-next-line no-param-reassign\n      event.target.language = props.language;\n      onChange(event);\n    },\n    [props.language, onChange]\n  );\n  const theme = useTheme();\n\n  return (\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, theme)}>\n        {/* FIXME: add proper tone for disabled when tones are refactored */}\n        <Text.Detail tone=\"secondary\">\n          {props.language.toUpperCase()}\n        </Text.Detail>\n      </label>\n      <TextInput\n        {...props}\n        onChange={handleChange}\n        css={getLocalizedInputStyles}\n      />\n    </div>\n  );\n};\n\nLocalizedInput.displayName = 'LocalizedInput';\nLocalizedInput.propTypes = {\n  /**\n   * Used as prefix of HTML `id` property. Each input field id will have the language as a suffix (`${idPrefix}.${lang}`), e.g. `foo.en`. You can use the static `LocalizedTextInput.getId(idPrefix, language)` to create this id string, e.g. for labels.\n   */\n  id: PropTypes.string,\n  /**\n   * Used as HTML `name` property for each input field. Each input field name will have the language as a suffix (`${namePrefix}.${lang}`), e.g. `foo.en`\n   */\n  name: PropTypes.string,\n  /**\n   * Used as HTML `autocomplete` property\n   */\n  autoComplete: PropTypes.string,\n  value: PropTypes.string.isRequired,\n  /**\n   * Gets called when any input is changed. Is called with the change event of the changed input.\n   */\n  onChange: requiredIf(PropTypes.func, (props) => !props.isReadOnly),\n  language: PropTypes.string.isRequired,\n  onBlur: PropTypes.func,\n  onFocus: PropTypes.func,\n  isAutofocussed: PropTypes.bool,\n  isDisabled: PropTypes.bool,\n  isReadOnly: PropTypes.bool,\n  hasError: PropTypes.bool,\n  placeholder: PropTypes.string,\n};\n\nconst RequiredValueErrorMessage = () => (\n  <ErrorMessage>\n    <FormattedMessage {...messagesLocalizedInput.missingRequiredField} />\n  </ErrorMessage>\n);\n\nRequiredValueErrorMessage.displayName = 'RequiredValueErrorMessage';\n\nconst LocalizedTextInput = (props) => {\n  const defaultExpansionState =\n    props.hideLanguageExpansionControls ||\n    props.defaultExpandLanguages || // default to `false`, because useToggleState defaults to `true`\n    false;\n\n  const [areLanguagesExpanded, toggleLanguages] = useToggleState(\n    defaultExpansionState\n  );\n\n  const languages = sortLanguages(\n    props.selectedLanguage,\n    Object.keys(props.value)\n  );\n\n  const id = useFieldId(props.id, sequentialId);\n\n  const hasErrorInRemainingLanguages =\n    props.hasError ||\n    getHasErrorOnRemainingLanguages(props.errors, props.selectedLanguage);\n\n  if (hasErrorInRemainingLanguages) {\n    // this update within render replaces the old `getDerivedStateFromProps` functionality\n    // https://reactjs.org/docs/hooks-faq.html#how-do-i-implement-getderivedstatefromprops\n    if (hasErrorInRemainingLanguages !== areLanguagesExpanded) {\n      toggleLanguages();\n    }\n  }\n\n  const shouldRenderLanguagesButton =\n    languages.length > 1 && !props.hideLanguageExpansionControls;\n\n  return (\n    <Constraints.Horizontal max={props.horizontalConstraint}>\n      <Stack scale=\"xs\">\n        <Stack>\n          {languages.map((language, index) => {\n            const isFirstLanguage = index === 0;\n            if (!isFirstLanguage && !areLanguagesExpanded) return null;\n\n            return (\n              <div key={language}>\n                <Stack scale=\"xs\">\n                  <LocalizedInput\n                    autoComplete={props.autoComplete}\n                    id={LocalizedTextInput.getId(id, language)}\n                    name={LocalizedTextInput.getName(props.name, language)}\n                    value={props.value[language]}\n                    onChange={props.onChange}\n                    language={language}\n                    placeholder={\n                      props.placeholder\n                        ? props.placeholder[language]\n                        : undefined\n                    }\n                    onBlur={props.onBlur}\n                    onFocus={props.onFocus}\n                    isAutofocussed={index === 0 && props.isAutofocussed}\n                    isDisabled={props.isDisabled}\n                    isReadOnly={props.isReadOnly}\n                    hasError={Boolean(\n                      props.hasError || (props.errors && props.errors[language])\n                    )}\n                    {...createLocalizedDataAttributes(props, language)}\n                  />\n                  {props.errors && props.errors[language]}\n                </Stack>\n              </div>\n            );\n          })}\n        </Stack>\n        {shouldRenderLanguagesButton && (\n          <LocalizedInputToggle\n            isOpen={areLanguagesExpanded}\n            onClick={toggleLanguages}\n            isDisabled={areLanguagesExpanded && hasErrorInRemainingLanguages}\n            remainingLocalizations={languages.length - 1}\n          />\n        )}\n      </Stack>\n    </Constraints.Horizontal>\n  );\n};\n\nLocalizedTextInput.displayName = 'LocalizedTextInput';\n\nLocalizedTextInput.RequiredValueErrorMessage = RequiredValueErrorMessage;\n\nLocalizedTextInput.propTypes = {\n  id: PropTypes.string,\n  name: PropTypes.string,\n  autoComplete: PropTypes.string,\n  // then input doesn't accept a \"languages\" prop, instead all possible\n  // languages have to exist (with empty or filled strings) on the value:\n  //   { en: 'foo', de: '', es: '' }\n  value: PropTypes.objectOf(PropTypes.string).isRequired,\n  /**\n   * Gets called when any input is changed. Is called with the change event of the changed input.\n   */\n  onChange: requiredIf(PropTypes.func, (props) => !props.isReadOnly),\n  /**\n   * Specifies which language will be shown in case the `LocalizedTextInput` is collapsed.\n   */\n  selectedLanguage: PropTypes.string.isRequired,\n  /**\n   * Called when any field is blurred. Is called with the `event` of that field.\n   */\n  onBlur: PropTypes.func,\n  /**\n   * Called when any field is focussed. Is called with the `event` of that field.\n   */\n  onFocus: PropTypes.func,\n  /**\n   * Will hide the language expansion controls when set to `true`. All languages will be shown when set to `true`.\n   */\n  hideLanguageExpansionControls: PropTypes.bool,\n  /**\n   * Controls whether one or all languages are visible by default\n   */\n  defaultExpandLanguages: (props, propName, componentName, ...rest) => {\n    if (\n      props.hideLanguageExpansionControls &&\n      typeof props[propName] === 'boolean'\n    ) {\n      throw new Error(\n        oneLine`\n          ${componentName}: \"${propName}\" does not have any effect when\n          \"hideLanguageExpansionControls\" is set.\n        `\n      );\n    }\n    return PropTypes.bool(props, propName, componentName, ...rest);\n  },\n  /**\n   * Focus the input field on initial render\n   */\n  isAutofocussed: PropTypes.bool,\n  /**\n   * Disables all input fields.\n   */\n  isDisabled: PropTypes.bool,\n  /**\n   * Disables all input fields and shows them in read-only mode.\n   */\n  isReadOnly: PropTypes.bool,\n  /**\n   * Placeholders for each language. Object of the same shape as `value`.\n   */\n  placeholder: PropTypes.objectOf(PropTypes.string),\n  /**\n   * Horizontal size limit of the input fields.\n   */\n  horizontalConstraint: PropTypes.oneOf([\n    1,\n    2,\n    3,\n    4,\n    5,\n    6,\n    7,\n    8,\n    9,\n    10,\n    11,\n    12,\n    13,\n    14,\n    15,\n    16,\n    'scale',\n    'auto',\n  ]),\n  /**\n   * Will apply the error state to each input without showing any error message.\n   */\n  hasError: PropTypes.bool,\n  /**\n   * Used to show errors underneath the inputs of specific currencies. Pass an object whose key is a currency and whose value is the error to show for that key.\n   */\n  errors: PropTypes.objectOf(PropTypes.node),\n};\n\nLocalizedTextInput.defaultProps = {\n  horizontalConstraint: 'scale',\n};\n\nLocalizedTextInput.getId = getId;\n\nLocalizedTextInput.getName = getName;\n\nLocalizedTextInput.createLocalizedString = createLocalizedString;\n\nLocalizedTextInput.isEmpty = isEmpty;\n\nLocalizedTextInput.omitEmptyTranslations = omitEmptyTranslations;\n\nLocalizedTextInput.isTouched = isTouched;\n\nexport default LocalizedTextInput;\n"]} */",
|
|
91
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["localized-text-input.tsx"],"names":[],"mappings":"AAkLc","file":"localized-text-input.tsx","sourcesContent":["import {\n  type FocusEventHandler,\n  type ChangeEventHandler,\n  useCallback,\n} from 'react';\nimport { FormattedMessage } from 'react-intl';\nimport { css, useTheme } from '@emotion/react';\nimport { useFieldId, useToggleState } from '@commercetools-uikit/hooks';\nimport { ErrorMessage } from '@commercetools-uikit/messages';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport Constraints from '@commercetools-uikit/constraints';\nimport Text from '@commercetools-uikit/text';\nimport {\n  sortLanguages,\n  createLocalizedDataAttributes,\n  getHasErrorOnRemainingLanguages,\n  isTouched,\n  omitEmptyTranslations,\n  isEmpty,\n  createLocalizedString,\n  getId,\n  getName,\n} from '@commercetools-uikit/localized-utils';\nimport { createSequentialId, warning } from '@commercetools-uikit/utils';\nimport TextInput from '@commercetools-uikit/text-input';\nimport {\n  LocalizedInputToggle,\n  messagesLocalizedInput,\n} from '@commercetools-uikit/input-utils';\nimport {\n  getLocalizedInputStyles,\n  getLanguageLabelStyles,\n} from './localized-text-input.styles';\n\ntype TLocalizedTextInputProps = {\n  id?: string;\n  name?: string;\n  autoComplete?: string;\n  /**\n   *   then input doesn't accept a \"languages\" prop, instead all possible\n  languages have to exist (with empty or filled strings) on the value:\n    { en: 'foo', de: '', es: '' }\n   */\n  value: Record<string, string>;\n  /**\n   * Gets called when any input is changed. Is called with the change event of the changed input.\n   */\n  onChange?: ChangeEventHandler;\n  /**\n   * Specifies which language will be shown in case the `LocalizedTextInput` is collapsed.\n   */\n  selectedLanguage: string;\n  /**\n   * Called when any field is blurred. Is called with the `event` of that field.\n   */\n  onBlur?: FocusEventHandler;\n  /**\n   * Called when any field is focussed. Is called with the `event` of that field.\n   */\n  onFocus?: FocusEventHandler;\n  /**\n   * Will hide the language expansion controls when set to `true`. All languages will be shown when set to `true`.\n   */\n  hideLanguageExpansionControls?: boolean;\n  /**\n   * Controls whether one or all languages are visible by default\n   */\n  defaultExpandLanguages?: boolean;\n  /**\n   * Focus the input field on initial render\n   */\n  isAutofocussed?: boolean;\n  /**\n   * Disables all input fields.\n   */\n  isDisabled?: boolean;\n  /**\n   * Disables all input fields and shows them in read-only mode.\n   */\n  isReadOnly?: boolean;\n  /**\n   * Placeholders for each language. Object of the same shape as `value`.\n   */\n  placeholder?: Record<string, string>;\n  /**\n   * Horizontal size limit of the input fields.\n   */\n  horizontalConstraint?:\n    | 1\n    | 2\n    | 3\n    | 4\n    | 5\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n  /**\n   * Will apply the error state to each input without showing any error message.\n   */\n  hasError?: boolean;\n  /**\n   * Used to show errors underneath the inputs of specific currencies. Pass an object whose key is a currency and whose value is the error to show for that key.\n   */\n  errors?: Record<string, string>;\n};\n\ntype TLocalizedInputProps = {\n  /**\n   * Used as prefix of HTML `id` property. Each input field id will have the language as a suffix (`${idPrefix}.${lang}`), e.g. `foo.en`. You can use the static `LocalizedTextInput.getId(idPrefix, language)` to create this id string, e.g. for labels.\n   */\n  id?: string;\n  /**\n   * Used as HTML `name` property for each input field. Each input field name will have the language as a suffix (`${namePrefix}.${lang}`), e.g. `foo.en`\n   */\n  name?: string;\n  /**\n   * Used as HTML `autocomplete` property\n   */\n  autoComplete?: string;\n  value: string;\n  /**\n   * Gets called when any input is changed. Is called with the change event of the changed input.\n   */\n  onChange?: ChangeEventHandler;\n  language: string;\n  onBlur?: FocusEventHandler;\n  onFocus?: FocusEventHandler;\n  isAutofocussed?: boolean;\n  isDisabled?: boolean;\n  isReadOnly?: boolean;\n  hasError?: boolean;\n  placeholder?: string;\n};\n\nconst sequentialId = createSequentialId('localized-text-input-');\n\nconst LocalizedInput = (props: TLocalizedInputProps) => {\n  const { onChange } = props;\n  const handleChange = useCallback(\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      //\n      event.target.language = props.language;\n      onChange?.(event);\n    },\n    [props.language, onChange]\n  );\n  const theme = useTheme();\n\n  if (!props.isReadOnly) {\n    warning(\n      typeof props.onChange === 'function',\n      'LocaliszedTextInput: \"onChange\" is required when isReadOnly is not true'\n    );\n  }\n\n  return (\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, theme)}>\n        {/* FIXME: add proper tone for disabled when tones are refactored */}\n        <Text.Detail tone=\"secondary\">\n          {props.language.toUpperCase()}\n        </Text.Detail>\n      </label>\n      <TextInput\n        {...props}\n        onChange={handleChange}\n        css={getLocalizedInputStyles}\n      />\n    </div>\n  );\n};\n\nLocalizedInput.displayName = 'LocalizedInput';\n\nconst RequiredValueErrorMessage = () => (\n  <ErrorMessage>\n    <FormattedMessage {...messagesLocalizedInput.missingRequiredField} />\n  </ErrorMessage>\n);\n\nRequiredValueErrorMessage.displayName = 'RequiredValueErrorMessage';\n\nconst LocalizedTextInput = (props: TLocalizedTextInputProps) => {\n  const defaultExpansionState =\n    props.hideLanguageExpansionControls ||\n    props.defaultExpandLanguages || // default to `false`, because useToggleState defaults to `true`\n    false;\n\n  const [areLanguagesExpanded, toggleLanguages] = useToggleState(\n    defaultExpansionState\n  );\n\n  const onLocalizedInputToggle = useCallback(\n    () => toggleLanguages(),\n    [toggleLanguages]\n  );\n\n  const languages = sortLanguages(\n    props.selectedLanguage,\n    Object.keys(props.value)\n  );\n\n  const id = useFieldId(props.id, sequentialId);\n\n  const hasErrorInRemainingLanguages =\n    props.hasError ||\n    getHasErrorOnRemainingLanguages(props.errors, props.selectedLanguage);\n\n  if (hasErrorInRemainingLanguages) {\n    // this update within render replaces the old `getDerivedStateFromProps` functionality\n    // https://reactjs.org/docs/hooks-faq.html#how-do-i-implement-getderivedstatefromprops\n    if (hasErrorInRemainingLanguages !== areLanguagesExpanded) {\n      toggleLanguages();\n    }\n  }\n\n  const shouldRenderLanguagesButton =\n    languages.length > 1 && !props.hideLanguageExpansionControls;\n\n  if (!props.isReadOnly) {\n    warning(\n      typeof props.onChange === 'function',\n      'LocalizedTextInput: \"onChange\" is required when isReadOnly is not true'\n    );\n  }\n\n  if (props.hideLanguageExpansionControls) {\n    warning(\n      typeof props.defaultExpandLanguages !== 'boolean',\n      'LocalizedTextInput: \"defaultExpandLanguages\" does not have any effect when \"hideLanguageExpansionControls\" is set.'\n    );\n  }\n\n  return (\n    <Constraints.Horizontal max={props.horizontalConstraint}>\n      <Stack scale=\"xs\">\n        <Stack>\n          {languages.map((language, index) => {\n            const isFirstLanguage = index === 0;\n            if (!isFirstLanguage && !areLanguagesExpanded) return null;\n\n            return (\n              <div key={language}>\n                <Stack scale=\"xs\">\n                  <LocalizedInput\n                    autoComplete={props.autoComplete}\n                    id={LocalizedTextInput.getId(id, language)}\n                    name={LocalizedTextInput.getName(props.name, language)}\n                    value={props.value[language]}\n                    onChange={props.onChange}\n                    language={language}\n                    placeholder={\n                      props.placeholder\n                        ? props.placeholder[language]\n                        : undefined\n                    }\n                    onBlur={props.onBlur}\n                    onFocus={props.onFocus}\n                    isAutofocussed={index === 0 && props.isAutofocussed}\n                    isDisabled={props.isDisabled}\n                    isReadOnly={props.isReadOnly}\n                    hasError={Boolean(\n                      props.hasError || (props.errors && props.errors[language])\n                    )}\n                    {...createLocalizedDataAttributes(props, language)}\n                  />\n                  {props.errors && props.errors[language]}\n                </Stack>\n              </div>\n            );\n          })}\n        </Stack>\n        {shouldRenderLanguagesButton && (\n          <LocalizedInputToggle\n            isOpen={areLanguagesExpanded}\n            onClick={onLocalizedInputToggle}\n            isDisabled={areLanguagesExpanded && hasErrorInRemainingLanguages}\n            remainingLocalizations={languages.length - 1}\n          />\n        )}\n      </Stack>\n    </Constraints.Horizontal>\n  );\n};\n\nLocalizedTextInput.displayName = 'LocalizedTextInput';\n\nLocalizedTextInput.RequiredValueErrorMessage = RequiredValueErrorMessage;\n\nLocalizedTextInput.defaultProps = {\n  horizontalConstraint: 'scale',\n};\n\nLocalizedTextInput.getId = getId;\n\nLocalizedTextInput.getName = getName;\n\nLocalizedTextInput.createLocalizedString = createLocalizedString;\n\nLocalizedTextInput.isEmpty = isEmpty;\n\nLocalizedTextInput.omitEmptyTranslations = omitEmptyTranslations;\n\nLocalizedTextInput.isTouched = isTouched;\n\nexport default LocalizedTextInput;\n"]} */",
|
|
100
92
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
101
93
|
};
|
|
102
94
|
|
|
@@ -114,11 +106,15 @@ var LocalizedInput = function LocalizedInput(props) {
|
|
|
114
106
|
// might clear it using the knob, and then we can't parse the language from
|
|
115
107
|
// the input name anymore.
|
|
116
108
|
//
|
|
117
|
-
// eslint-disable-next-line no-param-reassign
|
|
118
109
|
event.target.language = props.language;
|
|
119
|
-
onChange(event);
|
|
110
|
+
onChange === null || onChange === void 0 ? void 0 : onChange(event);
|
|
120
111
|
}, [props.language, onChange]);
|
|
121
112
|
var theme = react.useTheme();
|
|
113
|
+
|
|
114
|
+
if (!props.isReadOnly) {
|
|
115
|
+
process.env.NODE_ENV !== "production" ? utils.warning(typeof props.onChange === 'function', 'LocaliszedTextInput: "onChange" is required when isReadOnly is not true') : void 0;
|
|
116
|
+
}
|
|
117
|
+
|
|
122
118
|
return jsxRuntime.jsxs("div", {
|
|
123
119
|
css: _ref,
|
|
124
120
|
children: [jsxRuntime.jsx("label", {
|
|
@@ -135,39 +131,22 @@ var LocalizedInput = function LocalizedInput(props) {
|
|
|
135
131
|
}, props.language);
|
|
136
132
|
};
|
|
137
133
|
|
|
138
|
-
LocalizedInput.displayName = 'LocalizedInput';
|
|
139
134
|
LocalizedInput.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
autoComplete: PropTypes__default["default"].string,
|
|
154
|
-
value: PropTypes__default["default"].string.isRequired,
|
|
155
|
-
|
|
156
|
-
/**
|
|
157
|
-
* Gets called when any input is changed. Is called with the change event of the changed input.
|
|
158
|
-
*/
|
|
159
|
-
onChange: requiredIf__default["default"](PropTypes__default["default"].func, function (props) {
|
|
160
|
-
return !props.isReadOnly;
|
|
161
|
-
}),
|
|
162
|
-
language: PropTypes__default["default"].string.isRequired,
|
|
163
|
-
onBlur: PropTypes__default["default"].func,
|
|
164
|
-
onFocus: PropTypes__default["default"].func,
|
|
165
|
-
isAutofocussed: PropTypes__default["default"].bool,
|
|
166
|
-
isDisabled: PropTypes__default["default"].bool,
|
|
167
|
-
isReadOnly: PropTypes__default["default"].bool,
|
|
168
|
-
hasError: PropTypes__default["default"].bool,
|
|
169
|
-
placeholder: PropTypes__default["default"].string
|
|
135
|
+
id: _pt__default["default"].string,
|
|
136
|
+
name: _pt__default["default"].string,
|
|
137
|
+
autoComplete: _pt__default["default"].string,
|
|
138
|
+
value: _pt__default["default"].string.isRequired,
|
|
139
|
+
onChange: _pt__default["default"].func,
|
|
140
|
+
language: _pt__default["default"].string.isRequired,
|
|
141
|
+
onBlur: _pt__default["default"].func,
|
|
142
|
+
onFocus: _pt__default["default"].func,
|
|
143
|
+
isAutofocussed: _pt__default["default"].bool,
|
|
144
|
+
isDisabled: _pt__default["default"].bool,
|
|
145
|
+
isReadOnly: _pt__default["default"].bool,
|
|
146
|
+
hasError: _pt__default["default"].bool,
|
|
147
|
+
placeholder: _pt__default["default"].string
|
|
170
148
|
} : {};
|
|
149
|
+
LocalizedInput.displayName = 'LocalizedInput';
|
|
171
150
|
|
|
172
151
|
var RequiredValueErrorMessage = function RequiredValueErrorMessage() {
|
|
173
152
|
return jsxRuntime.jsx(messages.ErrorMessage, {
|
|
@@ -186,6 +165,9 @@ var LocalizedTextInput = function LocalizedTextInput(props) {
|
|
|
186
165
|
areLanguagesExpanded = _useToggleState2[0],
|
|
187
166
|
toggleLanguages = _useToggleState2[1];
|
|
188
167
|
|
|
168
|
+
var onLocalizedInputToggle = react$1.useCallback(function () {
|
|
169
|
+
return toggleLanguages();
|
|
170
|
+
}, [toggleLanguages]);
|
|
189
171
|
var languages = localizedUtils.sortLanguages(props.selectedLanguage, _Object$keys__default["default"](props.value));
|
|
190
172
|
var id = hooks.useFieldId(props.id, sequentialId);
|
|
191
173
|
var hasErrorInRemainingLanguages = props.hasError || localizedUtils.getHasErrorOnRemainingLanguages(props.errors, props.selectedLanguage);
|
|
@@ -199,6 +181,15 @@ var LocalizedTextInput = function LocalizedTextInput(props) {
|
|
|
199
181
|
}
|
|
200
182
|
|
|
201
183
|
var shouldRenderLanguagesButton = languages.length > 1 && !props.hideLanguageExpansionControls;
|
|
184
|
+
|
|
185
|
+
if (!props.isReadOnly) {
|
|
186
|
+
process.env.NODE_ENV !== "production" ? utils.warning(typeof props.onChange === 'function', 'LocalizedTextInput: "onChange" is required when isReadOnly is not true') : void 0;
|
|
187
|
+
}
|
|
188
|
+
|
|
189
|
+
if (props.hideLanguageExpansionControls) {
|
|
190
|
+
process.env.NODE_ENV !== "production" ? utils.warning(typeof props.defaultExpandLanguages !== 'boolean', 'LocalizedTextInput: "defaultExpandLanguages" does not have any effect when "hideLanguageExpansionControls" is set.') : void 0;
|
|
191
|
+
}
|
|
192
|
+
|
|
202
193
|
return jsxRuntime.jsx(Constraints__default["default"].Horizontal, {
|
|
203
194
|
max: props.horizontalConstraint,
|
|
204
195
|
children: jsxRuntime.jsxs(Stack__default["default"], {
|
|
@@ -230,7 +221,7 @@ var LocalizedTextInput = function LocalizedTextInput(props) {
|
|
|
230
221
|
})
|
|
231
222
|
}), shouldRenderLanguagesButton && jsxRuntime.jsx(inputUtils.LocalizedInputToggle, {
|
|
232
223
|
isOpen: areLanguagesExpanded,
|
|
233
|
-
onClick:
|
|
224
|
+
onClick: onLocalizedInputToggle,
|
|
234
225
|
isDisabled: areLanguagesExpanded && hasErrorInRemainingLanguages,
|
|
235
226
|
remainingLocalizations: languages.length - 1
|
|
236
227
|
})]
|
|
@@ -238,96 +229,27 @@ var LocalizedTextInput = function LocalizedTextInput(props) {
|
|
|
238
229
|
});
|
|
239
230
|
};
|
|
240
231
|
|
|
241
|
-
LocalizedTextInput.displayName = 'LocalizedTextInput';
|
|
242
|
-
LocalizedTextInput.RequiredValueErrorMessage = RequiredValueErrorMessage;
|
|
243
232
|
LocalizedTextInput.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
244
|
-
id:
|
|
245
|
-
name:
|
|
246
|
-
autoComplete:
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
*/
|
|
262
|
-
selectedLanguage: PropTypes__default["default"].string.isRequired,
|
|
263
|
-
|
|
264
|
-
/**
|
|
265
|
-
* Called when any field is blurred. Is called with the `event` of that field.
|
|
266
|
-
*/
|
|
267
|
-
onBlur: PropTypes__default["default"].func,
|
|
268
|
-
|
|
269
|
-
/**
|
|
270
|
-
* Called when any field is focussed. Is called with the `event` of that field.
|
|
271
|
-
*/
|
|
272
|
-
onFocus: PropTypes__default["default"].func,
|
|
273
|
-
|
|
274
|
-
/**
|
|
275
|
-
* Will hide the language expansion controls when set to `true`. All languages will be shown when set to `true`.
|
|
276
|
-
*/
|
|
277
|
-
hideLanguageExpansionControls: PropTypes__default["default"].bool,
|
|
278
|
-
|
|
279
|
-
/**
|
|
280
|
-
* Controls whether one or all languages are visible by default
|
|
281
|
-
*/
|
|
282
|
-
defaultExpandLanguages: function defaultExpandLanguages(props, propName, componentName) {
|
|
283
|
-
var _context;
|
|
284
|
-
|
|
285
|
-
if (props.hideLanguageExpansionControls && typeof props[propName] === 'boolean') {
|
|
286
|
-
throw new Error(commonTags.oneLine(_templateObject || (_templateObject = _taggedTemplateLiteral(["\n ", ": \"", "\" does not have any effect when\n \"hideLanguageExpansionControls\" is set.\n "])), componentName, propName));
|
|
287
|
-
}
|
|
288
|
-
|
|
289
|
-
for (var _len = arguments.length, rest = new Array(_len > 3 ? _len - 3 : 0), _key = 3; _key < _len; _key++) {
|
|
290
|
-
rest[_key - 3] = arguments[_key];
|
|
291
|
-
}
|
|
292
|
-
|
|
293
|
-
return PropTypes__default["default"].bool.apply(PropTypes__default["default"], _concatInstanceProperty__default["default"](_context = [props, propName, componentName]).call(_context, rest));
|
|
294
|
-
},
|
|
295
|
-
|
|
296
|
-
/**
|
|
297
|
-
* Focus the input field on initial render
|
|
298
|
-
*/
|
|
299
|
-
isAutofocussed: PropTypes__default["default"].bool,
|
|
300
|
-
|
|
301
|
-
/**
|
|
302
|
-
* Disables all input fields.
|
|
303
|
-
*/
|
|
304
|
-
isDisabled: PropTypes__default["default"].bool,
|
|
305
|
-
|
|
306
|
-
/**
|
|
307
|
-
* Disables all input fields and shows them in read-only mode.
|
|
308
|
-
*/
|
|
309
|
-
isReadOnly: PropTypes__default["default"].bool,
|
|
310
|
-
|
|
311
|
-
/**
|
|
312
|
-
* Placeholders for each language. Object of the same shape as `value`.
|
|
313
|
-
*/
|
|
314
|
-
placeholder: PropTypes__default["default"].objectOf(PropTypes__default["default"].string),
|
|
315
|
-
|
|
316
|
-
/**
|
|
317
|
-
* Horizontal size limit of the input fields.
|
|
318
|
-
*/
|
|
319
|
-
horizontalConstraint: PropTypes__default["default"].oneOf([1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 'scale', 'auto']),
|
|
320
|
-
|
|
321
|
-
/**
|
|
322
|
-
* Will apply the error state to each input without showing any error message.
|
|
323
|
-
*/
|
|
324
|
-
hasError: PropTypes__default["default"].bool,
|
|
325
|
-
|
|
326
|
-
/**
|
|
327
|
-
* Used to show errors underneath the inputs of specific currencies. Pass an object whose key is a currency and whose value is the error to show for that key.
|
|
328
|
-
*/
|
|
329
|
-
errors: PropTypes__default["default"].objectOf(PropTypes__default["default"].node)
|
|
233
|
+
id: _pt__default["default"].string,
|
|
234
|
+
name: _pt__default["default"].string,
|
|
235
|
+
autoComplete: _pt__default["default"].string,
|
|
236
|
+
value: _pt__default["default"].objectOf(_pt__default["default"].string).isRequired,
|
|
237
|
+
onChange: _pt__default["default"].func,
|
|
238
|
+
selectedLanguage: _pt__default["default"].string.isRequired,
|
|
239
|
+
onBlur: _pt__default["default"].func,
|
|
240
|
+
onFocus: _pt__default["default"].func,
|
|
241
|
+
hideLanguageExpansionControls: _pt__default["default"].bool,
|
|
242
|
+
defaultExpandLanguages: _pt__default["default"].bool,
|
|
243
|
+
isAutofocussed: _pt__default["default"].bool,
|
|
244
|
+
isDisabled: _pt__default["default"].bool,
|
|
245
|
+
isReadOnly: _pt__default["default"].bool,
|
|
246
|
+
placeholder: _pt__default["default"].objectOf(_pt__default["default"].string),
|
|
247
|
+
horizontalConstraint: _pt__default["default"].oneOf([1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 'scale', 'auto']),
|
|
248
|
+
hasError: _pt__default["default"].bool,
|
|
249
|
+
errors: _pt__default["default"].objectOf(_pt__default["default"].string)
|
|
330
250
|
} : {};
|
|
251
|
+
LocalizedTextInput.displayName = 'LocalizedTextInput';
|
|
252
|
+
LocalizedTextInput.RequiredValueErrorMessage = RequiredValueErrorMessage;
|
|
331
253
|
LocalizedTextInput.defaultProps = {
|
|
332
254
|
horizontalConstraint: 'scale'
|
|
333
255
|
};
|
|
@@ -340,7 +262,7 @@ LocalizedTextInput.isTouched = localizedUtils.isTouched;
|
|
|
340
262
|
var LocalizedTextInput$1 = LocalizedTextInput;
|
|
341
263
|
|
|
342
264
|
// NOTE: This string will be replaced on build time with the package version.
|
|
343
|
-
var version = "13.0.
|
|
265
|
+
var version = "13.0.2";
|
|
344
266
|
|
|
345
267
|
exports["default"] = LocalizedTextInput$1;
|
|
346
268
|
exports.version = version;
|
|
@@ -9,16 +9,12 @@ var _forEachInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/in
|
|
|
9
9
|
var _Object$getOwnPropertyDescriptors = require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptors');
|
|
10
10
|
var _Object$defineProperties = require('@babel/runtime-corejs3/core-js-stable/object/define-properties');
|
|
11
11
|
var _Object$defineProperty = require('@babel/runtime-corejs3/core-js-stable/object/define-property');
|
|
12
|
-
require('@babel/runtime-corejs3/helpers/taggedTemplateLiteral');
|
|
13
12
|
var _slicedToArray = require('@babel/runtime-corejs3/helpers/slicedToArray');
|
|
14
13
|
var _defineProperty = require('@babel/runtime-corejs3/helpers/defineProperty');
|
|
14
|
+
require('prop-types');
|
|
15
15
|
var _Object$keys = require('@babel/runtime-corejs3/core-js-stable/object/keys');
|
|
16
16
|
var _mapInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/map');
|
|
17
|
-
require('@babel/runtime-corejs3/core-js-stable/instance/concat');
|
|
18
17
|
var react$1 = require('react');
|
|
19
|
-
require('prop-types');
|
|
20
|
-
require('react-required-if');
|
|
21
|
-
require('common-tags');
|
|
22
18
|
var reactIntl = require('react-intl');
|
|
23
19
|
var react = require('@emotion/react');
|
|
24
20
|
var hooks = require('@commercetools-uikit/hooks');
|
|
@@ -65,7 +61,7 @@ var getLocalizedInputStyles = function getLocalizedInputStyles() {
|
|
|
65
61
|
return [_ref$1];
|
|
66
62
|
};
|
|
67
63
|
|
|
68
|
-
var getLanguageLabelStyles = function getLanguageLabelStyles(
|
|
64
|
+
var getLanguageLabelStyles = function getLanguageLabelStyles(_props, theme) {
|
|
69
65
|
var overwrittenVars = _objectSpread$1(_objectSpread$1({}, designSystem.customProperties), theme);
|
|
70
66
|
|
|
71
67
|
return /*#__PURE__*/react.css("flex:1 0 auto;box-sizing:border-box;color:", overwrittenVars[designSystem.designTokens.fontColorForInputWhenDisabled], ";height:", designSystem.customProperties.sizeHeightInput, ";line-height:", designSystem.customProperties.sizeHeightInput, ";background-color:", overwrittenVars[designSystem.designTokens.backgroundColorForInputWhenDisabled], ";border-top-left-radius:", overwrittenVars[designSystem.designTokens.borderRadiusForInput], ";border-bottom-left-radius:", overwrittenVars[designSystem.designTokens.borderRadiusForInput], ";border:1px ", overwrittenVars[designSystem.designTokens.borderColorForInputWhenDisabled], " solid;padding:0 ", designSystem.customProperties.spacingS, ";transition:border-color ", designSystem.customProperties.transitionStandard, ",background-color ", designSystem.customProperties.transitionStandard, ",color ", designSystem.customProperties.transitionStandard, ";border-right:0;box-shadow:none;appearance:none;" + ("" ), "" );
|
|
@@ -73,7 +69,7 @@ var getLanguageLabelStyles = function getLanguageLabelStyles(props, theme) {
|
|
|
73
69
|
|
|
74
70
|
function ownKeys(object, enumerableOnly) { var keys = _Object$keys__default["default"](object); if (_Object$getOwnPropertySymbols__default["default"]) { var symbols = _Object$getOwnPropertySymbols__default["default"](object); enumerableOnly && (symbols = _filterInstanceProperty__default["default"](symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor__default["default"](object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
75
71
|
|
|
76
|
-
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var
|
|
72
|
+
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var _context, _context2; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty__default["default"](_context = ownKeys(Object(source), !0)).call(_context, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](target, _Object$getOwnPropertyDescriptors__default["default"](source)) : _forEachInstanceProperty__default["default"](_context2 = ownKeys(Object(source))).call(_context2, function (key) { _Object$defineProperty__default["default"](target, key, _Object$getOwnPropertyDescriptor__default["default"](source, key)); }); } return target; }
|
|
77
73
|
var sequentialId = utils.createSequentialId('localized-text-input-');
|
|
78
74
|
|
|
79
75
|
var _ref = {
|
|
@@ -95,11 +91,13 @@ var LocalizedInput = function LocalizedInput(props) {
|
|
|
95
91
|
// might clear it using the knob, and then we can't parse the language from
|
|
96
92
|
// the input name anymore.
|
|
97
93
|
//
|
|
98
|
-
// eslint-disable-next-line no-param-reassign
|
|
99
94
|
event.target.language = props.language;
|
|
100
|
-
onChange(event);
|
|
95
|
+
onChange === null || onChange === void 0 ? void 0 : onChange(event);
|
|
101
96
|
}, [props.language, onChange]);
|
|
102
97
|
var theme = react.useTheme();
|
|
98
|
+
|
|
99
|
+
if (!props.isReadOnly) ;
|
|
100
|
+
|
|
103
101
|
return jsxRuntime.jsxs("div", {
|
|
104
102
|
css: _ref,
|
|
105
103
|
children: [jsxRuntime.jsx("label", {
|
|
@@ -116,8 +114,8 @@ var LocalizedInput = function LocalizedInput(props) {
|
|
|
116
114
|
}, props.language);
|
|
117
115
|
};
|
|
118
116
|
|
|
119
|
-
LocalizedInput.displayName = 'LocalizedInput';
|
|
120
117
|
LocalizedInput.propTypes = {};
|
|
118
|
+
LocalizedInput.displayName = 'LocalizedInput';
|
|
121
119
|
|
|
122
120
|
var RequiredValueErrorMessage = function RequiredValueErrorMessage() {
|
|
123
121
|
return jsxRuntime.jsx(messages.ErrorMessage, {
|
|
@@ -136,6 +134,9 @@ var LocalizedTextInput = function LocalizedTextInput(props) {
|
|
|
136
134
|
areLanguagesExpanded = _useToggleState2[0],
|
|
137
135
|
toggleLanguages = _useToggleState2[1];
|
|
138
136
|
|
|
137
|
+
var onLocalizedInputToggle = react$1.useCallback(function () {
|
|
138
|
+
return toggleLanguages();
|
|
139
|
+
}, [toggleLanguages]);
|
|
139
140
|
var languages = localizedUtils.sortLanguages(props.selectedLanguage, _Object$keys__default["default"](props.value));
|
|
140
141
|
var id = hooks.useFieldId(props.id, sequentialId);
|
|
141
142
|
var hasErrorInRemainingLanguages = props.hasError || localizedUtils.getHasErrorOnRemainingLanguages(props.errors, props.selectedLanguage);
|
|
@@ -149,6 +150,11 @@ var LocalizedTextInput = function LocalizedTextInput(props) {
|
|
|
149
150
|
}
|
|
150
151
|
|
|
151
152
|
var shouldRenderLanguagesButton = languages.length > 1 && !props.hideLanguageExpansionControls;
|
|
153
|
+
|
|
154
|
+
if (!props.isReadOnly) ;
|
|
155
|
+
|
|
156
|
+
if (props.hideLanguageExpansionControls) ;
|
|
157
|
+
|
|
152
158
|
return jsxRuntime.jsx(Constraints__default["default"].Horizontal, {
|
|
153
159
|
max: props.horizontalConstraint,
|
|
154
160
|
children: jsxRuntime.jsxs(Stack__default["default"], {
|
|
@@ -180,7 +186,7 @@ var LocalizedTextInput = function LocalizedTextInput(props) {
|
|
|
180
186
|
})
|
|
181
187
|
}), shouldRenderLanguagesButton && jsxRuntime.jsx(inputUtils.LocalizedInputToggle, {
|
|
182
188
|
isOpen: areLanguagesExpanded,
|
|
183
|
-
onClick:
|
|
189
|
+
onClick: onLocalizedInputToggle,
|
|
184
190
|
isDisabled: areLanguagesExpanded && hasErrorInRemainingLanguages,
|
|
185
191
|
remainingLocalizations: languages.length - 1
|
|
186
192
|
})]
|
|
@@ -188,9 +194,9 @@ var LocalizedTextInput = function LocalizedTextInput(props) {
|
|
|
188
194
|
});
|
|
189
195
|
};
|
|
190
196
|
|
|
197
|
+
LocalizedTextInput.propTypes = {};
|
|
191
198
|
LocalizedTextInput.displayName = 'LocalizedTextInput';
|
|
192
199
|
LocalizedTextInput.RequiredValueErrorMessage = RequiredValueErrorMessage;
|
|
193
|
-
LocalizedTextInput.propTypes = {};
|
|
194
200
|
LocalizedTextInput.defaultProps = {
|
|
195
201
|
horizontalConstraint: 'scale'
|
|
196
202
|
};
|
|
@@ -203,7 +209,7 @@ LocalizedTextInput.isTouched = localizedUtils.isTouched;
|
|
|
203
209
|
var LocalizedTextInput$1 = LocalizedTextInput;
|
|
204
210
|
|
|
205
211
|
// NOTE: This string will be replaced on build time with the package version.
|
|
206
|
-
var version = "13.0.
|
|
212
|
+
var version = "13.0.2";
|
|
207
213
|
|
|
208
214
|
exports["default"] = LocalizedTextInput$1;
|
|
209
215
|
exports.version = version;
|
|
@@ -5,16 +5,12 @@ import _forEachInstanceProperty from '@babel/runtime-corejs3/core-js-stable/inst
|
|
|
5
5
|
import _Object$getOwnPropertyDescriptors from '@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptors';
|
|
6
6
|
import _Object$defineProperties from '@babel/runtime-corejs3/core-js-stable/object/define-properties';
|
|
7
7
|
import _Object$defineProperty from '@babel/runtime-corejs3/core-js-stable/object/define-property';
|
|
8
|
-
import _taggedTemplateLiteral from '@babel/runtime-corejs3/helpers/esm/taggedTemplateLiteral';
|
|
9
8
|
import _slicedToArray from '@babel/runtime-corejs3/helpers/esm/slicedToArray';
|
|
10
9
|
import _defineProperty from '@babel/runtime-corejs3/helpers/esm/defineProperty';
|
|
10
|
+
import _pt from 'prop-types';
|
|
11
11
|
import _Object$keys from '@babel/runtime-corejs3/core-js-stable/object/keys';
|
|
12
12
|
import _mapInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/map';
|
|
13
|
-
import _concatInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/concat';
|
|
14
13
|
import { useCallback } from 'react';
|
|
15
|
-
import PropTypes from 'prop-types';
|
|
16
|
-
import requiredIf from 'react-required-if';
|
|
17
|
-
import { oneLine } from 'common-tags';
|
|
18
14
|
import { FormattedMessage } from 'react-intl';
|
|
19
15
|
import { css, useTheme } from '@emotion/react';
|
|
20
16
|
import { useToggleState, useFieldId } from '@commercetools-uikit/hooks';
|
|
@@ -23,7 +19,7 @@ import Stack from '@commercetools-uikit/spacings-stack';
|
|
|
23
19
|
import Constraints from '@commercetools-uikit/constraints';
|
|
24
20
|
import Text from '@commercetools-uikit/text';
|
|
25
21
|
import { sortLanguages, getHasErrorOnRemainingLanguages, createLocalizedDataAttributes, getId, getName, createLocalizedString, isEmpty, omitEmptyTranslations, isTouched } from '@commercetools-uikit/localized-utils';
|
|
26
|
-
import { createSequentialId } from '@commercetools-uikit/utils';
|
|
22
|
+
import { createSequentialId, warning } from '@commercetools-uikit/utils';
|
|
27
23
|
import TextInput from '@commercetools-uikit/text-input';
|
|
28
24
|
import { LocalizedInputToggle, messagesLocalizedInput } from '@commercetools-uikit/input-utils';
|
|
29
25
|
import { customProperties, designTokens } from '@commercetools-uikit/design-system';
|
|
@@ -44,7 +40,7 @@ var _ref$1 = process.env.NODE_ENV === "production" ? {
|
|
|
44
40
|
} : {
|
|
45
41
|
name: "bqcila-getLocalizedInputStyles",
|
|
46
42
|
styles: "border-top-left-radius:0;border-bottom-left-radius:0;border-style:solid;flex:auto;label:getLocalizedInputStyles;",
|
|
47
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
43
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImxvY2FsaXplZC10ZXh0LWlucHV0LnN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFXSyIsImZpbGUiOiJsb2NhbGl6ZWQtdGV4dC1pbnB1dC5zdHlsZXMudHMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjc3MsIHR5cGUgVGhlbWUgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQge1xuICBjdXN0b21Qcm9wZXJ0aWVzIGFzIHZhcnMsXG4gIGRlc2lnblRva2Vucyxcbn0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5cbi8vIE5PVEU6IG9yZGVyIGlzIGltcG9ydGFudCBoZXJlXG4vLyAqIGEgZGlzYWJsZWQtZmllbGQgY3VycmVudGx5IGRvZXMgbm90IGRpc3BsYXkgd2FybmluZy9lcnJvci1zdGF0ZXMgc28gaXQgdGFrZXMgcHJlY2VkZW5jZVxuLy8gKiBhIHJlYWRvbmx5LWZpZWxkIGNhbm5vdCBiZSBjaGFuZ2VkLCBidXQgaXQgbWlnaHQgYmUgcmVsZXZhbnQgZm9yIHZhbGlkYXRpb24sIHNvIGVycm9yIGFuZCB3YXJuaW5nIGFyZSBjaGVja2VkIGZpcnN0XG4vLyBob3cgeW91IGNhbiBpbnRlcmFjdCB3aXRoIHRoZSBmaWVsZCBpcyBjb250cm9sbGVkIHNlcGFyYXRlbHkgYnkgdGhlIHByb3BzLCB0aGlzIG9ubHkgaW5mbHVlbmNlcyB2aXN1YWxzXG5jb25zdCBnZXRMb2NhbGl6ZWRJbnB1dFN0eWxlcyA9ICgpID0+IFtcbiAgY3NzYFxuICAgIGJvcmRlci10b3AtbGVmdC1yYWRpdXM6IDA7XG4gICAgYm9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogMDtcbiAgICBib3JkZXItc3R5bGU6IHNvbGlkO1xuICAgIGZsZXg6IGF1dG87XG4gIGAsXG5dO1xuXG5jb25zdCBnZXRMYW5ndWFnZUxhYmVsU3R5bGVzID0gKF9wcm9wczogdW5rbm93biwgdGhlbWU6IFRoZW1lKSA9PiB7XG4gIGNvbnN0IG92ZXJ3cml0dGVuVmFycyA9IHtcbiAgICAuLi52YXJzLFxuICAgIC4uLnRoZW1lLFxuICB9O1xuXG4gIHJldHVybiBjc3NgXG4gICAgLyogYXZvaWQgd3JhcHBpbmcgbGFiZWwgb250byBuZXcgbGluZXMgKi9cbiAgICBmbGV4OiAxIDAgYXV0bztcbiAgICBib3gtc2l6aW5nOiBib3JkZXItYm94O1xuICAgIGNvbG9yOiAke292ZXJ3cml0dGVuVmFyc1tkZXNpZ25Ub2tlbnMuZm9udENvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWRdfTtcbiAgICBoZWlnaHQ6ICR7dmFycy5zaXplSGVpZ2h0SW5wdXR9O1xuICAgIGxpbmUtaGVpZ2h0OiAke3ZhcnMuc2l6ZUhlaWdodElucHV0fTtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke292ZXJ3cml0dGVuVmFyc1tcbiAgICAgIGRlc2lnblRva2Vucy5iYWNrZ3JvdW5kQ29sb3JGb3JJbnB1dFdoZW5EaXNhYmxlZFxuICAgIF19O1xuICAgIGJvcmRlci10b3AtbGVmdC1yYWRpdXM6ICR7b3ZlcndyaXR0ZW5WYXJzW1xuICAgICAgZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1c0ZvcklucHV0XG4gICAgXX07XG4gICAgYm9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogJHtvdmVyd3JpdHRlblZhcnNbXG4gICAgICBkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzRm9ySW5wdXRcbiAgICBdfTtcbiAgICBib3JkZXI6IDFweCAke292ZXJ3cml0dGVuVmFyc1tkZXNpZ25Ub2tlbnMuYm9yZGVyQ29sb3JGb3JJbnB1dFdoZW5EaXNhYmxlZF19XG4gICAgICBzb2xpZDtcbiAgICBwYWRkaW5nOiAwICR7dmFycy5zcGFjaW5nU307XG4gICAgdHJhbnNpdGlvbjogYm9yZGVyLWNvbG9yICR7dmFycy50cmFuc2l0aW9uU3RhbmRhcmR9LFxuICAgICAgYmFja2dyb3VuZC1jb2xvciAke3ZhcnMudHJhbnNpdGlvblN0YW5kYXJkfSxcbiAgICAgIGNvbG9yICR7dmFycy50cmFuc2l0aW9uU3RhbmRhcmR9O1xuICAgIGJvcmRlci1yaWdodDogMDtcbiAgICBib3gtc2hhZG93OiBub25lO1xuICAgIGFwcGVhcmFuY2U6IG5vbmU7XG4gIGA7XG59O1xuXG5leHBvcnQgeyBnZXRMb2NhbGl6ZWRJbnB1dFN0eWxlcywgZ2V0TGFuZ3VhZ2VMYWJlbFN0eWxlcyB9O1xuIl19 */",
|
|
48
44
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
|
|
49
45
|
};
|
|
50
46
|
|
|
@@ -52,17 +48,15 @@ var getLocalizedInputStyles = function getLocalizedInputStyles() {
|
|
|
52
48
|
return [_ref$1];
|
|
53
49
|
};
|
|
54
50
|
|
|
55
|
-
var getLanguageLabelStyles = function getLanguageLabelStyles(
|
|
51
|
+
var getLanguageLabelStyles = function getLanguageLabelStyles(_props, theme) {
|
|
56
52
|
var overwrittenVars = _objectSpread$1(_objectSpread$1({}, customProperties), theme);
|
|
57
53
|
|
|
58
|
-
return /*#__PURE__*/css("flex:1 0 auto;box-sizing:border-box;color:", overwrittenVars[designTokens.fontColorForInputWhenDisabled], ";height:", customProperties.sizeHeightInput, ";line-height:", customProperties.sizeHeightInput, ";background-color:", overwrittenVars[designTokens.backgroundColorForInputWhenDisabled], ";border-top-left-radius:", overwrittenVars[designTokens.borderRadiusForInput], ";border-bottom-left-radius:", overwrittenVars[designTokens.borderRadiusForInput], ";border:1px ", overwrittenVars[designTokens.borderColorForInputWhenDisabled], " solid;padding:0 ", customProperties.spacingS, ";transition:border-color ", customProperties.transitionStandard, ",background-color ", customProperties.transitionStandard, ",color ", customProperties.transitionStandard, ";border-right:0;box-shadow:none;appearance:none;" + (process.env.NODE_ENV === "production" ? "" : ";label:getLanguageLabelStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
54
|
+
return /*#__PURE__*/css("flex:1 0 auto;box-sizing:border-box;color:", overwrittenVars[designTokens.fontColorForInputWhenDisabled], ";height:", customProperties.sizeHeightInput, ";line-height:", customProperties.sizeHeightInput, ";background-color:", overwrittenVars[designTokens.backgroundColorForInputWhenDisabled], ";border-top-left-radius:", overwrittenVars[designTokens.borderRadiusForInput], ";border-bottom-left-radius:", overwrittenVars[designTokens.borderRadiusForInput], ";border:1px ", overwrittenVars[designTokens.borderColorForInputWhenDisabled], " solid;padding:0 ", customProperties.spacingS, ";transition:border-color ", customProperties.transitionStandard, ",background-color ", customProperties.transitionStandard, ",color ", customProperties.transitionStandard, ";border-right:0;box-shadow:none;appearance:none;" + (process.env.NODE_ENV === "production" ? "" : ";label:getLanguageLabelStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImxvY2FsaXplZC10ZXh0LWlucHV0LnN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF5QlkiLCJmaWxlIjoibG9jYWxpemVkLXRleHQtaW5wdXQuc3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzLCB0eXBlIFRoZW1lIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHtcbiAgY3VzdG9tUHJvcGVydGllcyBhcyB2YXJzLFxuICBkZXNpZ25Ub2tlbnMsXG59IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuXG4vLyBOT1RFOiBvcmRlciBpcyBpbXBvcnRhbnQgaGVyZVxuLy8gKiBhIGRpc2FibGVkLWZpZWxkIGN1cnJlbnRseSBkb2VzIG5vdCBkaXNwbGF5IHdhcm5pbmcvZXJyb3Itc3RhdGVzIHNvIGl0IHRha2VzIHByZWNlZGVuY2Vcbi8vICogYSByZWFkb25seS1maWVsZCBjYW5ub3QgYmUgY2hhbmdlZCwgYnV0IGl0IG1pZ2h0IGJlIHJlbGV2YW50IGZvciB2YWxpZGF0aW9uLCBzbyBlcnJvciBhbmQgd2FybmluZyBhcmUgY2hlY2tlZCBmaXJzdFxuLy8gaG93IHlvdSBjYW4gaW50ZXJhY3Qgd2l0aCB0aGUgZmllbGQgaXMgY29udHJvbGxlZCBzZXBhcmF0ZWx5IGJ5IHRoZSBwcm9wcywgdGhpcyBvbmx5IGluZmx1ZW5jZXMgdmlzdWFsc1xuY29uc3QgZ2V0TG9jYWxpemVkSW5wdXRTdHlsZXMgPSAoKSA9PiBbXG4gIGNzc2BcbiAgICBib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAwO1xuICAgIGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6IDA7XG4gICAgYm9yZGVyLXN0eWxlOiBzb2xpZDtcbiAgICBmbGV4OiBhdXRvO1xuICBgLFxuXTtcblxuY29uc3QgZ2V0TGFuZ3VhZ2VMYWJlbFN0eWxlcyA9IChfcHJvcHM6IHVua25vd24sIHRoZW1lOiBUaGVtZSkgPT4ge1xuICBjb25zdCBvdmVyd3JpdHRlblZhcnMgPSB7XG4gICAgLi4udmFycyxcbiAgICAuLi50aGVtZSxcbiAgfTtcblxuICByZXR1cm4gY3NzYFxuICAgIC8qIGF2b2lkIHdyYXBwaW5nIGxhYmVsIG9udG8gbmV3IGxpbmVzICovXG4gICAgZmxleDogMSAwIGF1dG87XG4gICAgYm94LXNpemluZzogYm9yZGVyLWJveDtcbiAgICBjb2xvcjogJHtvdmVyd3JpdHRlblZhcnNbZGVzaWduVG9rZW5zLmZvbnRDb2xvckZvcklucHV0V2hlbkRpc2FibGVkXX07XG4gICAgaGVpZ2h0OiAke3ZhcnMuc2l6ZUhlaWdodElucHV0fTtcbiAgICBsaW5lLWhlaWdodDogJHt2YXJzLnNpemVIZWlnaHRJbnB1dH07XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHtvdmVyd3JpdHRlblZhcnNbXG4gICAgICBkZXNpZ25Ub2tlbnMuYmFja2dyb3VuZENvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWRcbiAgICBdfTtcbiAgICBib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAke292ZXJ3cml0dGVuVmFyc1tcbiAgICAgIGRlc2lnblRva2Vucy5ib3JkZXJSYWRpdXNGb3JJbnB1dFxuICAgIF19O1xuICAgIGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6ICR7b3ZlcndyaXR0ZW5WYXJzW1xuICAgICAgZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1c0ZvcklucHV0XG4gICAgXX07XG4gICAgYm9yZGVyOiAxcHggJHtvdmVyd3JpdHRlblZhcnNbZGVzaWduVG9rZW5zLmJvcmRlckNvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWRdfVxuICAgICAgc29saWQ7XG4gICAgcGFkZGluZzogMCAke3ZhcnMuc3BhY2luZ1N9O1xuICAgIHRyYW5zaXRpb246IGJvcmRlci1jb2xvciAke3ZhcnMudHJhbnNpdGlvblN0YW5kYXJkfSxcbiAgICAgIGJhY2tncm91bmQtY29sb3IgJHt2YXJzLnRyYW5zaXRpb25TdGFuZGFyZH0sXG4gICAgICBjb2xvciAke3ZhcnMudHJhbnNpdGlvblN0YW5kYXJkfTtcbiAgICBib3JkZXItcmlnaHQ6IDA7XG4gICAgYm94LXNoYWRvdzogbm9uZTtcbiAgICBhcHBlYXJhbmNlOiBub25lO1xuICBgO1xufTtcblxuZXhwb3J0IHsgZ2V0TG9jYWxpemVkSW5wdXRTdHlsZXMsIGdldExhbmd1YWdlTGFiZWxTdHlsZXMgfTtcbiJdfQ== */");
|
|
59
55
|
};
|
|
60
56
|
|
|
61
|
-
var _templateObject;
|
|
62
|
-
|
|
63
57
|
function ownKeys(object, enumerableOnly) { var keys = _Object$keys(object); if (_Object$getOwnPropertySymbols) { var symbols = _Object$getOwnPropertySymbols(object); enumerableOnly && (symbols = _filterInstanceProperty(symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
64
58
|
|
|
65
|
-
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var
|
|
59
|
+
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var _context, _context2; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty(_context = ownKeys(Object(source), !0)).call(_context, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(target, _Object$getOwnPropertyDescriptors(source)) : _forEachInstanceProperty(_context2 = ownKeys(Object(source))).call(_context2, function (key) { _Object$defineProperty(target, key, _Object$getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
66
60
|
|
|
67
61
|
function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
68
62
|
var sequentialId = createSequentialId('localized-text-input-');
|
|
@@ -73,7 +67,7 @@ var _ref = process.env.NODE_ENV === "production" ? {
|
|
|
73
67
|
} : {
|
|
74
68
|
name: "1ysn02y-LocalizedInput",
|
|
75
69
|
styles: "width:100%;position:relative;display:flex;label:LocalizedInput;",
|
|
76
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["localized-text-input.js"],"names":[],"mappings":"AA6Dc","file":"localized-text-input.js","sourcesContent":["import { useCallback } from 'react';\nimport PropTypes from 'prop-types';\nimport requiredIf from 'react-required-if';\nimport { oneLine } from 'common-tags';\nimport { FormattedMessage } from 'react-intl';\nimport { css, useTheme } from '@emotion/react';\nimport { useFieldId, useToggleState } from '@commercetools-uikit/hooks';\nimport { ErrorMessage } from '@commercetools-uikit/messages';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport Constraints from '@commercetools-uikit/constraints';\nimport Text from '@commercetools-uikit/text';\nimport {\n  sortLanguages,\n  createLocalizedDataAttributes,\n  getHasErrorOnRemainingLanguages,\n  isTouched,\n  omitEmptyTranslations,\n  isEmpty,\n  createLocalizedString,\n  getId,\n  getName,\n} from '@commercetools-uikit/localized-utils';\nimport { createSequentialId } from '@commercetools-uikit/utils';\nimport TextInput from '@commercetools-uikit/text-input';\nimport {\n  LocalizedInputToggle,\n  messagesLocalizedInput,\n} from '@commercetools-uikit/input-utils';\nimport {\n  getLocalizedInputStyles,\n  getLanguageLabelStyles,\n} from './localized-text-input.styles';\n\nconst sequentialId = createSequentialId('localized-text-input-');\n\nconst LocalizedInput = (props) => {\n  const { onChange } = props;\n  const handleChange = useCallback(\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      //\n      // eslint-disable-next-line no-param-reassign\n      event.target.language = props.language;\n      onChange(event);\n    },\n    [props.language, onChange]\n  );\n  const theme = useTheme();\n\n  return (\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, theme)}>\n        {/* FIXME: add proper tone for disabled when tones are refactored */}\n        <Text.Detail tone=\"secondary\">\n          {props.language.toUpperCase()}\n        </Text.Detail>\n      </label>\n      <TextInput\n        {...props}\n        onChange={handleChange}\n        css={getLocalizedInputStyles}\n      />\n    </div>\n  );\n};\n\nLocalizedInput.displayName = 'LocalizedInput';\nLocalizedInput.propTypes = {\n  /**\n   * Used as prefix of HTML `id` property. Each input field id will have the language as a suffix (`${idPrefix}.${lang}`), e.g. `foo.en`. You can use the static `LocalizedTextInput.getId(idPrefix, language)` to create this id string, e.g. for labels.\n   */\n  id: PropTypes.string,\n  /**\n   * Used as HTML `name` property for each input field. Each input field name will have the language as a suffix (`${namePrefix}.${lang}`), e.g. `foo.en`\n   */\n  name: PropTypes.string,\n  /**\n   * Used as HTML `autocomplete` property\n   */\n  autoComplete: PropTypes.string,\n  value: PropTypes.string.isRequired,\n  /**\n   * Gets called when any input is changed. Is called with the change event of the changed input.\n   */\n  onChange: requiredIf(PropTypes.func, (props) => !props.isReadOnly),\n  language: PropTypes.string.isRequired,\n  onBlur: PropTypes.func,\n  onFocus: PropTypes.func,\n  isAutofocussed: PropTypes.bool,\n  isDisabled: PropTypes.bool,\n  isReadOnly: PropTypes.bool,\n  hasError: PropTypes.bool,\n  placeholder: PropTypes.string,\n};\n\nconst RequiredValueErrorMessage = () => (\n  <ErrorMessage>\n    <FormattedMessage {...messagesLocalizedInput.missingRequiredField} />\n  </ErrorMessage>\n);\n\nRequiredValueErrorMessage.displayName = 'RequiredValueErrorMessage';\n\nconst LocalizedTextInput = (props) => {\n  const defaultExpansionState =\n    props.hideLanguageExpansionControls ||\n    props.defaultExpandLanguages || // default to `false`, because useToggleState defaults to `true`\n    false;\n\n  const [areLanguagesExpanded, toggleLanguages] = useToggleState(\n    defaultExpansionState\n  );\n\n  const languages = sortLanguages(\n    props.selectedLanguage,\n    Object.keys(props.value)\n  );\n\n  const id = useFieldId(props.id, sequentialId);\n\n  const hasErrorInRemainingLanguages =\n    props.hasError ||\n    getHasErrorOnRemainingLanguages(props.errors, props.selectedLanguage);\n\n  if (hasErrorInRemainingLanguages) {\n    // this update within render replaces the old `getDerivedStateFromProps` functionality\n    // https://reactjs.org/docs/hooks-faq.html#how-do-i-implement-getderivedstatefromprops\n    if (hasErrorInRemainingLanguages !== areLanguagesExpanded) {\n      toggleLanguages();\n    }\n  }\n\n  const shouldRenderLanguagesButton =\n    languages.length > 1 && !props.hideLanguageExpansionControls;\n\n  return (\n    <Constraints.Horizontal max={props.horizontalConstraint}>\n      <Stack scale=\"xs\">\n        <Stack>\n          {languages.map((language, index) => {\n            const isFirstLanguage = index === 0;\n            if (!isFirstLanguage && !areLanguagesExpanded) return null;\n\n            return (\n              <div key={language}>\n                <Stack scale=\"xs\">\n                  <LocalizedInput\n                    autoComplete={props.autoComplete}\n                    id={LocalizedTextInput.getId(id, language)}\n                    name={LocalizedTextInput.getName(props.name, language)}\n                    value={props.value[language]}\n                    onChange={props.onChange}\n                    language={language}\n                    placeholder={\n                      props.placeholder\n                        ? props.placeholder[language]\n                        : undefined\n                    }\n                    onBlur={props.onBlur}\n                    onFocus={props.onFocus}\n                    isAutofocussed={index === 0 && props.isAutofocussed}\n                    isDisabled={props.isDisabled}\n                    isReadOnly={props.isReadOnly}\n                    hasError={Boolean(\n                      props.hasError || (props.errors && props.errors[language])\n                    )}\n                    {...createLocalizedDataAttributes(props, language)}\n                  />\n                  {props.errors && props.errors[language]}\n                </Stack>\n              </div>\n            );\n          })}\n        </Stack>\n        {shouldRenderLanguagesButton && (\n          <LocalizedInputToggle\n            isOpen={areLanguagesExpanded}\n            onClick={toggleLanguages}\n            isDisabled={areLanguagesExpanded && hasErrorInRemainingLanguages}\n            remainingLocalizations={languages.length - 1}\n          />\n        )}\n      </Stack>\n    </Constraints.Horizontal>\n  );\n};\n\nLocalizedTextInput.displayName = 'LocalizedTextInput';\n\nLocalizedTextInput.RequiredValueErrorMessage = RequiredValueErrorMessage;\n\nLocalizedTextInput.propTypes = {\n  id: PropTypes.string,\n  name: PropTypes.string,\n  autoComplete: PropTypes.string,\n  // then input doesn't accept a \"languages\" prop, instead all possible\n  // languages have to exist (with empty or filled strings) on the value:\n  //   { en: 'foo', de: '', es: '' }\n  value: PropTypes.objectOf(PropTypes.string).isRequired,\n  /**\n   * Gets called when any input is changed. Is called with the change event of the changed input.\n   */\n  onChange: requiredIf(PropTypes.func, (props) => !props.isReadOnly),\n  /**\n   * Specifies which language will be shown in case the `LocalizedTextInput` is collapsed.\n   */\n  selectedLanguage: PropTypes.string.isRequired,\n  /**\n   * Called when any field is blurred. Is called with the `event` of that field.\n   */\n  onBlur: PropTypes.func,\n  /**\n   * Called when any field is focussed. Is called with the `event` of that field.\n   */\n  onFocus: PropTypes.func,\n  /**\n   * Will hide the language expansion controls when set to `true`. All languages will be shown when set to `true`.\n   */\n  hideLanguageExpansionControls: PropTypes.bool,\n  /**\n   * Controls whether one or all languages are visible by default\n   */\n  defaultExpandLanguages: (props, propName, componentName, ...rest) => {\n    if (\n      props.hideLanguageExpansionControls &&\n      typeof props[propName] === 'boolean'\n    ) {\n      throw new Error(\n        oneLine`\n          ${componentName}: \"${propName}\" does not have any effect when\n          \"hideLanguageExpansionControls\" is set.\n        `\n      );\n    }\n    return PropTypes.bool(props, propName, componentName, ...rest);\n  },\n  /**\n   * Focus the input field on initial render\n   */\n  isAutofocussed: PropTypes.bool,\n  /**\n   * Disables all input fields.\n   */\n  isDisabled: PropTypes.bool,\n  /**\n   * Disables all input fields and shows them in read-only mode.\n   */\n  isReadOnly: PropTypes.bool,\n  /**\n   * Placeholders for each language. Object of the same shape as `value`.\n   */\n  placeholder: PropTypes.objectOf(PropTypes.string),\n  /**\n   * Horizontal size limit of the input fields.\n   */\n  horizontalConstraint: PropTypes.oneOf([\n    1,\n    2,\n    3,\n    4,\n    5,\n    6,\n    7,\n    8,\n    9,\n    10,\n    11,\n    12,\n    13,\n    14,\n    15,\n    16,\n    'scale',\n    'auto',\n  ]),\n  /**\n   * Will apply the error state to each input without showing any error message.\n   */\n  hasError: PropTypes.bool,\n  /**\n   * Used to show errors underneath the inputs of specific currencies. Pass an object whose key is a currency and whose value is the error to show for that key.\n   */\n  errors: PropTypes.objectOf(PropTypes.node),\n};\n\nLocalizedTextInput.defaultProps = {\n  horizontalConstraint: 'scale',\n};\n\nLocalizedTextInput.getId = getId;\n\nLocalizedTextInput.getName = getName;\n\nLocalizedTextInput.createLocalizedString = createLocalizedString;\n\nLocalizedTextInput.isEmpty = isEmpty;\n\nLocalizedTextInput.omitEmptyTranslations = omitEmptyTranslations;\n\nLocalizedTextInput.isTouched = isTouched;\n\nexport default LocalizedTextInput;\n"]} */",
|
|
70
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["localized-text-input.tsx"],"names":[],"mappings":"AAkLc","file":"localized-text-input.tsx","sourcesContent":["import {\n  type FocusEventHandler,\n  type ChangeEventHandler,\n  useCallback,\n} from 'react';\nimport { FormattedMessage } from 'react-intl';\nimport { css, useTheme } from '@emotion/react';\nimport { useFieldId, useToggleState } from '@commercetools-uikit/hooks';\nimport { ErrorMessage } from '@commercetools-uikit/messages';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport Constraints from '@commercetools-uikit/constraints';\nimport Text from '@commercetools-uikit/text';\nimport {\n  sortLanguages,\n  createLocalizedDataAttributes,\n  getHasErrorOnRemainingLanguages,\n  isTouched,\n  omitEmptyTranslations,\n  isEmpty,\n  createLocalizedString,\n  getId,\n  getName,\n} from '@commercetools-uikit/localized-utils';\nimport { createSequentialId, warning } from '@commercetools-uikit/utils';\nimport TextInput from '@commercetools-uikit/text-input';\nimport {\n  LocalizedInputToggle,\n  messagesLocalizedInput,\n} from '@commercetools-uikit/input-utils';\nimport {\n  getLocalizedInputStyles,\n  getLanguageLabelStyles,\n} from './localized-text-input.styles';\n\ntype TLocalizedTextInputProps = {\n  id?: string;\n  name?: string;\n  autoComplete?: string;\n  /**\n   *   then input doesn't accept a \"languages\" prop, instead all possible\n  languages have to exist (with empty or filled strings) on the value:\n    { en: 'foo', de: '', es: '' }\n   */\n  value: Record<string, string>;\n  /**\n   * Gets called when any input is changed. Is called with the change event of the changed input.\n   */\n  onChange?: ChangeEventHandler;\n  /**\n   * Specifies which language will be shown in case the `LocalizedTextInput` is collapsed.\n   */\n  selectedLanguage: string;\n  /**\n   * Called when any field is blurred. Is called with the `event` of that field.\n   */\n  onBlur?: FocusEventHandler;\n  /**\n   * Called when any field is focussed. Is called with the `event` of that field.\n   */\n  onFocus?: FocusEventHandler;\n  /**\n   * Will hide the language expansion controls when set to `true`. All languages will be shown when set to `true`.\n   */\n  hideLanguageExpansionControls?: boolean;\n  /**\n   * Controls whether one or all languages are visible by default\n   */\n  defaultExpandLanguages?: boolean;\n  /**\n   * Focus the input field on initial render\n   */\n  isAutofocussed?: boolean;\n  /**\n   * Disables all input fields.\n   */\n  isDisabled?: boolean;\n  /**\n   * Disables all input fields and shows them in read-only mode.\n   */\n  isReadOnly?: boolean;\n  /**\n   * Placeholders for each language. Object of the same shape as `value`.\n   */\n  placeholder?: Record<string, string>;\n  /**\n   * Horizontal size limit of the input fields.\n   */\n  horizontalConstraint?:\n    | 1\n    | 2\n    | 3\n    | 4\n    | 5\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n  /**\n   * Will apply the error state to each input without showing any error message.\n   */\n  hasError?: boolean;\n  /**\n   * Used to show errors underneath the inputs of specific currencies. Pass an object whose key is a currency and whose value is the error to show for that key.\n   */\n  errors?: Record<string, string>;\n};\n\ntype TLocalizedInputProps = {\n  /**\n   * Used as prefix of HTML `id` property. Each input field id will have the language as a suffix (`${idPrefix}.${lang}`), e.g. `foo.en`. You can use the static `LocalizedTextInput.getId(idPrefix, language)` to create this id string, e.g. for labels.\n   */\n  id?: string;\n  /**\n   * Used as HTML `name` property for each input field. Each input field name will have the language as a suffix (`${namePrefix}.${lang}`), e.g. `foo.en`\n   */\n  name?: string;\n  /**\n   * Used as HTML `autocomplete` property\n   */\n  autoComplete?: string;\n  value: string;\n  /**\n   * Gets called when any input is changed. Is called with the change event of the changed input.\n   */\n  onChange?: ChangeEventHandler;\n  language: string;\n  onBlur?: FocusEventHandler;\n  onFocus?: FocusEventHandler;\n  isAutofocussed?: boolean;\n  isDisabled?: boolean;\n  isReadOnly?: boolean;\n  hasError?: boolean;\n  placeholder?: string;\n};\n\nconst sequentialId = createSequentialId('localized-text-input-');\n\nconst LocalizedInput = (props: TLocalizedInputProps) => {\n  const { onChange } = props;\n  const handleChange = useCallback(\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      //\n      event.target.language = props.language;\n      onChange?.(event);\n    },\n    [props.language, onChange]\n  );\n  const theme = useTheme();\n\n  if (!props.isReadOnly) {\n    warning(\n      typeof props.onChange === 'function',\n      'LocaliszedTextInput: \"onChange\" is required when isReadOnly is not true'\n    );\n  }\n\n  return (\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, theme)}>\n        {/* FIXME: add proper tone for disabled when tones are refactored */}\n        <Text.Detail tone=\"secondary\">\n          {props.language.toUpperCase()}\n        </Text.Detail>\n      </label>\n      <TextInput\n        {...props}\n        onChange={handleChange}\n        css={getLocalizedInputStyles}\n      />\n    </div>\n  );\n};\n\nLocalizedInput.displayName = 'LocalizedInput';\n\nconst RequiredValueErrorMessage = () => (\n  <ErrorMessage>\n    <FormattedMessage {...messagesLocalizedInput.missingRequiredField} />\n  </ErrorMessage>\n);\n\nRequiredValueErrorMessage.displayName = 'RequiredValueErrorMessage';\n\nconst LocalizedTextInput = (props: TLocalizedTextInputProps) => {\n  const defaultExpansionState =\n    props.hideLanguageExpansionControls ||\n    props.defaultExpandLanguages || // default to `false`, because useToggleState defaults to `true`\n    false;\n\n  const [areLanguagesExpanded, toggleLanguages] = useToggleState(\n    defaultExpansionState\n  );\n\n  const onLocalizedInputToggle = useCallback(\n    () => toggleLanguages(),\n    [toggleLanguages]\n  );\n\n  const languages = sortLanguages(\n    props.selectedLanguage,\n    Object.keys(props.value)\n  );\n\n  const id = useFieldId(props.id, sequentialId);\n\n  const hasErrorInRemainingLanguages =\n    props.hasError ||\n    getHasErrorOnRemainingLanguages(props.errors, props.selectedLanguage);\n\n  if (hasErrorInRemainingLanguages) {\n    // this update within render replaces the old `getDerivedStateFromProps` functionality\n    // https://reactjs.org/docs/hooks-faq.html#how-do-i-implement-getderivedstatefromprops\n    if (hasErrorInRemainingLanguages !== areLanguagesExpanded) {\n      toggleLanguages();\n    }\n  }\n\n  const shouldRenderLanguagesButton =\n    languages.length > 1 && !props.hideLanguageExpansionControls;\n\n  if (!props.isReadOnly) {\n    warning(\n      typeof props.onChange === 'function',\n      'LocalizedTextInput: \"onChange\" is required when isReadOnly is not true'\n    );\n  }\n\n  if (props.hideLanguageExpansionControls) {\n    warning(\n      typeof props.defaultExpandLanguages !== 'boolean',\n      'LocalizedTextInput: \"defaultExpandLanguages\" does not have any effect when \"hideLanguageExpansionControls\" is set.'\n    );\n  }\n\n  return (\n    <Constraints.Horizontal max={props.horizontalConstraint}>\n      <Stack scale=\"xs\">\n        <Stack>\n          {languages.map((language, index) => {\n            const isFirstLanguage = index === 0;\n            if (!isFirstLanguage && !areLanguagesExpanded) return null;\n\n            return (\n              <div key={language}>\n                <Stack scale=\"xs\">\n                  <LocalizedInput\n                    autoComplete={props.autoComplete}\n                    id={LocalizedTextInput.getId(id, language)}\n                    name={LocalizedTextInput.getName(props.name, language)}\n                    value={props.value[language]}\n                    onChange={props.onChange}\n                    language={language}\n                    placeholder={\n                      props.placeholder\n                        ? props.placeholder[language]\n                        : undefined\n                    }\n                    onBlur={props.onBlur}\n                    onFocus={props.onFocus}\n                    isAutofocussed={index === 0 && props.isAutofocussed}\n                    isDisabled={props.isDisabled}\n                    isReadOnly={props.isReadOnly}\n                    hasError={Boolean(\n                      props.hasError || (props.errors && props.errors[language])\n                    )}\n                    {...createLocalizedDataAttributes(props, language)}\n                  />\n                  {props.errors && props.errors[language]}\n                </Stack>\n              </div>\n            );\n          })}\n        </Stack>\n        {shouldRenderLanguagesButton && (\n          <LocalizedInputToggle\n            isOpen={areLanguagesExpanded}\n            onClick={onLocalizedInputToggle}\n            isDisabled={areLanguagesExpanded && hasErrorInRemainingLanguages}\n            remainingLocalizations={languages.length - 1}\n          />\n        )}\n      </Stack>\n    </Constraints.Horizontal>\n  );\n};\n\nLocalizedTextInput.displayName = 'LocalizedTextInput';\n\nLocalizedTextInput.RequiredValueErrorMessage = RequiredValueErrorMessage;\n\nLocalizedTextInput.defaultProps = {\n  horizontalConstraint: 'scale',\n};\n\nLocalizedTextInput.getId = getId;\n\nLocalizedTextInput.getName = getName;\n\nLocalizedTextInput.createLocalizedString = createLocalizedString;\n\nLocalizedTextInput.isEmpty = isEmpty;\n\nLocalizedTextInput.omitEmptyTranslations = omitEmptyTranslations;\n\nLocalizedTextInput.isTouched = isTouched;\n\nexport default LocalizedTextInput;\n"]} */",
|
|
77
71
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
78
72
|
};
|
|
79
73
|
|
|
@@ -91,11 +85,15 @@ var LocalizedInput = function LocalizedInput(props) {
|
|
|
91
85
|
// might clear it using the knob, and then we can't parse the language from
|
|
92
86
|
// the input name anymore.
|
|
93
87
|
//
|
|
94
|
-
// eslint-disable-next-line no-param-reassign
|
|
95
88
|
event.target.language = props.language;
|
|
96
|
-
onChange(event);
|
|
89
|
+
onChange === null || onChange === void 0 ? void 0 : onChange(event);
|
|
97
90
|
}, [props.language, onChange]);
|
|
98
91
|
var theme = useTheme();
|
|
92
|
+
|
|
93
|
+
if (!props.isReadOnly) {
|
|
94
|
+
process.env.NODE_ENV !== "production" ? warning(typeof props.onChange === 'function', 'LocaliszedTextInput: "onChange" is required when isReadOnly is not true') : void 0;
|
|
95
|
+
}
|
|
96
|
+
|
|
99
97
|
return jsxs("div", {
|
|
100
98
|
css: _ref,
|
|
101
99
|
children: [jsx("label", {
|
|
@@ -112,39 +110,22 @@ var LocalizedInput = function LocalizedInput(props) {
|
|
|
112
110
|
}, props.language);
|
|
113
111
|
};
|
|
114
112
|
|
|
115
|
-
LocalizedInput.displayName = 'LocalizedInput';
|
|
116
113
|
LocalizedInput.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
autoComplete: PropTypes.string,
|
|
131
|
-
value: PropTypes.string.isRequired,
|
|
132
|
-
|
|
133
|
-
/**
|
|
134
|
-
* Gets called when any input is changed. Is called with the change event of the changed input.
|
|
135
|
-
*/
|
|
136
|
-
onChange: requiredIf(PropTypes.func, function (props) {
|
|
137
|
-
return !props.isReadOnly;
|
|
138
|
-
}),
|
|
139
|
-
language: PropTypes.string.isRequired,
|
|
140
|
-
onBlur: PropTypes.func,
|
|
141
|
-
onFocus: PropTypes.func,
|
|
142
|
-
isAutofocussed: PropTypes.bool,
|
|
143
|
-
isDisabled: PropTypes.bool,
|
|
144
|
-
isReadOnly: PropTypes.bool,
|
|
145
|
-
hasError: PropTypes.bool,
|
|
146
|
-
placeholder: PropTypes.string
|
|
114
|
+
id: _pt.string,
|
|
115
|
+
name: _pt.string,
|
|
116
|
+
autoComplete: _pt.string,
|
|
117
|
+
value: _pt.string.isRequired,
|
|
118
|
+
onChange: _pt.func,
|
|
119
|
+
language: _pt.string.isRequired,
|
|
120
|
+
onBlur: _pt.func,
|
|
121
|
+
onFocus: _pt.func,
|
|
122
|
+
isAutofocussed: _pt.bool,
|
|
123
|
+
isDisabled: _pt.bool,
|
|
124
|
+
isReadOnly: _pt.bool,
|
|
125
|
+
hasError: _pt.bool,
|
|
126
|
+
placeholder: _pt.string
|
|
147
127
|
} : {};
|
|
128
|
+
LocalizedInput.displayName = 'LocalizedInput';
|
|
148
129
|
|
|
149
130
|
var RequiredValueErrorMessage = function RequiredValueErrorMessage() {
|
|
150
131
|
return jsx(ErrorMessage, {
|
|
@@ -163,6 +144,9 @@ var LocalizedTextInput = function LocalizedTextInput(props) {
|
|
|
163
144
|
areLanguagesExpanded = _useToggleState2[0],
|
|
164
145
|
toggleLanguages = _useToggleState2[1];
|
|
165
146
|
|
|
147
|
+
var onLocalizedInputToggle = useCallback(function () {
|
|
148
|
+
return toggleLanguages();
|
|
149
|
+
}, [toggleLanguages]);
|
|
166
150
|
var languages = sortLanguages(props.selectedLanguage, _Object$keys(props.value));
|
|
167
151
|
var id = useFieldId(props.id, sequentialId);
|
|
168
152
|
var hasErrorInRemainingLanguages = props.hasError || getHasErrorOnRemainingLanguages(props.errors, props.selectedLanguage);
|
|
@@ -176,6 +160,15 @@ var LocalizedTextInput = function LocalizedTextInput(props) {
|
|
|
176
160
|
}
|
|
177
161
|
|
|
178
162
|
var shouldRenderLanguagesButton = languages.length > 1 && !props.hideLanguageExpansionControls;
|
|
163
|
+
|
|
164
|
+
if (!props.isReadOnly) {
|
|
165
|
+
process.env.NODE_ENV !== "production" ? warning(typeof props.onChange === 'function', 'LocalizedTextInput: "onChange" is required when isReadOnly is not true') : void 0;
|
|
166
|
+
}
|
|
167
|
+
|
|
168
|
+
if (props.hideLanguageExpansionControls) {
|
|
169
|
+
process.env.NODE_ENV !== "production" ? warning(typeof props.defaultExpandLanguages !== 'boolean', 'LocalizedTextInput: "defaultExpandLanguages" does not have any effect when "hideLanguageExpansionControls" is set.') : void 0;
|
|
170
|
+
}
|
|
171
|
+
|
|
179
172
|
return jsx(Constraints.Horizontal, {
|
|
180
173
|
max: props.horizontalConstraint,
|
|
181
174
|
children: jsxs(Stack, {
|
|
@@ -207,7 +200,7 @@ var LocalizedTextInput = function LocalizedTextInput(props) {
|
|
|
207
200
|
})
|
|
208
201
|
}), shouldRenderLanguagesButton && jsx(LocalizedInputToggle, {
|
|
209
202
|
isOpen: areLanguagesExpanded,
|
|
210
|
-
onClick:
|
|
203
|
+
onClick: onLocalizedInputToggle,
|
|
211
204
|
isDisabled: areLanguagesExpanded && hasErrorInRemainingLanguages,
|
|
212
205
|
remainingLocalizations: languages.length - 1
|
|
213
206
|
})]
|
|
@@ -215,96 +208,27 @@ var LocalizedTextInput = function LocalizedTextInput(props) {
|
|
|
215
208
|
});
|
|
216
209
|
};
|
|
217
210
|
|
|
218
|
-
LocalizedTextInput.displayName = 'LocalizedTextInput';
|
|
219
|
-
LocalizedTextInput.RequiredValueErrorMessage = RequiredValueErrorMessage;
|
|
220
211
|
LocalizedTextInput.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
221
|
-
id:
|
|
222
|
-
name:
|
|
223
|
-
autoComplete:
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
*/
|
|
239
|
-
selectedLanguage: PropTypes.string.isRequired,
|
|
240
|
-
|
|
241
|
-
/**
|
|
242
|
-
* Called when any field is blurred. Is called with the `event` of that field.
|
|
243
|
-
*/
|
|
244
|
-
onBlur: PropTypes.func,
|
|
245
|
-
|
|
246
|
-
/**
|
|
247
|
-
* Called when any field is focussed. Is called with the `event` of that field.
|
|
248
|
-
*/
|
|
249
|
-
onFocus: PropTypes.func,
|
|
250
|
-
|
|
251
|
-
/**
|
|
252
|
-
* Will hide the language expansion controls when set to `true`. All languages will be shown when set to `true`.
|
|
253
|
-
*/
|
|
254
|
-
hideLanguageExpansionControls: PropTypes.bool,
|
|
255
|
-
|
|
256
|
-
/**
|
|
257
|
-
* Controls whether one or all languages are visible by default
|
|
258
|
-
*/
|
|
259
|
-
defaultExpandLanguages: function defaultExpandLanguages(props, propName, componentName) {
|
|
260
|
-
var _context;
|
|
261
|
-
|
|
262
|
-
if (props.hideLanguageExpansionControls && typeof props[propName] === 'boolean') {
|
|
263
|
-
throw new Error(oneLine(_templateObject || (_templateObject = _taggedTemplateLiteral(["\n ", ": \"", "\" does not have any effect when\n \"hideLanguageExpansionControls\" is set.\n "])), componentName, propName));
|
|
264
|
-
}
|
|
265
|
-
|
|
266
|
-
for (var _len = arguments.length, rest = new Array(_len > 3 ? _len - 3 : 0), _key = 3; _key < _len; _key++) {
|
|
267
|
-
rest[_key - 3] = arguments[_key];
|
|
268
|
-
}
|
|
269
|
-
|
|
270
|
-
return PropTypes.bool.apply(PropTypes, _concatInstanceProperty(_context = [props, propName, componentName]).call(_context, rest));
|
|
271
|
-
},
|
|
272
|
-
|
|
273
|
-
/**
|
|
274
|
-
* Focus the input field on initial render
|
|
275
|
-
*/
|
|
276
|
-
isAutofocussed: PropTypes.bool,
|
|
277
|
-
|
|
278
|
-
/**
|
|
279
|
-
* Disables all input fields.
|
|
280
|
-
*/
|
|
281
|
-
isDisabled: PropTypes.bool,
|
|
282
|
-
|
|
283
|
-
/**
|
|
284
|
-
* Disables all input fields and shows them in read-only mode.
|
|
285
|
-
*/
|
|
286
|
-
isReadOnly: PropTypes.bool,
|
|
287
|
-
|
|
288
|
-
/**
|
|
289
|
-
* Placeholders for each language. Object of the same shape as `value`.
|
|
290
|
-
*/
|
|
291
|
-
placeholder: PropTypes.objectOf(PropTypes.string),
|
|
292
|
-
|
|
293
|
-
/**
|
|
294
|
-
* Horizontal size limit of the input fields.
|
|
295
|
-
*/
|
|
296
|
-
horizontalConstraint: PropTypes.oneOf([1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 'scale', 'auto']),
|
|
297
|
-
|
|
298
|
-
/**
|
|
299
|
-
* Will apply the error state to each input without showing any error message.
|
|
300
|
-
*/
|
|
301
|
-
hasError: PropTypes.bool,
|
|
302
|
-
|
|
303
|
-
/**
|
|
304
|
-
* Used to show errors underneath the inputs of specific currencies. Pass an object whose key is a currency and whose value is the error to show for that key.
|
|
305
|
-
*/
|
|
306
|
-
errors: PropTypes.objectOf(PropTypes.node)
|
|
212
|
+
id: _pt.string,
|
|
213
|
+
name: _pt.string,
|
|
214
|
+
autoComplete: _pt.string,
|
|
215
|
+
value: _pt.objectOf(_pt.string).isRequired,
|
|
216
|
+
onChange: _pt.func,
|
|
217
|
+
selectedLanguage: _pt.string.isRequired,
|
|
218
|
+
onBlur: _pt.func,
|
|
219
|
+
onFocus: _pt.func,
|
|
220
|
+
hideLanguageExpansionControls: _pt.bool,
|
|
221
|
+
defaultExpandLanguages: _pt.bool,
|
|
222
|
+
isAutofocussed: _pt.bool,
|
|
223
|
+
isDisabled: _pt.bool,
|
|
224
|
+
isReadOnly: _pt.bool,
|
|
225
|
+
placeholder: _pt.objectOf(_pt.string),
|
|
226
|
+
horizontalConstraint: _pt.oneOf([1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 'scale', 'auto']),
|
|
227
|
+
hasError: _pt.bool,
|
|
228
|
+
errors: _pt.objectOf(_pt.string)
|
|
307
229
|
} : {};
|
|
230
|
+
LocalizedTextInput.displayName = 'LocalizedTextInput';
|
|
231
|
+
LocalizedTextInput.RequiredValueErrorMessage = RequiredValueErrorMessage;
|
|
308
232
|
LocalizedTextInput.defaultProps = {
|
|
309
233
|
horizontalConstraint: 'scale'
|
|
310
234
|
};
|
|
@@ -317,6 +241,6 @@ LocalizedTextInput.isTouched = isTouched;
|
|
|
317
241
|
var LocalizedTextInput$1 = LocalizedTextInput;
|
|
318
242
|
|
|
319
243
|
// NOTE: This string will be replaced on build time with the package version.
|
|
320
|
-
var version = "13.0.
|
|
244
|
+
var version = "13.0.2";
|
|
321
245
|
|
|
322
246
|
export { LocalizedTextInput$1 as default, version };
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import { type FocusEventHandler, type ChangeEventHandler } from 'react';
|
|
2
|
+
declare type TLocalizedTextInputProps = {
|
|
3
|
+
id?: string;
|
|
4
|
+
name?: string;
|
|
5
|
+
autoComplete?: string;
|
|
6
|
+
value: Record<string, string>;
|
|
7
|
+
onChange?: ChangeEventHandler;
|
|
8
|
+
selectedLanguage: string;
|
|
9
|
+
onBlur?: FocusEventHandler;
|
|
10
|
+
onFocus?: FocusEventHandler;
|
|
11
|
+
hideLanguageExpansionControls?: boolean;
|
|
12
|
+
defaultExpandLanguages?: boolean;
|
|
13
|
+
isAutofocussed?: boolean;
|
|
14
|
+
isDisabled?: boolean;
|
|
15
|
+
isReadOnly?: boolean;
|
|
16
|
+
placeholder?: Record<string, string>;
|
|
17
|
+
horizontalConstraint?: 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 'scale' | 'auto';
|
|
18
|
+
hasError?: boolean;
|
|
19
|
+
errors?: Record<string, string>;
|
|
20
|
+
};
|
|
21
|
+
declare const LocalizedTextInput: {
|
|
22
|
+
(props: TLocalizedTextInputProps): import("@emotion/react/jsx-runtime").JSX.Element;
|
|
23
|
+
displayName: string;
|
|
24
|
+
RequiredValueErrorMessage: {
|
|
25
|
+
(): import("@emotion/react/jsx-runtime").JSX.Element;
|
|
26
|
+
displayName: string;
|
|
27
|
+
};
|
|
28
|
+
defaultProps: {
|
|
29
|
+
horizontalConstraint: string;
|
|
30
|
+
};
|
|
31
|
+
getId: (idPrefix?: string | undefined, language?: string | undefined) => string | undefined;
|
|
32
|
+
getName: (namePrefix?: string | undefined, language?: string | undefined) => string | undefined;
|
|
33
|
+
createLocalizedString: (languages: string[], existingTranslations?: {
|
|
34
|
+
[locale: string]: string;
|
|
35
|
+
}) => {
|
|
36
|
+
[locale: string]: string;
|
|
37
|
+
};
|
|
38
|
+
isEmpty: (localizedString?: {
|
|
39
|
+
[locale: string]: string;
|
|
40
|
+
} | undefined) => boolean;
|
|
41
|
+
omitEmptyTranslations: <TTranslations extends {
|
|
42
|
+
[locale: string]: string;
|
|
43
|
+
}>(localizedString: TTranslations) => {
|
|
44
|
+
[locale: string]: string;
|
|
45
|
+
};
|
|
46
|
+
isTouched: (touched?: {
|
|
47
|
+
[locale: string]: boolean;
|
|
48
|
+
} | undefined) => boolean;
|
|
49
|
+
};
|
|
50
|
+
export default LocalizedTextInput;
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import { type Theme } from '@emotion/react';
|
|
2
|
+
declare const getLocalizedInputStyles: () => import("@emotion/utils").SerializedStyles[];
|
|
3
|
+
declare const getLanguageLabelStyles: (_props: unknown, theme: Theme) => import("@emotion/utils").SerializedStyles;
|
|
4
|
+
export { getLocalizedInputStyles, getLanguageLabelStyles };
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@commercetools-uikit/localized-text-input",
|
|
3
3
|
"description": "A controlled text input component for localized single-line strings with validation states.",
|
|
4
|
-
"version": "13.0.
|
|
4
|
+
"version": "13.0.2",
|
|
5
5
|
"bugs": "https://github.com/commercetools/ui-kit/issues",
|
|
6
6
|
"repository": {
|
|
7
7
|
"type": "git",
|
|
@@ -21,18 +21,18 @@
|
|
|
21
21
|
"dependencies": {
|
|
22
22
|
"@babel/runtime": "7.17.2",
|
|
23
23
|
"@babel/runtime-corejs3": "7.17.2",
|
|
24
|
-
"@commercetools-uikit/constraints": "13.0.
|
|
24
|
+
"@commercetools-uikit/constraints": "13.0.2",
|
|
25
25
|
"@commercetools-uikit/design-system": "13.0.0",
|
|
26
|
-
"@commercetools-uikit/flat-button": "13.0.
|
|
27
|
-
"@commercetools-uikit/hooks": "
|
|
28
|
-
"@commercetools-uikit/icons": "13.0.
|
|
29
|
-
"@commercetools-uikit/input-utils": "13.0.
|
|
30
|
-
"@commercetools-uikit/localized-utils": "
|
|
31
|
-
"@commercetools-uikit/messages": "13.0.
|
|
32
|
-
"@commercetools-uikit/spacings-stack": "13.0.
|
|
33
|
-
"@commercetools-uikit/text": "13.0.
|
|
34
|
-
"@commercetools-uikit/text-input": "13.0.
|
|
35
|
-
"@commercetools-uikit/utils": "
|
|
26
|
+
"@commercetools-uikit/flat-button": "13.0.2",
|
|
27
|
+
"@commercetools-uikit/hooks": "13.0.2",
|
|
28
|
+
"@commercetools-uikit/icons": "13.0.2",
|
|
29
|
+
"@commercetools-uikit/input-utils": "13.0.2",
|
|
30
|
+
"@commercetools-uikit/localized-utils": "13.0.2",
|
|
31
|
+
"@commercetools-uikit/messages": "13.0.2",
|
|
32
|
+
"@commercetools-uikit/spacings-stack": "13.0.2",
|
|
33
|
+
"@commercetools-uikit/text": "13.0.2",
|
|
34
|
+
"@commercetools-uikit/text-input": "13.0.2",
|
|
35
|
+
"@commercetools-uikit/utils": "13.0.2",
|
|
36
36
|
"@emotion/react": "^11.4.0",
|
|
37
37
|
"@emotion/styled": "^11.3.0",
|
|
38
38
|
"common-tags": "1.8.2",
|