@wireapp/react-ui-kit 8.1.0 → 8.4.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +36 -3
- package/package.json +4 -4
- package/src/Form/Button.d.js +4 -0
- package/src/Form/Button.d.ts +8 -0
- package/src/Form/Button.js +83 -20
- package/src/Form/Button.js.map +1 -1
- package/src/Form/Button.md +61 -2
- package/src/Form/Checkbox.js +44 -22
- package/src/Form/Checkbox.js.map +1 -1
- package/src/Form/CodeInput.js +10 -4
- package/src/Form/CodeInput.js.map +1 -1
- package/src/Form/CodeInput.md +9 -1
- package/src/Form/ErrorMessage.js +18 -12
- package/src/Form/ErrorMessage.js.map +1 -1
- package/src/Form/Form.md +23 -0
- package/src/Form/Input.d.ts +6 -2
- package/src/Form/Input.js +101 -16
- package/src/Form/Input.js.map +1 -1
- package/src/Form/InputBlock.js +7 -3
- package/src/Form/InputBlock.js.map +1 -1
- package/src/Form/InputLabel.d.js +2 -0
- package/src/Form/InputLabel.d.js.map +1 -0
- package/src/Form/InputLabel.d.ts +9 -0
- package/src/Form/InputLabel.js +47 -0
- package/src/Form/InputLabel.js.map +1 -0
- package/src/Form/InputLabel.md +33 -0
- package/src/Form/InputSubmitCombo.js +5 -4
- package/src/Form/InputSubmitCombo.js.map +1 -1
- package/src/Form/Select.d.ts +6 -2
- package/src/Form/Select.js +57 -12
- package/src/Form/Select.js.map +1 -1
- package/src/Form/Select.md +25 -4
- package/src/Form/TextArea.js +1 -1
- package/src/Form/TextArea.js.map +1 -1
- package/src/Form/index.d.js +13 -0
- package/src/Form/index.d.js.map +1 -1
- package/src/Form/index.d.ts +1 -0
- package/src/Form/index.js +13 -0
- package/src/Form/index.js.map +1 -1
- package/src/Icon/HideIcon.js +1 -1
- package/src/Icon/HideIcon.js.map +1 -1
- package/src/Icon/ShowIcon.js +1 -1
- package/src/Icon/ShowIcon.js.map +1 -1
- package/src/Identity/colors-v2.d.ts +1 -1
- package/src/Identity/colors-v2.js +3 -3
- package/src/Identity/colors-v2.js.map +1 -1
- package/src/Identity/colors-v2.md +1 -1
- package/src/Identity/index.d.js +13 -0
- package/src/Identity/index.d.js.map +1 -1
- package/src/Identity/index.d.ts +1 -0
- package/src/Identity/index.js +13 -0
- package/src/Identity/index.js.map +1 -1
- package/src/Layout/Theme.js +3 -1
- package/src/Layout/Theme.js.map +1 -1
- package/src/Misc/ButtonGroup.d.js +2 -0
- package/src/Misc/ButtonGroup.d.js.map +1 -0
- package/src/Misc/ButtonGroup.d.ts +14 -0
- package/src/Misc/ButtonGroup.js +113 -0
- package/src/Misc/ButtonGroup.js.map +1 -0
- package/src/Misc/ButtonGroup.md +27 -0
- package/src/Misc/IconButton.d.js +6 -0
- package/src/Misc/IconButton.d.js.map +1 -0
- package/src/Misc/IconButton.d.ts +15 -0
- package/src/Misc/IconButton.js +122 -0
- package/src/Misc/IconButton.js.map +1 -0
- package/src/Misc/IconButton.md +43 -0
- package/src/Misc/childrenWithDefaultProps.d.ts +1 -1
- package/src/Misc/index.d.js +26 -0
- package/src/Misc/index.d.js.map +1 -1
- package/src/Misc/index.d.ts +2 -0
- package/src/Misc/index.js +26 -0
- package/src/Misc/index.js.map +1 -1
- package/src/Text/Label.md +18 -18
- package/src/Text/TextLink.js +2 -2
- package/src/Text/TextLink.js.map +1 -1
package/src/Form/CodeInput.js
CHANGED
|
@@ -23,6 +23,8 @@ var _util = require("../util");
|
|
|
23
23
|
|
|
24
24
|
var _Input = require("./Input");
|
|
25
25
|
|
|
26
|
+
var _Identity = require("../Identity");
|
|
27
|
+
|
|
26
28
|
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
27
29
|
|
|
28
30
|
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
@@ -39,7 +41,7 @@ var _ref = process.env.NODE_ENV === "production" ? {
|
|
|
39
41
|
} : {
|
|
40
42
|
name: "tvpiqi-CodeInputWrapper",
|
|
41
43
|
styles: "display:flex;justify-content:center;label:CodeInputWrapper;",
|
|
42
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
44
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNvZGVJbnB1dC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBOEJJIiwiZmlsZSI6IkNvZGVJbnB1dC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogV2lyZVxuICogQ29weXJpZ2h0IChDKSAyMDE4IFdpcmUgU3dpc3MgR21iSFxuICpcbiAqIFRoaXMgcHJvZ3JhbSBpcyBmcmVlIHNvZnR3YXJlOiB5b3UgY2FuIHJlZGlzdHJpYnV0ZSBpdCBhbmQvb3IgbW9kaWZ5XG4gKiBpdCB1bmRlciB0aGUgdGVybXMgb2YgdGhlIEdOVSBHZW5lcmFsIFB1YmxpYyBMaWNlbnNlIGFzIHB1Ymxpc2hlZCBieVxuICogdGhlIEZyZWUgU29mdHdhcmUgRm91bmRhdGlvbiwgZWl0aGVyIHZlcnNpb24gMyBvZiB0aGUgTGljZW5zZSwgb3JcbiAqIChhdCB5b3VyIG9wdGlvbikgYW55IGxhdGVyIHZlcnNpb24uXG4gKlxuICogVGhpcyBwcm9ncmFtIGlzIGRpc3RyaWJ1dGVkIGluIHRoZSBob3BlIHRoYXQgaXQgd2lsbCBiZSB1c2VmdWwsXG4gKiBidXQgV0lUSE9VVCBBTlkgV0FSUkFOVFk7IHdpdGhvdXQgZXZlbiB0aGUgaW1wbGllZCB3YXJyYW50eSBvZlxuICogTUVSQ0hBTlRBQklMSVRZIG9yIEZJVE5FU1MgRk9SIEEgUEFSVElDVUxBUiBQVVJQT1NFLiBTZWUgdGhlXG4gKiBHTlUgR2VuZXJhbCBQdWJsaWMgTGljZW5zZSBmb3IgbW9yZSBkZXRhaWxzLlxuICpcbiAqIFlvdSBzaG91bGQgaGF2ZSByZWNlaXZlZCBhIGNvcHkgb2YgdGhlIEdOVSBHZW5lcmFsIFB1YmxpYyBMaWNlbnNlXG4gKiBhbG9uZyB3aXRoIHRoaXMgcHJvZ3JhbS4gSWYgbm90LCBzZWUgaHR0cDovL3d3dy5nbnUub3JnL2xpY2Vuc2VzLy5cbiAqXG4gKi9cblxuLyoqIEBqc3gganN4ICovXG5pbXBvcnQge0NTU09iamVjdCwganN4fSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgUmVhY3QsIHt1c2VFZmZlY3QsIHVzZVN0YXRlfSBmcm9tICdyZWFjdCc7XG5cbmltcG9ydCB0eXBlIHtUaGVtZX0gZnJvbSAnLi4vTGF5b3V0JztcbmltcG9ydCB7bm9vcH0gZnJvbSAnLi4vdXRpbCc7XG5pbXBvcnQge0lucHV0UHJvcHMsIGlucHV0U3R5bGV9IGZyb20gJy4vSW5wdXQnO1xuaW1wb3J0IHtDT0xPUl9WMn0gZnJvbSAnLi4vSWRlbnRpdHknO1xuXG5jb25zdCBDb2RlSW5wdXRXcmFwcGVyID0gKHByb3BzOiBSZWFjdC5IVE1MUHJvcHM8SFRNTERpdkVsZW1lbnQ+KSA9PiAoXG4gIDxkaXZcbiAgICBjc3M9e3tcbiAgICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICAgIGp1c3RpZnlDb250ZW50OiAnY2VudGVyJyxcbiAgICB9fVxuICAgIHsuLi5wcm9wc31cbiAgLz5cbik7XG5cbnR5cGUgRGlnaXRJbnB1dFByb3BzPFQgPSBIVE1MSW5wdXRFbGVtZW50PiA9IElucHV0UHJvcHM8VD47XG5cbmNvbnN0IGRpZ2l0SW5wdXRTdHlsZTogPFQ+KHRoZW1lOiBUaGVtZSwgcHJvcHM6IERpZ2l0SW5wdXRQcm9wczxUPikgPT4gQ1NTT2JqZWN0ID0gKHRoZW1lLCBwcm9wcykgPT4gKHtcbiAgLi4uaW5wdXRTdHlsZSh0aGVtZSwgcHJvcHMpLFxuICAnJiArICYnOiB7XG4gICAgbWFyZ2luTGVmdDogJzE5cHgnLFxuICB9LFxuICAnJjpob3Zlcic6IHtcbiAgICBib3hTaGFkb3c6IGAwIDAgMCAxcHggJHtDT0xPUl9WMi5HUkFZXzYwfWAsXG4gIH0sXG4gIGZvbnRTaXplOiAnMjRweCcsXG4gIGxpbmVIZWlnaHQ6ICcyOHB4JyxcbiAgcGFkZGluZzogMCxcbiAgdGV4dEFsaWduOiAnY2VudGVyJyxcbiAgd2lkdGg6ICc0OHB4JyxcbiAgaGVpZ2h0OiAnNTZweCcsXG59KTtcblxuY29uc3QgRGlnaXRJbnB1dDogUmVhY3QuRkM8RGlnaXRJbnB1dFByb3BzPEhUTUxJbnB1dEVsZW1lbnQ+PiA9IFJlYWN0LmZvcndhcmRSZWY8XG4gIEhUTUxJbnB1dEVsZW1lbnQsXG4gIERpZ2l0SW5wdXRQcm9wczxIVE1MSW5wdXRFbGVtZW50PlxuPigocHJvcHMsIHJlZikgPT4gPGlucHV0IHJlZj17cmVmfSBjc3M9eyh0aGVtZTogVGhlbWUpID0+IGRpZ2l0SW5wdXRTdHlsZSh0aGVtZSwgcHJvcHMpfSB7Li4ucHJvcHN9IHR5cGU9XCJ0ZWxcIiAvPik7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ29kZUlucHV0UHJvcHM8VCA9IEhUTUxJbnB1dEVsZW1lbnQ+IGV4dGVuZHMgSW5wdXRQcm9wczxUPiB7XG4gIGF1dG9Gb2N1cz86IGJvb2xlYW47XG4gIGRpZ2l0cz86IG51bWJlcjtcbiAgbWFya0ludmFsaWQ/OiBib29sZWFuO1xuICBvbkNvZGVDb21wbGV0ZT86IChjb21wbGV0ZUNvZGU/OiBzdHJpbmcpID0+IHZvaWQ7XG59XG5cbmV4cG9ydCBjb25zdCBDb2RlSW5wdXQgPSAoe1xuICBzdHlsZSxcbiAgZGlnaXRzID0gNixcbiAgYXV0b0ZvY3VzID0gZmFsc2UsXG4gIG1hcmtJbnZhbGlkLFxuICBvbkNvZGVDb21wbGV0ZSA9IG5vb3AsXG4gIGRpc2FibGVkLFxufTogQ29kZUlucHV0UHJvcHMpID0+IHtcbiAgY29uc3QgW3ZhbHVlcywgc2V0VmFsdWVzXSA9IHVzZVN0YXRlKEFycmF5KGRpZ2l0cykuZmlsbCgnJykpO1xuICBjb25zdCBpbnB1dHMgPSBBcnJheShkaWdpdHMpO1xuXG4gIGNvbnN0IGZvcmNlU2VsZWN0aW9uID0gKFxuICAgIGV2ZW50OlxuICAgICAgfCBSZWFjdC5Nb3VzZUV2ZW50PEhUTUxJbnB1dEVsZW1lbnQ+XG4gICAgICB8IFJlYWN0LlRvdWNoRXZlbnQ8SFRNTElucHV0RWxlbWVudD5cbiAgICAgIHwgUmVhY3QuS2V5Ym9hcmRFdmVudDxIVE1MSW5wdXRFbGVtZW50PlxuICAgICAgfCBSZWFjdC5Gb2N1c0V2ZW50PEhUTUxJbnB1dEVsZW1lbnQ+LFxuICApID0+IHtcbiAgICBjb25zdCB0YXJnZXQgPSBldmVudC50YXJnZXQgYXMgSFRNTElucHV0RWxlbWVudDtcbiAgICB0YXJnZXQuc2VsZWN0KCk7XG4gIH07XG5cbiAgY29uc3QgZm9yY2VTZWxlY3Rpb25QcmV2ZW50RGVmYXVsdCA9IChcbiAgICBldmVudDogUmVhY3QuTW91c2VFdmVudDxIVE1MSW5wdXRFbGVtZW50PiB8IFJlYWN0LlRvdWNoRXZlbnQ8SFRNTElucHV0RWxlbWVudD4sXG4gICkgPT4ge1xuICAgIGZvcmNlU2VsZWN0aW9uKGV2ZW50KTtcbiAgICBldmVudC5wcmV2ZW50RGVmYXVsdCgpO1xuICB9O1xuXG4gIGNvbnN0IG5leHRGaWVsZCA9IChjdXJyZW50RmllbGRJbmRleDogbnVtYmVyKSA9PiB7XG4gICAgY29uc3QgbmV4dEZpZWxkSW5kZXggPSBjdXJyZW50RmllbGRJbmRleCArIDE7XG4gICAgaWYgKG5leHRGaWVsZEluZGV4IDwgZGlnaXRzKSB7XG4gICAgICBpbnB1dHNbbmV4dEZpZWxkSW5kZXhdLmZvY3VzKCk7XG4gICAgfVxuICB9O1xuXG4gIGNvbnN0IHByZXZpb3VzRmllbGQgPSAoY3VycmVudEZpZWxkSW5kZXg6IG51bWJlcikgPT4ge1xuICAgIGlmIChjdXJyZW50RmllbGRJbmRleCA+IDApIHtcbiAgICAgIGlucHV0c1tjdXJyZW50RmllbGRJbmRleCAtIDFdLmZvY3VzKCk7XG4gICAgfVxuICB9O1xuXG4gIGNvbnN0IHNldFZhbHVlID0gKGZpZWxkSW5kZXg6IG51bWJlciwgdmFsdWU6IHN0cmluZykgPT4ge1xuICAgIGlmICgvXlswLTldPyQvLnRlc3QodmFsdWUpKSB7XG4gICAgICBjb25zdCB2YWx1ZXNDb3B5ID0gdmFsdWVzLnNsaWNlKCk7XG4gICAgICB2YWx1ZXNDb3B5W2ZpZWxkSW5kZXhdID0gdmFsdWU7XG4gICAgICBzZXRWYWx1ZXModmFsdWVzQ29weSk7XG4gICAgICBpZiAodmFsdWUubGVuZ3RoKSB7XG4gICAgICAgIG5leHRGaWVsZChmaWVsZEluZGV4KTtcbiAgICAgIH1cbiAgICB9XG4gIH07XG5cbiAgY29uc3QgaGFuZGxlS2V5RG93biA9IChmaWVsZEluZGV4OiBudW1iZXIsIHtrZXl9OiBSZWFjdC5LZXlib2FyZEV2ZW50PEhUTUxJbnB1dEVsZW1lbnQ+KSA9PiB7XG4gICAgc3dpdGNoIChrZXkpIHtcbiAgICAgIGNhc2UgJ0JhY2tzcGFjZSc6XG4gICAgICAgIHNldFZhbHVlKGZpZWxkSW5kZXgsICcnKTtcbiAgICAgICAgcHJldmlvdXNGaWVsZChmaWVsZEluZGV4KTtcbiAgICAgICAgYnJlYWs7XG4gICAgICBjYXNlICdBcnJvd0xlZnQnOlxuICAgICAgICBwcmV2aW91c0ZpZWxkKGZpZWxkSW5kZXgpO1xuICAgICAgICBicmVhaztcbiAgICAgIGNhc2UgJ0Fycm93UmlnaHQnOlxuICAgICAgICBuZXh0RmllbGQoZmllbGRJbmRleCk7XG4gICAgICAgIGJyZWFrO1xuICAgIH1cbiAgICBpZiAoL15bMC05XSQvLnRlc3Qoa2V5KSkge1xuICAgICAgc2V0VmFsdWUoZmllbGRJbmRleCwga2V5KTtcbiAgICB9XG4gIH07XG5cbiAgY29uc3QgaGFuZGxlUGFzdGUgPSAoZmllbGRJbmRleDogbnVtYmVyLCBldmVudDogUmVhY3QuQ2xpcGJvYXJkRXZlbnQ8SFRNTElucHV0RWxlbWVudD4pID0+IHtcbiAgICBjb25zdCBwYXN0ZWRWYWx1ZSA9IGV2ZW50LmNsaXBib2FyZERhdGEuZ2V0RGF0YSgnVGV4dCcpO1xuICAgIGNvbnN0IGNsZWFuZWRQYXN0ZSA9IHBhc3RlZFZhbHVlLnJlcGxhY2UoL1teMC05XS9nLCAnJyk7XG4gICAgaWYgKC9eWzAtOV0rJC8udGVzdChjbGVhbmVkUGFzdGUpKSB7XG4gICAgICBzZXRWYWx1ZXModmFsdWVzLnNsaWNlKDAsIGZpZWxkSW5kZXgpLmNvbmNhdChjbGVhbmVkUGFzdGUuc3BsaXQoJycpKS5zbGljZSgwLCBkaWdpdHMpKTtcbiAgICB9XG4gIH07XG5cbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBjb25zdCBjb21wbGV0ZUNvZGUgPSB2YWx1ZXMuam9pbignJyk7XG4gICAgaWYgKGNvbXBsZXRlQ29kZS5sZW5ndGggPT09IGRpZ2l0cykge1xuICAgICAgb25Db2RlQ29tcGxldGUoY29tcGxldGVDb2RlKTtcbiAgICB9XG4gIH0sIFt2YWx1ZXNdKTtcblxuICByZXR1cm4gKFxuICAgIDxDb2RlSW5wdXRXcmFwcGVyIHN0eWxlPXtzdHlsZX0+XG4gICAgICB7QXJyYXkuZnJvbSh7bGVuZ3RoOiBkaWdpdHN9LCAoXywgaW5kZXgpID0+IChcbiAgICAgICAgPERpZ2l0SW5wdXRcbiAgICAgICAgICBhdXRvRm9jdXM9e2luZGV4ID09PSAwICYmIGF1dG9Gb2N1c31cbiAgICAgICAgICBrZXk9e2luZGV4fVxuICAgICAgICAgIG9uUGFzdGU9e2V2ZW50ID0+IGhhbmRsZVBhc3RlKGluZGV4LCBldmVudCl9XG4gICAgICAgICAgb25Gb2N1cz17Zm9yY2VTZWxlY3Rpb259XG4gICAgICAgICAgb25Nb3VzZURvd249e2ZvcmNlU2VsZWN0aW9uUHJldmVudERlZmF1bHR9XG4gICAgICAgICAgb25Ub3VjaFN0YXJ0PXtmb3JjZVNlbGVjdGlvblByZXZlbnREZWZhdWx0fVxuICAgICAgICAgIG9uS2V5RG93bj17ZXZlbnQgPT4gaGFuZGxlS2V5RG93bihpbmRleCwgZXZlbnQpfVxuICAgICAgICAgIG9uS2V5VXA9e2ZvcmNlU2VsZWN0aW9ufVxuICAgICAgICAgIG1hcmtJbnZhbGlkPXttYXJrSW52YWxpZH1cbiAgICAgICAgICByZWY9e25vZGUgPT4gKGlucHV0c1tpbmRleF0gPSBub2RlKX1cbiAgICAgICAgICB2YWx1ZT17dmFsdWVzW2luZGV4XX1cbiAgICAgICAgICBvbkNoYW5nZT17KCkgPT4ge319XG4gICAgICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgICAvPlxuICAgICAgKSl9XG4gICAgPC9Db2RlSW5wdXRXcmFwcGVyPlxuICApO1xufTtcbiJdfQ== */",
|
|
43
45
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
44
46
|
};
|
|
45
47
|
|
|
@@ -54,11 +56,15 @@ var digitInputStyle = function digitInputStyle(theme, props) {
|
|
|
54
56
|
'& + &': {
|
|
55
57
|
marginLeft: '19px'
|
|
56
58
|
},
|
|
57
|
-
|
|
58
|
-
|
|
59
|
+
'&:hover': {
|
|
60
|
+
boxShadow: "0 0 0 1px ".concat(_Identity.COLOR_V2.GRAY_60)
|
|
61
|
+
},
|
|
62
|
+
fontSize: '24px',
|
|
63
|
+
lineHeight: '28px',
|
|
59
64
|
padding: 0,
|
|
60
65
|
textAlign: 'center',
|
|
61
|
-
width: '48px'
|
|
66
|
+
width: '48px',
|
|
67
|
+
height: '56px'
|
|
62
68
|
});
|
|
63
69
|
};
|
|
64
70
|
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["CodeInput.tsx"],"names":["CodeInputWrapper","props","digitInputStyle","theme","marginLeft","fontSize","lineHeight","padding","textAlign","width","DigitInput","React","forwardRef","ref","CodeInput","style","digits","autoFocus","markInvalid","onCodeComplete","noop","disabled","Array","fill","values","setValues","inputs","forceSelection","event","target","select","forceSelectionPreventDefault","preventDefault","nextField","currentFieldIndex","nextFieldIndex","focus","previousField","setValue","fieldIndex","value","test","valuesCopy","slice","length","handleKeyDown","key","handlePaste","pastedValue","clipboardData","getData","cleanedPaste","replace","concat","split","completeCode","join","from","_","index","node"],"mappings":"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","sourcesContent":["/*\n * Wire\n * Copyright (C) 2018 Wire Swiss GmbH\n *\n * This program is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * This program is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n *\n * You should have received a copy of the GNU General Public License\n * along with this program. If not, see http://www.gnu.org/licenses/.\n *\n */\n\n/** @jsx jsx */\nimport {CSSObject, jsx} from '@emotion/react';\nimport React, {useEffect, useState} from 'react';\n\nimport type {Theme} from '../Layout';\nimport {noop} from '../util';\nimport {InputProps, inputStyle} from './Input';\n\nconst CodeInputWrapper = (props: React.HTMLProps<HTMLDivElement>) => (\n <div\n css={{\n display: 'flex',\n justifyContent: 'center',\n }}\n {...props}\n />\n);\n\ntype DigitInputProps<T = HTMLInputElement> = InputProps<T>;\n\nconst digitInputStyle: <T>(theme: Theme, props: DigitInputProps<T>) => CSSObject = (theme, props) => ({\n ...inputStyle(theme, props),\n '& + &': {\n marginLeft: '19px',\n },\n fontSize: '32px',\n lineHeight: '56px',\n padding: 0,\n textAlign: 'center',\n width: '48px',\n});\n\nconst DigitInput: React.FC<DigitInputProps<HTMLInputElement>> = React.forwardRef<\n HTMLInputElement,\n DigitInputProps<HTMLInputElement>\n>((props, ref) => <input ref={ref} css={(theme: Theme) => digitInputStyle(theme, props)} {...props} type=\"tel\" />);\n\nexport interface CodeInputProps<T = HTMLInputElement> extends InputProps<T> {\n autoFocus?: boolean;\n digits?: number;\n markInvalid?: boolean;\n onCodeComplete?: (completeCode?: string) => void;\n}\n\nexport const CodeInput = ({\n style,\n digits = 6,\n autoFocus = false,\n markInvalid,\n onCodeComplete = noop,\n disabled,\n}: CodeInputProps) => {\n const [values, setValues] = useState(Array(digits).fill(''));\n const inputs = Array(digits);\n\n const forceSelection = (\n event:\n | React.MouseEvent<HTMLInputElement>\n | React.TouchEvent<HTMLInputElement>\n | React.KeyboardEvent<HTMLInputElement>\n | React.FocusEvent<HTMLInputElement>,\n ) => {\n const target = event.target as HTMLInputElement;\n target.select();\n };\n\n const forceSelectionPreventDefault = (\n event: React.MouseEvent<HTMLInputElement> | React.TouchEvent<HTMLInputElement>,\n ) => {\n forceSelection(event);\n event.preventDefault();\n };\n\n const nextField = (currentFieldIndex: number) => {\n const nextFieldIndex = currentFieldIndex + 1;\n if (nextFieldIndex < digits) {\n inputs[nextFieldIndex].focus();\n }\n };\n\n const previousField = (currentFieldIndex: number) => {\n if (currentFieldIndex > 0) {\n inputs[currentFieldIndex - 1].focus();\n }\n };\n\n const setValue = (fieldIndex: number, value: string) => {\n if (/^[0-9]?$/.test(value)) {\n const valuesCopy = values.slice();\n valuesCopy[fieldIndex] = value;\n setValues(valuesCopy);\n if (value.length) {\n nextField(fieldIndex);\n }\n }\n };\n\n const handleKeyDown = (fieldIndex: number, {key}: React.KeyboardEvent<HTMLInputElement>) => {\n switch (key) {\n case 'Backspace':\n setValue(fieldIndex, '');\n previousField(fieldIndex);\n break;\n case 'ArrowLeft':\n previousField(fieldIndex);\n break;\n case 'ArrowRight':\n nextField(fieldIndex);\n break;\n }\n if (/^[0-9]$/.test(key)) {\n setValue(fieldIndex, key);\n }\n };\n\n const handlePaste = (fieldIndex: number, event: React.ClipboardEvent<HTMLInputElement>) => {\n const pastedValue = event.clipboardData.getData('Text');\n const cleanedPaste = pastedValue.replace(/[^0-9]/g, '');\n if (/^[0-9]+$/.test(cleanedPaste)) {\n setValues(values.slice(0, fieldIndex).concat(cleanedPaste.split('')).slice(0, digits));\n }\n };\n\n useEffect(() => {\n const completeCode = values.join('');\n if (completeCode.length === digits) {\n onCodeComplete(completeCode);\n }\n }, [values]);\n\n return (\n <CodeInputWrapper style={style}>\n {Array.from({length: digits}, (_, index) => (\n <DigitInput\n autoFocus={index === 0 && autoFocus}\n key={index}\n onPaste={event => handlePaste(index, event)}\n onFocus={forceSelection}\n onMouseDown={forceSelectionPreventDefault}\n onTouchStart={forceSelectionPreventDefault}\n onKeyDown={event => handleKeyDown(index, event)}\n onKeyUp={forceSelection}\n markInvalid={markInvalid}\n ref={node => (inputs[index] = node)}\n value={values[index]}\n onChange={() => {}}\n disabled={disabled}\n />\n ))}\n </CodeInputWrapper>\n );\n};\n"],"file":"CodeInput.js"}
|
|
1
|
+
{"version":3,"sources":["CodeInput.tsx"],"names":["CodeInputWrapper","props","digitInputStyle","theme","marginLeft","boxShadow","COLOR_V2","GRAY_60","fontSize","lineHeight","padding","textAlign","width","height","DigitInput","React","forwardRef","ref","CodeInput","style","digits","autoFocus","markInvalid","onCodeComplete","noop","disabled","Array","fill","values","setValues","inputs","forceSelection","event","target","select","forceSelectionPreventDefault","preventDefault","nextField","currentFieldIndex","nextFieldIndex","focus","previousField","setValue","fieldIndex","value","test","valuesCopy","slice","length","handleKeyDown","key","handlePaste","pastedValue","clipboardData","getData","cleanedPaste","replace","concat","split","completeCode","join","from","_","index","node"],"mappings":"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","sourcesContent":["/*\n * Wire\n * Copyright (C) 2018 Wire Swiss GmbH\n *\n * This program is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * This program is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n *\n * You should have received a copy of the GNU General Public License\n * along with this program. If not, see http://www.gnu.org/licenses/.\n *\n */\n\n/** @jsx jsx */\nimport {CSSObject, jsx} from '@emotion/react';\nimport React, {useEffect, useState} from 'react';\n\nimport type {Theme} from '../Layout';\nimport {noop} from '../util';\nimport {InputProps, inputStyle} from './Input';\nimport {COLOR_V2} from '../Identity';\n\nconst CodeInputWrapper = (props: React.HTMLProps<HTMLDivElement>) => (\n <div\n css={{\n display: 'flex',\n justifyContent: 'center',\n }}\n {...props}\n />\n);\n\ntype DigitInputProps<T = HTMLInputElement> = InputProps<T>;\n\nconst digitInputStyle: <T>(theme: Theme, props: DigitInputProps<T>) => CSSObject = (theme, props) => ({\n ...inputStyle(theme, props),\n '& + &': {\n marginLeft: '19px',\n },\n '&:hover': {\n boxShadow: `0 0 0 1px ${COLOR_V2.GRAY_60}`,\n },\n fontSize: '24px',\n lineHeight: '28px',\n padding: 0,\n textAlign: 'center',\n width: '48px',\n height: '56px',\n});\n\nconst DigitInput: React.FC<DigitInputProps<HTMLInputElement>> = React.forwardRef<\n HTMLInputElement,\n DigitInputProps<HTMLInputElement>\n>((props, ref) => <input ref={ref} css={(theme: Theme) => digitInputStyle(theme, props)} {...props} type=\"tel\" />);\n\nexport interface CodeInputProps<T = HTMLInputElement> extends InputProps<T> {\n autoFocus?: boolean;\n digits?: number;\n markInvalid?: boolean;\n onCodeComplete?: (completeCode?: string) => void;\n}\n\nexport const CodeInput = ({\n style,\n digits = 6,\n autoFocus = false,\n markInvalid,\n onCodeComplete = noop,\n disabled,\n}: CodeInputProps) => {\n const [values, setValues] = useState(Array(digits).fill(''));\n const inputs = Array(digits);\n\n const forceSelection = (\n event:\n | React.MouseEvent<HTMLInputElement>\n | React.TouchEvent<HTMLInputElement>\n | React.KeyboardEvent<HTMLInputElement>\n | React.FocusEvent<HTMLInputElement>,\n ) => {\n const target = event.target as HTMLInputElement;\n target.select();\n };\n\n const forceSelectionPreventDefault = (\n event: React.MouseEvent<HTMLInputElement> | React.TouchEvent<HTMLInputElement>,\n ) => {\n forceSelection(event);\n event.preventDefault();\n };\n\n const nextField = (currentFieldIndex: number) => {\n const nextFieldIndex = currentFieldIndex + 1;\n if (nextFieldIndex < digits) {\n inputs[nextFieldIndex].focus();\n }\n };\n\n const previousField = (currentFieldIndex: number) => {\n if (currentFieldIndex > 0) {\n inputs[currentFieldIndex - 1].focus();\n }\n };\n\n const setValue = (fieldIndex: number, value: string) => {\n if (/^[0-9]?$/.test(value)) {\n const valuesCopy = values.slice();\n valuesCopy[fieldIndex] = value;\n setValues(valuesCopy);\n if (value.length) {\n nextField(fieldIndex);\n }\n }\n };\n\n const handleKeyDown = (fieldIndex: number, {key}: React.KeyboardEvent<HTMLInputElement>) => {\n switch (key) {\n case 'Backspace':\n setValue(fieldIndex, '');\n previousField(fieldIndex);\n break;\n case 'ArrowLeft':\n previousField(fieldIndex);\n break;\n case 'ArrowRight':\n nextField(fieldIndex);\n break;\n }\n if (/^[0-9]$/.test(key)) {\n setValue(fieldIndex, key);\n }\n };\n\n const handlePaste = (fieldIndex: number, event: React.ClipboardEvent<HTMLInputElement>) => {\n const pastedValue = event.clipboardData.getData('Text');\n const cleanedPaste = pastedValue.replace(/[^0-9]/g, '');\n if (/^[0-9]+$/.test(cleanedPaste)) {\n setValues(values.slice(0, fieldIndex).concat(cleanedPaste.split('')).slice(0, digits));\n }\n };\n\n useEffect(() => {\n const completeCode = values.join('');\n if (completeCode.length === digits) {\n onCodeComplete(completeCode);\n }\n }, [values]);\n\n return (\n <CodeInputWrapper style={style}>\n {Array.from({length: digits}, (_, index) => (\n <DigitInput\n autoFocus={index === 0 && autoFocus}\n key={index}\n onPaste={event => handlePaste(index, event)}\n onFocus={forceSelection}\n onMouseDown={forceSelectionPreventDefault}\n onTouchStart={forceSelectionPreventDefault}\n onKeyDown={event => handleKeyDown(index, event)}\n onKeyUp={forceSelection}\n markInvalid={markInvalid}\n ref={node => (inputs[index] = node)}\n value={values[index]}\n onChange={() => {}}\n disabled={disabled}\n />\n ))}\n </CodeInputWrapper>\n );\n};\n"],"file":"CodeInput.js"}
|
package/src/Form/CodeInput.md
CHANGED
|
@@ -3,5 +3,13 @@ Demo:
|
|
|
3
3
|
```js
|
|
4
4
|
import {onCodeComplete} from '@wireapp/react-ui-kit';
|
|
5
5
|
|
|
6
|
-
|
|
6
|
+
<>
|
|
7
|
+
<div style={{marginBottom: '20px'}}>
|
|
8
|
+
<CodeInput markInvalid onCodeComplete={code => console.info(code)} />
|
|
9
|
+
</div>
|
|
10
|
+
|
|
11
|
+
<div>
|
|
12
|
+
<CodeInput onCodeComplete={code => console.info(code)} />
|
|
13
|
+
</div>
|
|
14
|
+
</>;
|
|
7
15
|
```
|
package/src/Form/ErrorMessage.js
CHANGED
|
@@ -15,8 +15,6 @@ var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/h
|
|
|
15
15
|
|
|
16
16
|
var _react = require("@emotion/react");
|
|
17
17
|
|
|
18
|
-
var _Icon = require("../Icon");
|
|
19
|
-
|
|
20
18
|
var _Identity = require("../Identity");
|
|
21
19
|
|
|
22
20
|
var _Layout = require("../Layout");
|
|
@@ -28,13 +26,15 @@ var _util = require("../util");
|
|
|
28
26
|
var _excluded = ["justify", "align"],
|
|
29
27
|
_excluded2 = ["children"];
|
|
30
28
|
|
|
29
|
+
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)."; }
|
|
30
|
+
|
|
31
31
|
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
|
|
32
32
|
|
|
33
33
|
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
|
|
34
34
|
|
|
35
35
|
var errorMessageStyle = function errorMessageStyle(theme, _ref) {
|
|
36
36
|
var _ref$justify = _ref.justify,
|
|
37
|
-
justify = _ref$justify === void 0 ? '
|
|
37
|
+
justify = _ref$justify === void 0 ? 'flex-start' : _ref$justify,
|
|
38
38
|
_ref$align = _ref.align,
|
|
39
39
|
align = _ref$align === void 0 ? 'center' : _ref$align,
|
|
40
40
|
props = (0, _objectWithoutProperties2["default"])(_ref, _excluded);
|
|
@@ -44,7 +44,7 @@ var errorMessageStyle = function errorMessageStyle(theme, _ref) {
|
|
|
44
44
|
}, props))), {}, {
|
|
45
45
|
a: _objectSpread({}, (0, _Text.linkStyle)(theme, _objectSpread({
|
|
46
46
|
bold: false,
|
|
47
|
-
fontSize: '
|
|
47
|
+
fontSize: '12px',
|
|
48
48
|
textTransform: 'none'
|
|
49
49
|
}, props))),
|
|
50
50
|
marginBottom: '12px'
|
|
@@ -59,6 +59,16 @@ var filterErrorMessageProps = function filterErrorMessageProps(props) {
|
|
|
59
59
|
|
|
60
60
|
exports.filterErrorMessageProps = filterErrorMessageProps;
|
|
61
61
|
|
|
62
|
+
var _ref3 = process.env.NODE_ENV === "production" ? {
|
|
63
|
+
name: "mmvz9h",
|
|
64
|
+
styles: "font-weight:400"
|
|
65
|
+
} : {
|
|
66
|
+
name: "z4bxhs-ErrorMessage",
|
|
67
|
+
styles: "font-weight:400;label:ErrorMessage;",
|
|
68
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkVycm9yTWVzc2FnZS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBOEMyRCIsImZpbGUiOiJFcnJvck1lc3NhZ2UudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIFdpcmVcbiAqIENvcHlyaWdodCAoQykgMjAxOCBXaXJlIFN3aXNzIEdtYkhcbiAqXG4gKiBUaGlzIHByb2dyYW0gaXMgZnJlZSBzb2Z0d2FyZTogeW91IGNhbiByZWRpc3RyaWJ1dGUgaXQgYW5kL29yIG1vZGlmeVxuICogaXQgdW5kZXIgdGhlIHRlcm1zIG9mIHRoZSBHTlUgR2VuZXJhbCBQdWJsaWMgTGljZW5zZSBhcyBwdWJsaXNoZWQgYnlcbiAqIHRoZSBGcmVlIFNvZnR3YXJlIEZvdW5kYXRpb24sIGVpdGhlciB2ZXJzaW9uIDMgb2YgdGhlIExpY2Vuc2UsIG9yXG4gKiAoYXQgeW91ciBvcHRpb24pIGFueSBsYXRlciB2ZXJzaW9uLlxuICpcbiAqIFRoaXMgcHJvZ3JhbSBpcyBkaXN0cmlidXRlZCBpbiB0aGUgaG9wZSB0aGF0IGl0IHdpbGwgYmUgdXNlZnVsLFxuICogYnV0IFdJVEhPVVQgQU5ZIFdBUlJBTlRZOyB3aXRob3V0IGV2ZW4gdGhlIGltcGxpZWQgd2FycmFudHkgb2ZcbiAqIE1FUkNIQU5UQUJJTElUWSBvciBGSVRORVNTIEZPUiBBIFBBUlRJQ1VMQVIgUFVSUE9TRS4gU2VlIHRoZVxuICogR05VIEdlbmVyYWwgUHVibGljIExpY2Vuc2UgZm9yIG1vcmUgZGV0YWlscy5cbiAqXG4gKiBZb3Ugc2hvdWxkIGhhdmUgcmVjZWl2ZWQgYSBjb3B5IG9mIHRoZSBHTlUgR2VuZXJhbCBQdWJsaWMgTGljZW5zZVxuICogYWxvbmcgd2l0aCB0aGlzIHByb2dyYW0uIElmIG5vdCwgc2VlIGh0dHA6Ly93d3cuZ251Lm9yZy9saWNlbnNlcy8uXG4gKlxuICovXG5cbi8qKiBAanN4IGpzeCAqL1xuaW1wb3J0IHtDU1NPYmplY3QsIGpzeH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG5pbXBvcnQge0NPTE9SX1YyfSBmcm9tICcuLi9JZGVudGl0eSc7XG5pbXBvcnQge0ZsZXhCb3gsIEZsZXhCb3hQcm9wcywgZmxleEJveFN0eWxlLCBmaWx0ZXJGbGV4Qm94UHJvcHMsIFRoZW1lfSBmcm9tICcuLi9MYXlvdXQnO1xuaW1wb3J0IHtUZXh0LCBsaW5rU3R5bGV9IGZyb20gJy4uL1RleHQnO1xuaW1wb3J0IHtmaWx0ZXJQcm9wc30gZnJvbSAnLi4vdXRpbCc7XG5cbnR5cGUgRXJyb3JNZXNzYWdlUHJvcHM8VCA9IEhUTUxEaXZFbGVtZW50PiA9IEZsZXhCb3hQcm9wczxUPjtcblxuZXhwb3J0IGNvbnN0IGVycm9yTWVzc2FnZVN0eWxlOiA8VD4odGhlbWU6IFRoZW1lLCBwcm9wczogRXJyb3JNZXNzYWdlUHJvcHM8VD4pID0+IENTU09iamVjdCA9IChcbiAgdGhlbWUsXG4gIHtqdXN0aWZ5ID0gJ2ZsZXgtc3RhcnQnLCBhbGlnbiA9ICdjZW50ZXInLCAuLi5wcm9wc30sXG4pID0+ICh7XG4gIC4uLmZsZXhCb3hTdHlsZSh7YWxpZ24sIGp1c3RpZnksIC4uLnByb3BzfSksXG4gIGE6IHtcbiAgICAuLi5saW5rU3R5bGUodGhlbWUsIHtib2xkOiBmYWxzZSwgZm9udFNpemU6ICcxMnB4JywgdGV4dFRyYW5zZm9ybTogJ25vbmUnLCAuLi5wcm9wc30pLFxuICB9LFxuICBtYXJnaW5Cb3R0b206ICcxMnB4Jyxcbn0pO1xuXG5leHBvcnQgY29uc3QgZmlsdGVyRXJyb3JNZXNzYWdlUHJvcHMgPSAocHJvcHM6IEVycm9yTWVzc2FnZVByb3BzKSA9PiB7XG4gIHJldHVybiBmaWx0ZXJQcm9wcyhmaWx0ZXJGbGV4Qm94UHJvcHMocHJvcHMpIGFzIEVycm9yTWVzc2FnZVByb3BzLCBbXSk7XG59O1xuXG5leHBvcnQgY29uc3QgRXJyb3JNZXNzYWdlID0gKHtjaGlsZHJlbiwgLi4ucHJvcHN9OiBFcnJvck1lc3NhZ2VQcm9wcykgPT4gKFxuICA8RmxleEJveCBjc3M9eyh0aGVtZTogVGhlbWUpID0+IGVycm9yTWVzc2FnZVN0eWxlKHRoZW1lLCBwcm9wcyl9IHsuLi5wcm9wc30+XG4gICAgPFRleHQgY29sb3I9e0NPTE9SX1YyLlJFRF9MSUdIVF81MDB9IGZvbnRTaXplPXsnMTJweCd9IGNzcz17e2ZvbnRXZWlnaHQ6IDQwMH19PlxuICAgICAge2NoaWxkcmVufVxuICAgIDwvVGV4dD5cbiAgPC9GbGV4Qm94PlxuKTtcbiJdfQ== */",
|
|
69
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
70
|
+
};
|
|
71
|
+
|
|
62
72
|
var ErrorMessage = function ErrorMessage(_ref2) {
|
|
63
73
|
var children = _ref2.children,
|
|
64
74
|
props = (0, _objectWithoutProperties2["default"])(_ref2, _excluded2);
|
|
@@ -66,14 +76,10 @@ var ErrorMessage = function ErrorMessage(_ref2) {
|
|
|
66
76
|
css: function css(theme) {
|
|
67
77
|
return errorMessageStyle(theme, props);
|
|
68
78
|
}
|
|
69
|
-
}, props), (0, _react.jsx)(
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
"aria-hidden": "true"
|
|
74
|
-
}), (0, _react.jsx)(_Text.Text, {
|
|
75
|
-
color: _Identity.COLOR.RED,
|
|
76
|
-
fontSize: '11px'
|
|
79
|
+
}, props), (0, _react.jsx)(_Text.Text, {
|
|
80
|
+
color: _Identity.COLOR_V2.RED_LIGHT_500,
|
|
81
|
+
fontSize: '12px',
|
|
82
|
+
css: _ref3
|
|
77
83
|
}, children));
|
|
78
84
|
};
|
|
79
85
|
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["ErrorMessage.tsx"],"names":["errorMessageStyle","theme","justify","align","props","a","bold","fontSize","textTransform","marginBottom","filterErrorMessageProps","ErrorMessage","children","
|
|
1
|
+
{"version":3,"sources":["ErrorMessage.tsx"],"names":["errorMessageStyle","theme","justify","align","props","a","bold","fontSize","textTransform","marginBottom","filterErrorMessageProps","ErrorMessage","children","COLOR_V2","RED_LIGHT_500"],"mappings":";;;;;;;;;;;;;;;AAoBA;;AAEA;;AACA;;AACA;;AACA;;;;;;;;;;;AAIO,IAAMA,iBAA8E,GAAG,SAAjFA,iBAAiF,CAC5FC,KAD4F;AAAA,0BAE3FC,OAF2F;AAAA,MAE3FA,OAF2F,6BAEjF,YAFiF;AAAA,wBAEnEC,KAFmE;AAAA,MAEnEA,KAFmE,2BAE3D,QAF2D;AAAA,MAE9CC,KAF8C;AAAA,yCAIzF;AAAcD,IAAAA,KAAK,EAALA,KAAd;AAAqBD,IAAAA,OAAO,EAAPA;AAArB,KAAiCE,KAAjC,EAJyF;AAK5FC,IAAAA,CAAC,oBACI,qBAAUJ,KAAV;AAAkBK,MAAAA,IAAI,EAAE,KAAxB;AAA+BC,MAAAA,QAAQ,EAAE,MAAzC;AAAiDC,MAAAA,aAAa,EAAE;AAAhE,OAA2EJ,KAA3E,EADJ,CAL2F;AAQ5FK,IAAAA,YAAY,EAAE;AAR8E;AAAA,CAAvF;;;;AAWA,IAAMC,uBAAuB,GAAG,SAA1BA,uBAA0B,CAACN,KAAD,EAA8B;AACnE,SAAO,uBAAY,gCAAmBA,KAAnB,CAAZ,EAA4D,EAA5D,CAAP;AACD,CAFM;;;;;;;;;;;;;;AAIA,IAAMO,YAAY,GAAG,SAAfA,YAAe;AAAA,MAAEC,QAAF,SAAEA,QAAF;AAAA,MAAeR,KAAf;AAAA,SAC1B,gBAAC,eAAD;AAAS,IAAA,GAAG,EAAE,aAACH,KAAD;AAAA,aAAkBD,iBAAiB,CAACC,KAAD,EAAQG,KAAR,CAAnC;AAAA;AAAd,KAAqEA,KAArE,GACE,gBAAC,UAAD;AAAM,IAAA,KAAK,EAAES,mBAASC,aAAtB;AAAqC,IAAA,QAAQ,EAAE,MAA/C;AAAuD,IAAA,GAAG;AAA1D,KACGF,QADH,CADF,CAD0B;AAAA,CAArB","sourcesContent":["/*\n * Wire\n * Copyright (C) 2018 Wire Swiss GmbH\n *\n * This program is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * This program is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n *\n * You should have received a copy of the GNU General Public License\n * along with this program. If not, see http://www.gnu.org/licenses/.\n *\n */\n\n/** @jsx jsx */\nimport {CSSObject, jsx} from '@emotion/react';\n\nimport {COLOR_V2} from '../Identity';\nimport {FlexBox, FlexBoxProps, flexBoxStyle, filterFlexBoxProps, Theme} from '../Layout';\nimport {Text, linkStyle} from '../Text';\nimport {filterProps} from '../util';\n\ntype ErrorMessageProps<T = HTMLDivElement> = FlexBoxProps<T>;\n\nexport const errorMessageStyle: <T>(theme: Theme, props: ErrorMessageProps<T>) => CSSObject = (\n theme,\n {justify = 'flex-start', align = 'center', ...props},\n) => ({\n ...flexBoxStyle({align, justify, ...props}),\n a: {\n ...linkStyle(theme, {bold: false, fontSize: '12px', textTransform: 'none', ...props}),\n },\n marginBottom: '12px',\n});\n\nexport const filterErrorMessageProps = (props: ErrorMessageProps) => {\n return filterProps(filterFlexBoxProps(props) as ErrorMessageProps, []);\n};\n\nexport const ErrorMessage = ({children, ...props}: ErrorMessageProps) => (\n <FlexBox css={(theme: Theme) => errorMessageStyle(theme, props)} {...props}>\n <Text color={COLOR_V2.RED_LIGHT_500} fontSize={'12px'} css={{fontWeight: 400}}>\n {children}\n </Text>\n </FlexBox>\n);\n"],"file":"ErrorMessage.js"}
|
package/src/Form/Form.md
CHANGED
|
@@ -45,6 +45,29 @@ const shakeBox = useRef();
|
|
|
45
45
|
<Button type="submit" formNoValidate>
|
|
46
46
|
Submit Button
|
|
47
47
|
</Button>
|
|
48
|
+
|
|
49
|
+
<Input placeholder="InputBlock" label="Input Block" id="inputBlock" />
|
|
50
|
+
|
|
51
|
+
<Input placeholder="Input required" label="Second input required" required id="requiredInputBlock" />
|
|
52
|
+
|
|
53
|
+
<Input
|
|
54
|
+
placeholder="Error input"
|
|
55
|
+
markInvalid
|
|
56
|
+
label="Error input"
|
|
57
|
+
error={<ErrorMessage>Error message</ErrorMessage>}
|
|
58
|
+
required
|
|
59
|
+
id="errorInputBlock"
|
|
60
|
+
/>
|
|
61
|
+
|
|
62
|
+
<Input
|
|
63
|
+
type="password"
|
|
64
|
+
placeholder="Password Input"
|
|
65
|
+
label="Password Input"
|
|
66
|
+
required
|
|
67
|
+
id="passwordInput"
|
|
68
|
+
helperText="Must have at least one: uppercase letter, lowercase letter, number, symbol"
|
|
69
|
+
/>
|
|
70
|
+
|
|
48
71
|
<InputBlock>
|
|
49
72
|
<Input placeholder="InputBlock" markInvalid />
|
|
50
73
|
<Input placeholder="Second Input" markInvalid />
|
package/src/Form/Input.d.ts
CHANGED
|
@@ -1,13 +1,17 @@
|
|
|
1
1
|
/** @jsx jsx */
|
|
2
2
|
import { CSSObject } from '@emotion/react';
|
|
3
3
|
import type { Property } from 'csstype';
|
|
4
|
-
import React from 'react';
|
|
4
|
+
import React, { ReactElement } from 'react';
|
|
5
5
|
import type { Theme } from '../Layout';
|
|
6
6
|
import type { TextProps } from '../Text';
|
|
7
7
|
export interface InputProps<T = HTMLInputElement> extends TextProps<T> {
|
|
8
|
+
label?: string;
|
|
9
|
+
error?: ReactElement;
|
|
8
10
|
markInvalid?: boolean;
|
|
11
|
+
helperText?: string;
|
|
9
12
|
placeholderTextTransform?: Property.TextTransform;
|
|
10
13
|
}
|
|
11
|
-
export declare const inputStyle: <T>(theme: Theme, props: InputProps<T
|
|
14
|
+
export declare const inputStyle: <T>(theme: Theme, props: InputProps<T>, hasError?: boolean) => CSSObject;
|
|
12
15
|
export declare const INPUT_CLASSNAME = "wireinput";
|
|
16
|
+
export declare const INPUT_GROUP = "input-group";
|
|
13
17
|
export declare const Input: React.FC<InputProps<HTMLInputElement>>;
|
package/src/Form/Input.js
CHANGED
|
@@ -2,26 +2,38 @@
|
|
|
2
2
|
|
|
3
3
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
4
|
|
|
5
|
+
var _typeof = require("@babel/runtime/helpers/typeof");
|
|
6
|
+
|
|
5
7
|
Object.defineProperty(exports, "__esModule", {
|
|
6
8
|
value: true
|
|
7
9
|
});
|
|
8
|
-
exports.Input = exports.INPUT_CLASSNAME = exports.inputStyle = void 0;
|
|
10
|
+
exports.Input = exports.INPUT_GROUP = exports.INPUT_CLASSNAME = exports.inputStyle = void 0;
|
|
9
11
|
|
|
10
12
|
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
|
|
11
13
|
|
|
14
|
+
var _react = require("@emotion/react");
|
|
15
|
+
|
|
16
|
+
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
17
|
+
|
|
12
18
|
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
|
|
13
19
|
|
|
14
20
|
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
15
21
|
|
|
16
|
-
var
|
|
17
|
-
|
|
18
|
-
var _react2 = _interopRequireDefault(require("react"));
|
|
22
|
+
var _react2 = _interopRequireWildcard(require("react"));
|
|
19
23
|
|
|
20
24
|
var _Identity = require("../Identity");
|
|
21
25
|
|
|
22
26
|
var _util = require("../util");
|
|
23
27
|
|
|
24
|
-
var
|
|
28
|
+
var _Icon = require("../Icon");
|
|
29
|
+
|
|
30
|
+
var _InputLabel = _interopRequireDefault(require("./InputLabel"));
|
|
31
|
+
|
|
32
|
+
var _excluded = ["type", "label", "error", "helperText"];
|
|
33
|
+
|
|
34
|
+
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
35
|
+
|
|
36
|
+
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
25
37
|
|
|
26
38
|
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
|
|
27
39
|
|
|
@@ -36,7 +48,7 @@ var inputStyle = function inputStyle(theme, _ref) {
|
|
|
36
48
|
disabled = _ref$disabled === void 0 ? false : _ref$disabled;
|
|
37
49
|
var placeholderStyle = {
|
|
38
50
|
color: theme.Input.placeholderColor,
|
|
39
|
-
fontSize: '
|
|
51
|
+
fontSize: '16px',
|
|
40
52
|
textTransform: placeholderTextTransform
|
|
41
53
|
};
|
|
42
54
|
return {
|
|
@@ -46,21 +58,20 @@ var inputStyle = function inputStyle(theme, _ref) {
|
|
|
46
58
|
'&::-ms-input-placeholder': _objectSpread({}, placeholderStyle),
|
|
47
59
|
'&::-webkit-input-placeholder': _objectSpread({}, placeholderStyle),
|
|
48
60
|
'&:focus': {
|
|
49
|
-
boxShadow: "0 0 0 1px ".concat(_Identity.
|
|
61
|
+
boxShadow: "0 0 0 1px ".concat(_Identity.COLOR_V2.BLUE)
|
|
50
62
|
},
|
|
51
63
|
'&:invalid:not(:focus)': !markInvalid ? {
|
|
52
|
-
boxShadow: "0 0 0 1px ".concat(_Identity.
|
|
64
|
+
boxShadow: "0 0 0 1px ".concat(_Identity.COLOR_V2.GRAY)
|
|
53
65
|
} : {},
|
|
54
66
|
background: disabled ? theme.Input.backgroundColorDisabled : theme.Input.backgroundColor,
|
|
55
67
|
border: 'none',
|
|
56
68
|
borderRadius: '4px',
|
|
57
|
-
boxShadow: markInvalid ? "0 0 0 1px ".concat(_Identity.
|
|
58
|
-
caretColor: _Identity.
|
|
69
|
+
boxShadow: markInvalid ? "0 0 0 1px ".concat(_Identity.COLOR_V2.RED) : "0 0 0 1px ".concat(_Identity.COLOR_V2.GRAY_40),
|
|
70
|
+
caretColor: _Identity.COLOR_V2.BLUE,
|
|
59
71
|
color: theme.general.color,
|
|
60
72
|
fontWeight: 300,
|
|
61
|
-
height: '
|
|
73
|
+
height: '48px',
|
|
62
74
|
lineHeight: '24px',
|
|
63
|
-
margin: '0 0 16px',
|
|
64
75
|
outline: 'none',
|
|
65
76
|
padding: '0 16px',
|
|
66
77
|
width: '100%'
|
|
@@ -70,22 +81,96 @@ var inputStyle = function inputStyle(theme, _ref) {
|
|
|
70
81
|
exports.inputStyle = inputStyle;
|
|
71
82
|
var INPUT_CLASSNAME = 'wireinput';
|
|
72
83
|
exports.INPUT_CLASSNAME = INPUT_CLASSNAME;
|
|
84
|
+
var INPUT_GROUP = 'input-group';
|
|
85
|
+
exports.INPUT_GROUP = INPUT_GROUP;
|
|
73
86
|
|
|
74
87
|
var filterInputProps = function filterInputProps(props) {
|
|
75
88
|
return (0, _util.filterProps)(props, ['markInvalid', 'placeholderTextTransform']);
|
|
76
89
|
};
|
|
77
90
|
|
|
91
|
+
var centerInputAction = {
|
|
92
|
+
position: 'absolute',
|
|
93
|
+
right: '16px',
|
|
94
|
+
top: '50%',
|
|
95
|
+
transform: 'translateY(-50%)'
|
|
96
|
+
};
|
|
97
|
+
|
|
78
98
|
var Input = /*#__PURE__*/_react2["default"].forwardRef(function (_ref2, ref) {
|
|
79
99
|
var type = _ref2.type,
|
|
100
|
+
label = _ref2.label,
|
|
101
|
+
error = _ref2.error,
|
|
102
|
+
helperText = _ref2.helperText,
|
|
80
103
|
props = (0, _objectWithoutProperties2["default"])(_ref2, _excluded);
|
|
81
|
-
|
|
104
|
+
|
|
105
|
+
var _useState = (0, _react2.useState)(false),
|
|
106
|
+
_useState2 = (0, _slicedToArray2["default"])(_useState, 2),
|
|
107
|
+
togglePassword = _useState2[0],
|
|
108
|
+
setTogglePassword = _useState2[1];
|
|
109
|
+
|
|
110
|
+
var hasError = !!error;
|
|
111
|
+
var isPasswordInput = type === 'password';
|
|
112
|
+
var toggledPasswordType = togglePassword ? 'text' : 'password';
|
|
113
|
+
|
|
114
|
+
var toggleSetPassword = function toggleSetPassword() {
|
|
115
|
+
return setTogglePassword(function (prevState) {
|
|
116
|
+
return !prevState;
|
|
117
|
+
});
|
|
118
|
+
};
|
|
119
|
+
|
|
120
|
+
return (0, _react.jsx)("div", {
|
|
121
|
+
className: INPUT_GROUP,
|
|
122
|
+
css: /*#__PURE__*/(0, _react.css)({
|
|
123
|
+
marginBottom: hasError ? '2px' : '20px',
|
|
124
|
+
'&:focus-within label': {
|
|
125
|
+
color: _Identity.COLOR_V2.BLUE
|
|
126
|
+
}
|
|
127
|
+
}, process.env.NODE_ENV === "production" ? "" : ";label:Input;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIklucHV0LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE4R00iLCJmaWxlIjoiSW5wdXQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIFdpcmVcbiAqIENvcHlyaWdodCAoQykgMjAxOCBXaXJlIFN3aXNzIEdtYkhcbiAqXG4gKiBUaGlzIHByb2dyYW0gaXMgZnJlZSBzb2Z0d2FyZTogeW91IGNhbiByZWRpc3RyaWJ1dGUgaXQgYW5kL29yIG1vZGlmeVxuICogaXQgdW5kZXIgdGhlIHRlcm1zIG9mIHRoZSBHTlUgR2VuZXJhbCBQdWJsaWMgTGljZW5zZSBhcyBwdWJsaXNoZWQgYnlcbiAqIHRoZSBGcmVlIFNvZnR3YXJlIEZvdW5kYXRpb24sIGVpdGhlciB2ZXJzaW9uIDMgb2YgdGhlIExpY2Vuc2UsIG9yXG4gKiAoYXQgeW91ciBvcHRpb24pIGFueSBsYXRlciB2ZXJzaW9uLlxuICpcbiAqIFRoaXMgcHJvZ3JhbSBpcyBkaXN0cmlidXRlZCBpbiB0aGUgaG9wZSB0aGF0IGl0IHdpbGwgYmUgdXNlZnVsLFxuICogYnV0IFdJVEhPVVQgQU5ZIFdBUlJBTlRZOyB3aXRob3V0IGV2ZW4gdGhlIGltcGxpZWQgd2FycmFudHkgb2ZcbiAqIE1FUkNIQU5UQUJJTElUWSBvciBGSVRORVNTIEZPUiBBIFBBUlRJQ1VMQVIgUFVSUE9TRS4gU2VlIHRoZVxuICogR05VIEdlbmVyYWwgUHVibGljIExpY2Vuc2UgZm9yIG1vcmUgZGV0YWlscy5cbiAqXG4gKiBZb3Ugc2hvdWxkIGhhdmUgcmVjZWl2ZWQgYSBjb3B5IG9mIHRoZSBHTlUgR2VuZXJhbCBQdWJsaWMgTGljZW5zZVxuICogYWxvbmcgd2l0aCB0aGlzIHByb2dyYW0uIElmIG5vdCwgc2VlIGh0dHA6Ly93d3cuZ251Lm9yZy9saWNlbnNlcy8uXG4gKlxuICovXG5cbi8qKiBAanN4IGpzeCAqL1xuaW1wb3J0IHtDU1NPYmplY3QsIGpzeH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHR5cGUge1Byb3BlcnR5fSBmcm9tICdjc3N0eXBlJztcbmltcG9ydCBSZWFjdCwge1JlYWN0RWxlbWVudCwgdXNlU3RhdGV9IGZyb20gJ3JlYWN0JztcblxuaW1wb3J0IHtDT0xPUl9WMn0gZnJvbSAnLi4vSWRlbnRpdHknO1xuaW1wb3J0IHR5cGUge1RoZW1lfSBmcm9tICcuLi9MYXlvdXQnO1xuaW1wb3J0IHR5cGUge1RleHRQcm9wc30gZnJvbSAnLi4vVGV4dCc7XG5pbXBvcnQge2ZpbHRlclByb3BzfSBmcm9tICcuLi91dGlsJztcbmltcG9ydCB7RXJyb3JJY29uLCBIaWRlSWNvbiwgU2hvd0ljb259IGZyb20gJy4uL0ljb24nO1xuaW1wb3J0IElucHV0TGFiZWwgZnJvbSAnLi9JbnB1dExhYmVsJztcblxuZXhwb3J0IGludGVyZmFjZSBJbnB1dFByb3BzPFQgPSBIVE1MSW5wdXRFbGVtZW50PiBleHRlbmRzIFRleHRQcm9wczxUPiB7XG4gIGxhYmVsPzogc3RyaW5nO1xuICBlcnJvcj86IFJlYWN0RWxlbWVudDtcbiAgbWFya0ludmFsaWQ/OiBib29sZWFuO1xuICBoZWxwZXJUZXh0Pzogc3RyaW5nO1xuICBwbGFjZWhvbGRlclRleHRUcmFuc2Zvcm0/OiBQcm9wZXJ0eS5UZXh0VHJhbnNmb3JtO1xufVxuXG5leHBvcnQgY29uc3QgaW5wdXRTdHlsZTogPFQ+KHRoZW1lOiBUaGVtZSwgcHJvcHM6IElucHV0UHJvcHM8VD4sIGhhc0Vycm9yPzogYm9vbGVhbikgPT4gQ1NTT2JqZWN0ID0gKFxuICB0aGVtZSxcbiAge21hcmtJbnZhbGlkID0gZmFsc2UsIHBsYWNlaG9sZGVyVGV4dFRyYW5zZm9ybSA9ICdub25lJywgZGlzYWJsZWQgPSBmYWxzZX0sXG4pID0+IHtcbiAgY29uc3QgcGxhY2Vob2xkZXJTdHlsZSA9IHtcbiAgICBjb2xvcjogdGhlbWUuSW5wdXQucGxhY2Vob2xkZXJDb2xvcixcbiAgICBmb250U2l6ZTogJzE2cHgnLFxuICAgIHRleHRUcmFuc2Zvcm06IHBsYWNlaG9sZGVyVGV4dFRyYW5zZm9ybSxcbiAgfTtcblxuICByZXR1cm4ge1xuICAgICcmOjotbW96LXBsYWNlaG9sZGVyJzoge1xuICAgICAgLi4ucGxhY2Vob2xkZXJTdHlsZSxcbiAgICAgIG9wYWNpdHk6IDEsXG4gICAgfSxcbiAgICAnJjo6LW1zLWlucHV0LXBsYWNlaG9sZGVyJzoge1xuICAgICAgLi4ucGxhY2Vob2xkZXJTdHlsZSxcbiAgICB9LFxuICAgICcmOjotd2Via2l0LWlucHV0LXBsYWNlaG9sZGVyJzoge1xuICAgICAgLi4ucGxhY2Vob2xkZXJTdHlsZSxcbiAgICB9LFxuICAgICcmOmZvY3VzJzoge1xuICAgICAgYm94U2hhZG93OiBgMCAwIDAgMXB4ICR7Q09MT1JfVjIuQkxVRX1gLFxuICAgIH0sXG4gICAgJyY6aW52YWxpZDpub3QoOmZvY3VzKSc6ICFtYXJrSW52YWxpZFxuICAgICAgPyB7XG4gICAgICAgICAgYm94U2hhZG93OiBgMCAwIDAgMXB4ICR7Q09MT1JfVjIuR1JBWX1gLFxuICAgICAgICB9XG4gICAgICA6IHt9LFxuICAgIGJhY2tncm91bmQ6IGRpc2FibGVkID8gdGhlbWUuSW5wdXQuYmFja2dyb3VuZENvbG9yRGlzYWJsZWQgOiB0aGVtZS5JbnB1dC5iYWNrZ3JvdW5kQ29sb3IsXG4gICAgYm9yZGVyOiAnbm9uZScsXG4gICAgYm9yZGVyUmFkaXVzOiAnNHB4JyxcbiAgICBib3hTaGFkb3c6IG1hcmtJbnZhbGlkID8gYDAgMCAwIDFweCAke0NPTE9SX1YyLlJFRH1gIDogYDAgMCAwIDFweCAke0NPTE9SX1YyLkdSQVlfNDB9YCxcbiAgICBjYXJldENvbG9yOiBDT0xPUl9WMi5CTFVFLFxuICAgIGNvbG9yOiB0aGVtZS5nZW5lcmFsLmNvbG9yLFxuICAgIGZvbnRXZWlnaHQ6IDMwMCxcbiAgICBoZWlnaHQ6ICc0OHB4JyxcbiAgICBsaW5lSGVpZ2h0OiAnMjRweCcsXG4gICAgb3V0bGluZTogJ25vbmUnLFxuICAgIHBhZGRpbmc6ICcwIDE2cHgnLFxuICAgIHdpZHRoOiAnMTAwJScsXG4gIH07XG59O1xuXG5leHBvcnQgY29uc3QgSU5QVVRfQ0xBU1NOQU1FID0gJ3dpcmVpbnB1dCc7XG5leHBvcnQgY29uc3QgSU5QVVRfR1JPVVAgPSAnaW5wdXQtZ3JvdXAnO1xuXG5jb25zdCBmaWx0ZXJJbnB1dFByb3BzID0gKHByb3BzOiBJbnB1dFByb3BzKSA9PiBmaWx0ZXJQcm9wcyhwcm9wcywgWydtYXJrSW52YWxpZCcsICdwbGFjZWhvbGRlclRleHRUcmFuc2Zvcm0nXSk7XG5cbmNvbnN0IGNlbnRlcklucHV0QWN0aW9uOiBDU1NPYmplY3QgPSB7XG4gIHBvc2l0aW9uOiAnYWJzb2x1dGUnLFxuICByaWdodDogJzE2cHgnLFxuICB0b3A6ICc1MCUnLFxuICB0cmFuc2Zvcm06ICd0cmFuc2xhdGVZKC01MCUpJyxcbn07XG5cbmV4cG9ydCBjb25zdCBJbnB1dDogUmVhY3QuRkM8SW5wdXRQcm9wczxIVE1MSW5wdXRFbGVtZW50Pj4gPSBSZWFjdC5mb3J3YXJkUmVmPFxuICBIVE1MSW5wdXRFbGVtZW50LFxuICBJbnB1dFByb3BzPEhUTUxJbnB1dEVsZW1lbnQ+XG4+KCh7dHlwZSwgbGFiZWwsIGVycm9yLCBoZWxwZXJUZXh0LCAuLi5wcm9wc30sIHJlZikgPT4ge1xuICBjb25zdCBbdG9nZ2xlUGFzc3dvcmQsIHNldFRvZ2dsZVBhc3N3b3JkXSA9IHVzZVN0YXRlPGJvb2xlYW4+KGZhbHNlKTtcblxuICBjb25zdCBoYXNFcnJvciA9ICEhZXJyb3I7XG4gIGNvbnN0IGlzUGFzc3dvcmRJbnB1dCA9IHR5cGUgPT09ICdwYXNzd29yZCc7XG4gIGNvbnN0IHRvZ2dsZWRQYXNzd29yZFR5cGUgPSB0b2dnbGVQYXNzd29yZCA/ICd0ZXh0JyA6ICdwYXNzd29yZCc7XG5cbiAgY29uc3QgdG9nZ2xlU2V0UGFzc3dvcmQgPSAoKSA9PiBzZXRUb2dnbGVQYXNzd29yZChwcmV2U3RhdGUgPT4gIXByZXZTdGF0ZSk7XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2XG4gICAgICBjbGFzc05hbWU9e0lOUFVUX0dST1VQfVxuICAgICAgY3NzPXt7XG4gICAgICAgIG1hcmdpbkJvdHRvbTogaGFzRXJyb3IgPyAnMnB4JyA6ICcyMHB4JyxcbiAgICAgICAgJyY6Zm9jdXMtd2l0aGluIGxhYmVsJzoge1xuICAgICAgICAgIGNvbG9yOiBDT0xPUl9WMi5CTFVFLFxuICAgICAgICB9LFxuICAgICAgfX1cbiAgICA+XG4gICAgICB7bGFiZWwgJiYgKFxuICAgICAgICA8SW5wdXRMYWJlbCBodG1sRm9yPXtwcm9wcy5pZH0gaXNSZXF1aXJlZD17cHJvcHMucmVxdWlyZWR9IG1hcmtJbnZhbGlkPXtwcm9wcy5tYXJrSW52YWxpZH0+XG4gICAgICAgICAge2xhYmVsfVxuICAgICAgICA8L0lucHV0TGFiZWw+XG4gICAgICApfVxuXG4gICAgICA8ZGl2IGNzcz17e21hcmdpbkJvdHRvbTogaGFzRXJyb3IgJiYgJzhweCcsIHBvc2l0aW9uOiAncmVsYXRpdmUnfX0+XG4gICAgICAgIDxpbnB1dFxuICAgICAgICAgIGNsYXNzTmFtZT17SU5QVVRfQ0xBU1NOQU1FfVxuICAgICAgICAgIGNzcz17KHRoZW1lOiBUaGVtZSkgPT4gaW5wdXRTdHlsZSh0aGVtZSwgcHJvcHMsIGhhc0Vycm9yKX1cbiAgICAgICAgICByZWY9e3JlZn1cbiAgICAgICAgICB0eXBlPXtpc1Bhc3N3b3JkSW5wdXQgPyB0b2dnbGVkUGFzc3dvcmRUeXBlIDogdHlwZX1cbiAgICAgICAgICBhcmlhLXJlcXVpcmVkPXtwcm9wcy5yZXF1aXJlZH1cbiAgICAgICAgICB7Li4uZmlsdGVySW5wdXRQcm9wcyhwcm9wcyl9XG4gICAgICAgIC8+XG5cbiAgICAgICAge2hhc0Vycm9yICYmICFpc1Bhc3N3b3JkSW5wdXQgJiYgKFxuICAgICAgICAgIDxFcnJvckljb24gY3NzPXtjZW50ZXJJbnB1dEFjdGlvbn0gd2lkdGg9ezE2fSBoZWlnaHQ9ezE2fSBhcmlhLWhpZGRlbj1cInRydWVcIiAvPlxuICAgICAgICApfVxuXG4gICAgICAgIHtpc1Bhc3N3b3JkSW5wdXQgJiYgKFxuICAgICAgICAgIDxidXR0b25cbiAgICAgICAgICAgIHR5cGU9XCJidXR0b25cIlxuICAgICAgICAgICAgY3NzPXt7Li4uY2VudGVySW5wdXRBY3Rpb24sIGJhY2tncm91bmQ6ICd0cmFuc3BhcmVudCcsIGJvcmRlcjogJ25vbmUnLCBjdXJzb3I6ICdwb2ludGVyJywgcGFkZGluZzogMH19XG4gICAgICAgICAgICBvbkNsaWNrPXt0b2dnbGVTZXRQYXNzd29yZH1cbiAgICAgICAgICAgIHRpdGxlPVwiVG9nZ2xlIHBhc3N3b3JkIHZpc2liaWxpdHlcIlxuICAgICAgICAgICAgYXJpYS1jb250cm9scz17cHJvcHMuaWR9XG4gICAgICAgICAgICBhcmlhLWV4cGFuZGVkPXt0b2dnbGVQYXNzd29yZH1cbiAgICAgICAgICA+XG4gICAgICAgICAgICB7dG9nZ2xlUGFzc3dvcmQgPyA8SGlkZUljb24gY29sb3I9e0NPTE9SX1YyLkJMQUNLfSAvPiA6IDxTaG93SWNvbiBjb2xvcj17Q09MT1JfVjIuQkxBQ0t9IC8+fVxuICAgICAgICAgIDwvYnV0dG9uPlxuICAgICAgICApfVxuICAgICAgPC9kaXY+XG5cbiAgICAgIHshaGFzRXJyb3IgJiYgaGVscGVyVGV4dCAmJiAoXG4gICAgICAgIDxwIGNzcz17e2ZvbnRTaXplOiAnMTJweCcsIGZvbnRXZWlnaHQ6IDQwMCwgY29sb3I6IENPTE9SX1YyLkdSQVlfODAsIG1hcmdpblRvcDogOH19PntoZWxwZXJUZXh0fTwvcD5cbiAgICAgICl9XG5cbiAgICAgIHtlcnJvcn1cbiAgICA8L2Rpdj5cbiAgKTtcbn0pO1xuIl19 */")
|
|
128
|
+
}, label && (0, _react.jsx)(_InputLabel["default"], {
|
|
129
|
+
htmlFor: props.id,
|
|
130
|
+
isRequired: props.required,
|
|
131
|
+
markInvalid: props.markInvalid
|
|
132
|
+
}, label), (0, _react.jsx)("div", {
|
|
133
|
+
css: /*#__PURE__*/(0, _react.css)({
|
|
134
|
+
marginBottom: hasError && '8px',
|
|
135
|
+
position: 'relative'
|
|
136
|
+
}, process.env.NODE_ENV === "production" ? "" : ";label:Input;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIklucHV0LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEySFciLCJmaWxlIjoiSW5wdXQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIFdpcmVcbiAqIENvcHlyaWdodCAoQykgMjAxOCBXaXJlIFN3aXNzIEdtYkhcbiAqXG4gKiBUaGlzIHByb2dyYW0gaXMgZnJlZSBzb2Z0d2FyZTogeW91IGNhbiByZWRpc3RyaWJ1dGUgaXQgYW5kL29yIG1vZGlmeVxuICogaXQgdW5kZXIgdGhlIHRlcm1zIG9mIHRoZSBHTlUgR2VuZXJhbCBQdWJsaWMgTGljZW5zZSBhcyBwdWJsaXNoZWQgYnlcbiAqIHRoZSBGcmVlIFNvZnR3YXJlIEZvdW5kYXRpb24sIGVpdGhlciB2ZXJzaW9uIDMgb2YgdGhlIExpY2Vuc2UsIG9yXG4gKiAoYXQgeW91ciBvcHRpb24pIGFueSBsYXRlciB2ZXJzaW9uLlxuICpcbiAqIFRoaXMgcHJvZ3JhbSBpcyBkaXN0cmlidXRlZCBpbiB0aGUgaG9wZSB0aGF0IGl0IHdpbGwgYmUgdXNlZnVsLFxuICogYnV0IFdJVEhPVVQgQU5ZIFdBUlJBTlRZOyB3aXRob3V0IGV2ZW4gdGhlIGltcGxpZWQgd2FycmFudHkgb2ZcbiAqIE1FUkNIQU5UQUJJTElUWSBvciBGSVRORVNTIEZPUiBBIFBBUlRJQ1VMQVIgUFVSUE9TRS4gU2VlIHRoZVxuICogR05VIEdlbmVyYWwgUHVibGljIExpY2Vuc2UgZm9yIG1vcmUgZGV0YWlscy5cbiAqXG4gKiBZb3Ugc2hvdWxkIGhhdmUgcmVjZWl2ZWQgYSBjb3B5IG9mIHRoZSBHTlUgR2VuZXJhbCBQdWJsaWMgTGljZW5zZVxuICogYWxvbmcgd2l0aCB0aGlzIHByb2dyYW0uIElmIG5vdCwgc2VlIGh0dHA6Ly93d3cuZ251Lm9yZy9saWNlbnNlcy8uXG4gKlxuICovXG5cbi8qKiBAanN4IGpzeCAqL1xuaW1wb3J0IHtDU1NPYmplY3QsIGpzeH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHR5cGUge1Byb3BlcnR5fSBmcm9tICdjc3N0eXBlJztcbmltcG9ydCBSZWFjdCwge1JlYWN0RWxlbWVudCwgdXNlU3RhdGV9IGZyb20gJ3JlYWN0JztcblxuaW1wb3J0IHtDT0xPUl9WMn0gZnJvbSAnLi4vSWRlbnRpdHknO1xuaW1wb3J0IHR5cGUge1RoZW1lfSBmcm9tICcuLi9MYXlvdXQnO1xuaW1wb3J0IHR5cGUge1RleHRQcm9wc30gZnJvbSAnLi4vVGV4dCc7XG5pbXBvcnQge2ZpbHRlclByb3BzfSBmcm9tICcuLi91dGlsJztcbmltcG9ydCB7RXJyb3JJY29uLCBIaWRlSWNvbiwgU2hvd0ljb259IGZyb20gJy4uL0ljb24nO1xuaW1wb3J0IElucHV0TGFiZWwgZnJvbSAnLi9JbnB1dExhYmVsJztcblxuZXhwb3J0IGludGVyZmFjZSBJbnB1dFByb3BzPFQgPSBIVE1MSW5wdXRFbGVtZW50PiBleHRlbmRzIFRleHRQcm9wczxUPiB7XG4gIGxhYmVsPzogc3RyaW5nO1xuICBlcnJvcj86IFJlYWN0RWxlbWVudDtcbiAgbWFya0ludmFsaWQ/OiBib29sZWFuO1xuICBoZWxwZXJUZXh0Pzogc3RyaW5nO1xuICBwbGFjZWhvbGRlclRleHRUcmFuc2Zvcm0/OiBQcm9wZXJ0eS5UZXh0VHJhbnNmb3JtO1xufVxuXG5leHBvcnQgY29uc3QgaW5wdXRTdHlsZTogPFQ+KHRoZW1lOiBUaGVtZSwgcHJvcHM6IElucHV0UHJvcHM8VD4sIGhhc0Vycm9yPzogYm9vbGVhbikgPT4gQ1NTT2JqZWN0ID0gKFxuICB0aGVtZSxcbiAge21hcmtJbnZhbGlkID0gZmFsc2UsIHBsYWNlaG9sZGVyVGV4dFRyYW5zZm9ybSA9ICdub25lJywgZGlzYWJsZWQgPSBmYWxzZX0sXG4pID0+IHtcbiAgY29uc3QgcGxhY2Vob2xkZXJTdHlsZSA9IHtcbiAgICBjb2xvcjogdGhlbWUuSW5wdXQucGxhY2Vob2xkZXJDb2xvcixcbiAgICBmb250U2l6ZTogJzE2cHgnLFxuICAgIHRleHRUcmFuc2Zvcm06IHBsYWNlaG9sZGVyVGV4dFRyYW5zZm9ybSxcbiAgfTtcblxuICByZXR1cm4ge1xuICAgICcmOjotbW96LXBsYWNlaG9sZGVyJzoge1xuICAgICAgLi4ucGxhY2Vob2xkZXJTdHlsZSxcbiAgICAgIG9wYWNpdHk6IDEsXG4gICAgfSxcbiAgICAnJjo6LW1zLWlucHV0LXBsYWNlaG9sZGVyJzoge1xuICAgICAgLi4ucGxhY2Vob2xkZXJTdHlsZSxcbiAgICB9LFxuICAgICcmOjotd2Via2l0LWlucHV0LXBsYWNlaG9sZGVyJzoge1xuICAgICAgLi4ucGxhY2Vob2xkZXJTdHlsZSxcbiAgICB9LFxuICAgICcmOmZvY3VzJzoge1xuICAgICAgYm94U2hhZG93OiBgMCAwIDAgMXB4ICR7Q09MT1JfVjIuQkxVRX1gLFxuICAgIH0sXG4gICAgJyY6aW52YWxpZDpub3QoOmZvY3VzKSc6ICFtYXJrSW52YWxpZFxuICAgICAgPyB7XG4gICAgICAgICAgYm94U2hhZG93OiBgMCAwIDAgMXB4ICR7Q09MT1JfVjIuR1JBWX1gLFxuICAgICAgICB9XG4gICAgICA6IHt9LFxuICAgIGJhY2tncm91bmQ6IGRpc2FibGVkID8gdGhlbWUuSW5wdXQuYmFja2dyb3VuZENvbG9yRGlzYWJsZWQgOiB0aGVtZS5JbnB1dC5iYWNrZ3JvdW5kQ29sb3IsXG4gICAgYm9yZGVyOiAnbm9uZScsXG4gICAgYm9yZGVyUmFkaXVzOiAnNHB4JyxcbiAgICBib3hTaGFkb3c6IG1hcmtJbnZhbGlkID8gYDAgMCAwIDFweCAke0NPTE9SX1YyLlJFRH1gIDogYDAgMCAwIDFweCAke0NPTE9SX1YyLkdSQVlfNDB9YCxcbiAgICBjYXJldENvbG9yOiBDT0xPUl9WMi5CTFVFLFxuICAgIGNvbG9yOiB0aGVtZS5nZW5lcmFsLmNvbG9yLFxuICAgIGZvbnRXZWlnaHQ6IDMwMCxcbiAgICBoZWlnaHQ6ICc0OHB4JyxcbiAgICBsaW5lSGVpZ2h0OiAnMjRweCcsXG4gICAgb3V0bGluZTogJ25vbmUnLFxuICAgIHBhZGRpbmc6ICcwIDE2cHgnLFxuICAgIHdpZHRoOiAnMTAwJScsXG4gIH07XG59O1xuXG5leHBvcnQgY29uc3QgSU5QVVRfQ0xBU1NOQU1FID0gJ3dpcmVpbnB1dCc7XG5leHBvcnQgY29uc3QgSU5QVVRfR1JPVVAgPSAnaW5wdXQtZ3JvdXAnO1xuXG5jb25zdCBmaWx0ZXJJbnB1dFByb3BzID0gKHByb3BzOiBJbnB1dFByb3BzKSA9PiBmaWx0ZXJQcm9wcyhwcm9wcywgWydtYXJrSW52YWxpZCcsICdwbGFjZWhvbGRlclRleHRUcmFuc2Zvcm0nXSk7XG5cbmNvbnN0IGNlbnRlcklucHV0QWN0aW9uOiBDU1NPYmplY3QgPSB7XG4gIHBvc2l0aW9uOiAnYWJzb2x1dGUnLFxuICByaWdodDogJzE2cHgnLFxuICB0b3A6ICc1MCUnLFxuICB0cmFuc2Zvcm06ICd0cmFuc2xhdGVZKC01MCUpJyxcbn07XG5cbmV4cG9ydCBjb25zdCBJbnB1dDogUmVhY3QuRkM8SW5wdXRQcm9wczxIVE1MSW5wdXRFbGVtZW50Pj4gPSBSZWFjdC5mb3J3YXJkUmVmPFxuICBIVE1MSW5wdXRFbGVtZW50LFxuICBJbnB1dFByb3BzPEhUTUxJbnB1dEVsZW1lbnQ+XG4+KCh7dHlwZSwgbGFiZWwsIGVycm9yLCBoZWxwZXJUZXh0LCAuLi5wcm9wc30sIHJlZikgPT4ge1xuICBjb25zdCBbdG9nZ2xlUGFzc3dvcmQsIHNldFRvZ2dsZVBhc3N3b3JkXSA9IHVzZVN0YXRlPGJvb2xlYW4+KGZhbHNlKTtcblxuICBjb25zdCBoYXNFcnJvciA9ICEhZXJyb3I7XG4gIGNvbnN0IGlzUGFzc3dvcmRJbnB1dCA9IHR5cGUgPT09ICdwYXNzd29yZCc7XG4gIGNvbnN0IHRvZ2dsZWRQYXNzd29yZFR5cGUgPSB0b2dnbGVQYXNzd29yZCA/ICd0ZXh0JyA6ICdwYXNzd29yZCc7XG5cbiAgY29uc3QgdG9nZ2xlU2V0UGFzc3dvcmQgPSAoKSA9PiBzZXRUb2dnbGVQYXNzd29yZChwcmV2U3RhdGUgPT4gIXByZXZTdGF0ZSk7XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2XG4gICAgICBjbGFzc05hbWU9e0lOUFVUX0dST1VQfVxuICAgICAgY3NzPXt7XG4gICAgICAgIG1hcmdpbkJvdHRvbTogaGFzRXJyb3IgPyAnMnB4JyA6ICcyMHB4JyxcbiAgICAgICAgJyY6Zm9jdXMtd2l0aGluIGxhYmVsJzoge1xuICAgICAgICAgIGNvbG9yOiBDT0xPUl9WMi5CTFVFLFxuICAgICAgICB9LFxuICAgICAgfX1cbiAgICA+XG4gICAgICB7bGFiZWwgJiYgKFxuICAgICAgICA8SW5wdXRMYWJlbCBodG1sRm9yPXtwcm9wcy5pZH0gaXNSZXF1aXJlZD17cHJvcHMucmVxdWlyZWR9IG1hcmtJbnZhbGlkPXtwcm9wcy5tYXJrSW52YWxpZH0+XG4gICAgICAgICAge2xhYmVsfVxuICAgICAgICA8L0lucHV0TGFiZWw+XG4gICAgICApfVxuXG4gICAgICA8ZGl2IGNzcz17e21hcmdpbkJvdHRvbTogaGFzRXJyb3IgJiYgJzhweCcsIHBvc2l0aW9uOiAncmVsYXRpdmUnfX0+XG4gICAgICAgIDxpbnB1dFxuICAgICAgICAgIGNsYXNzTmFtZT17SU5QVVRfQ0xBU1NOQU1FfVxuICAgICAgICAgIGNzcz17KHRoZW1lOiBUaGVtZSkgPT4gaW5wdXRTdHlsZSh0aGVtZSwgcHJvcHMsIGhhc0Vycm9yKX1cbiAgICAgICAgICByZWY9e3JlZn1cbiAgICAgICAgICB0eXBlPXtpc1Bhc3N3b3JkSW5wdXQgPyB0b2dnbGVkUGFzc3dvcmRUeXBlIDogdHlwZX1cbiAgICAgICAgICBhcmlhLXJlcXVpcmVkPXtwcm9wcy5yZXF1aXJlZH1cbiAgICAgICAgICB7Li4uZmlsdGVySW5wdXRQcm9wcyhwcm9wcyl9XG4gICAgICAgIC8+XG5cbiAgICAgICAge2hhc0Vycm9yICYmICFpc1Bhc3N3b3JkSW5wdXQgJiYgKFxuICAgICAgICAgIDxFcnJvckljb24gY3NzPXtjZW50ZXJJbnB1dEFjdGlvbn0gd2lkdGg9ezE2fSBoZWlnaHQ9ezE2fSBhcmlhLWhpZGRlbj1cInRydWVcIiAvPlxuICAgICAgICApfVxuXG4gICAgICAgIHtpc1Bhc3N3b3JkSW5wdXQgJiYgKFxuICAgICAgICAgIDxidXR0b25cbiAgICAgICAgICAgIHR5cGU9XCJidXR0b25cIlxuICAgICAgICAgICAgY3NzPXt7Li4uY2VudGVySW5wdXRBY3Rpb24sIGJhY2tncm91bmQ6ICd0cmFuc3BhcmVudCcsIGJvcmRlcjogJ25vbmUnLCBjdXJzb3I6ICdwb2ludGVyJywgcGFkZGluZzogMH19XG4gICAgICAgICAgICBvbkNsaWNrPXt0b2dnbGVTZXRQYXNzd29yZH1cbiAgICAgICAgICAgIHRpdGxlPVwiVG9nZ2xlIHBhc3N3b3JkIHZpc2liaWxpdHlcIlxuICAgICAgICAgICAgYXJpYS1jb250cm9scz17cHJvcHMuaWR9XG4gICAgICAgICAgICBhcmlhLWV4cGFuZGVkPXt0b2dnbGVQYXNzd29yZH1cbiAgICAgICAgICA+XG4gICAgICAgICAgICB7dG9nZ2xlUGFzc3dvcmQgPyA8SGlkZUljb24gY29sb3I9e0NPTE9SX1YyLkJMQUNLfSAvPiA6IDxTaG93SWNvbiBjb2xvcj17Q09MT1JfVjIuQkxBQ0t9IC8+fVxuICAgICAgICAgIDwvYnV0dG9uPlxuICAgICAgICApfVxuICAgICAgPC9kaXY+XG5cbiAgICAgIHshaGFzRXJyb3IgJiYgaGVscGVyVGV4dCAmJiAoXG4gICAgICAgIDxwIGNzcz17e2ZvbnRTaXplOiAnMTJweCcsIGZvbnRXZWlnaHQ6IDQwMCwgY29sb3I6IENPTE9SX1YyLkdSQVlfODAsIG1hcmdpblRvcDogOH19PntoZWxwZXJUZXh0fTwvcD5cbiAgICAgICl9XG5cbiAgICAgIHtlcnJvcn1cbiAgICA8L2Rpdj5cbiAgKTtcbn0pO1xuIl19 */")
|
|
137
|
+
}, (0, _react.jsx)("input", (0, _extends2["default"])({
|
|
82
138
|
className: INPUT_CLASSNAME,
|
|
83
139
|
css: function css(theme) {
|
|
84
|
-
return inputStyle(theme, props);
|
|
140
|
+
return inputStyle(theme, props, hasError);
|
|
85
141
|
},
|
|
86
142
|
ref: ref,
|
|
87
|
-
type: type
|
|
88
|
-
|
|
143
|
+
type: isPasswordInput ? toggledPasswordType : type,
|
|
144
|
+
"aria-required": props.required
|
|
145
|
+
}, filterInputProps(props))), hasError && !isPasswordInput && (0, _react.jsx)(_Icon.ErrorIcon, {
|
|
146
|
+
css: centerInputAction,
|
|
147
|
+
width: 16,
|
|
148
|
+
height: 16,
|
|
149
|
+
"aria-hidden": "true"
|
|
150
|
+
}), isPasswordInput && (0, _react.jsx)("button", {
|
|
151
|
+
type: "button",
|
|
152
|
+
css: /*#__PURE__*/(0, _react.css)(_objectSpread(_objectSpread({}, centerInputAction), {}, {
|
|
153
|
+
background: 'transparent',
|
|
154
|
+
border: 'none',
|
|
155
|
+
cursor: 'pointer',
|
|
156
|
+
padding: 0
|
|
157
|
+
}), process.env.NODE_ENV === "production" ? "" : ";label:Input;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIklucHV0LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE0SVkiLCJmaWxlIjoiSW5wdXQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIFdpcmVcbiAqIENvcHlyaWdodCAoQykgMjAxOCBXaXJlIFN3aXNzIEdtYkhcbiAqXG4gKiBUaGlzIHByb2dyYW0gaXMgZnJlZSBzb2Z0d2FyZTogeW91IGNhbiByZWRpc3RyaWJ1dGUgaXQgYW5kL29yIG1vZGlmeVxuICogaXQgdW5kZXIgdGhlIHRlcm1zIG9mIHRoZSBHTlUgR2VuZXJhbCBQdWJsaWMgTGljZW5zZSBhcyBwdWJsaXNoZWQgYnlcbiAqIHRoZSBGcmVlIFNvZnR3YXJlIEZvdW5kYXRpb24sIGVpdGhlciB2ZXJzaW9uIDMgb2YgdGhlIExpY2Vuc2UsIG9yXG4gKiAoYXQgeW91ciBvcHRpb24pIGFueSBsYXRlciB2ZXJzaW9uLlxuICpcbiAqIFRoaXMgcHJvZ3JhbSBpcyBkaXN0cmlidXRlZCBpbiB0aGUgaG9wZSB0aGF0IGl0IHdpbGwgYmUgdXNlZnVsLFxuICogYnV0IFdJVEhPVVQgQU5ZIFdBUlJBTlRZOyB3aXRob3V0IGV2ZW4gdGhlIGltcGxpZWQgd2FycmFudHkgb2ZcbiAqIE1FUkNIQU5UQUJJTElUWSBvciBGSVRORVNTIEZPUiBBIFBBUlRJQ1VMQVIgUFVSUE9TRS4gU2VlIHRoZVxuICogR05VIEdlbmVyYWwgUHVibGljIExpY2Vuc2UgZm9yIG1vcmUgZGV0YWlscy5cbiAqXG4gKiBZb3Ugc2hvdWxkIGhhdmUgcmVjZWl2ZWQgYSBjb3B5IG9mIHRoZSBHTlUgR2VuZXJhbCBQdWJsaWMgTGljZW5zZVxuICogYWxvbmcgd2l0aCB0aGlzIHByb2dyYW0uIElmIG5vdCwgc2VlIGh0dHA6Ly93d3cuZ251Lm9yZy9saWNlbnNlcy8uXG4gKlxuICovXG5cbi8qKiBAanN4IGpzeCAqL1xuaW1wb3J0IHtDU1NPYmplY3QsIGpzeH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHR5cGUge1Byb3BlcnR5fSBmcm9tICdjc3N0eXBlJztcbmltcG9ydCBSZWFjdCwge1JlYWN0RWxlbWVudCwgdXNlU3RhdGV9IGZyb20gJ3JlYWN0JztcblxuaW1wb3J0IHtDT0xPUl9WMn0gZnJvbSAnLi4vSWRlbnRpdHknO1xuaW1wb3J0IHR5cGUge1RoZW1lfSBmcm9tICcuLi9MYXlvdXQnO1xuaW1wb3J0IHR5cGUge1RleHRQcm9wc30gZnJvbSAnLi4vVGV4dCc7XG5pbXBvcnQge2ZpbHRlclByb3BzfSBmcm9tICcuLi91dGlsJztcbmltcG9ydCB7RXJyb3JJY29uLCBIaWRlSWNvbiwgU2hvd0ljb259IGZyb20gJy4uL0ljb24nO1xuaW1wb3J0IElucHV0TGFiZWwgZnJvbSAnLi9JbnB1dExhYmVsJztcblxuZXhwb3J0IGludGVyZmFjZSBJbnB1dFByb3BzPFQgPSBIVE1MSW5wdXRFbGVtZW50PiBleHRlbmRzIFRleHRQcm9wczxUPiB7XG4gIGxhYmVsPzogc3RyaW5nO1xuICBlcnJvcj86IFJlYWN0RWxlbWVudDtcbiAgbWFya0ludmFsaWQ/OiBib29sZWFuO1xuICBoZWxwZXJUZXh0Pzogc3RyaW5nO1xuICBwbGFjZWhvbGRlclRleHRUcmFuc2Zvcm0/OiBQcm9wZXJ0eS5UZXh0VHJhbnNmb3JtO1xufVxuXG5leHBvcnQgY29uc3QgaW5wdXRTdHlsZTogPFQ+KHRoZW1lOiBUaGVtZSwgcHJvcHM6IElucHV0UHJvcHM8VD4sIGhhc0Vycm9yPzogYm9vbGVhbikgPT4gQ1NTT2JqZWN0ID0gKFxuICB0aGVtZSxcbiAge21hcmtJbnZhbGlkID0gZmFsc2UsIHBsYWNlaG9sZGVyVGV4dFRyYW5zZm9ybSA9ICdub25lJywgZGlzYWJsZWQgPSBmYWxzZX0sXG4pID0+IHtcbiAgY29uc3QgcGxhY2Vob2xkZXJTdHlsZSA9IHtcbiAgICBjb2xvcjogdGhlbWUuSW5wdXQucGxhY2Vob2xkZXJDb2xvcixcbiAgICBmb250U2l6ZTogJzE2cHgnLFxuICAgIHRleHRUcmFuc2Zvcm06IHBsYWNlaG9sZGVyVGV4dFRyYW5zZm9ybSxcbiAgfTtcblxuICByZXR1cm4ge1xuICAgICcmOjotbW96LXBsYWNlaG9sZGVyJzoge1xuICAgICAgLi4ucGxhY2Vob2xkZXJTdHlsZSxcbiAgICAgIG9wYWNpdHk6IDEsXG4gICAgfSxcbiAgICAnJjo6LW1zLWlucHV0LXBsYWNlaG9sZGVyJzoge1xuICAgICAgLi4ucGxhY2Vob2xkZXJTdHlsZSxcbiAgICB9LFxuICAgICcmOjotd2Via2l0LWlucHV0LXBsYWNlaG9sZGVyJzoge1xuICAgICAgLi4ucGxhY2Vob2xkZXJTdHlsZSxcbiAgICB9LFxuICAgICcmOmZvY3VzJzoge1xuICAgICAgYm94U2hhZG93OiBgMCAwIDAgMXB4ICR7Q09MT1JfVjIuQkxVRX1gLFxuICAgIH0sXG4gICAgJyY6aW52YWxpZDpub3QoOmZvY3VzKSc6ICFtYXJrSW52YWxpZFxuICAgICAgPyB7XG4gICAgICAgICAgYm94U2hhZG93OiBgMCAwIDAgMXB4ICR7Q09MT1JfVjIuR1JBWX1gLFxuICAgICAgICB9XG4gICAgICA6IHt9LFxuICAgIGJhY2tncm91bmQ6IGRpc2FibGVkID8gdGhlbWUuSW5wdXQuYmFja2dyb3VuZENvbG9yRGlzYWJsZWQgOiB0aGVtZS5JbnB1dC5iYWNrZ3JvdW5kQ29sb3IsXG4gICAgYm9yZGVyOiAnbm9uZScsXG4gICAgYm9yZGVyUmFkaXVzOiAnNHB4JyxcbiAgICBib3hTaGFkb3c6IG1hcmtJbnZhbGlkID8gYDAgMCAwIDFweCAke0NPTE9SX1YyLlJFRH1gIDogYDAgMCAwIDFweCAke0NPTE9SX1YyLkdSQVlfNDB9YCxcbiAgICBjYXJldENvbG9yOiBDT0xPUl9WMi5CTFVFLFxuICAgIGNvbG9yOiB0aGVtZS5nZW5lcmFsLmNvbG9yLFxuICAgIGZvbnRXZWlnaHQ6IDMwMCxcbiAgICBoZWlnaHQ6ICc0OHB4JyxcbiAgICBsaW5lSGVpZ2h0OiAnMjRweCcsXG4gICAgb3V0bGluZTogJ25vbmUnLFxuICAgIHBhZGRpbmc6ICcwIDE2cHgnLFxuICAgIHdpZHRoOiAnMTAwJScsXG4gIH07XG59O1xuXG5leHBvcnQgY29uc3QgSU5QVVRfQ0xBU1NOQU1FID0gJ3dpcmVpbnB1dCc7XG5leHBvcnQgY29uc3QgSU5QVVRfR1JPVVAgPSAnaW5wdXQtZ3JvdXAnO1xuXG5jb25zdCBmaWx0ZXJJbnB1dFByb3BzID0gKHByb3BzOiBJbnB1dFByb3BzKSA9PiBmaWx0ZXJQcm9wcyhwcm9wcywgWydtYXJrSW52YWxpZCcsICdwbGFjZWhvbGRlclRleHRUcmFuc2Zvcm0nXSk7XG5cbmNvbnN0IGNlbnRlcklucHV0QWN0aW9uOiBDU1NPYmplY3QgPSB7XG4gIHBvc2l0aW9uOiAnYWJzb2x1dGUnLFxuICByaWdodDogJzE2cHgnLFxuICB0b3A6ICc1MCUnLFxuICB0cmFuc2Zvcm06ICd0cmFuc2xhdGVZKC01MCUpJyxcbn07XG5cbmV4cG9ydCBjb25zdCBJbnB1dDogUmVhY3QuRkM8SW5wdXRQcm9wczxIVE1MSW5wdXRFbGVtZW50Pj4gPSBSZWFjdC5mb3J3YXJkUmVmPFxuICBIVE1MSW5wdXRFbGVtZW50LFxuICBJbnB1dFByb3BzPEhUTUxJbnB1dEVsZW1lbnQ+XG4+KCh7dHlwZSwgbGFiZWwsIGVycm9yLCBoZWxwZXJUZXh0LCAuLi5wcm9wc30sIHJlZikgPT4ge1xuICBjb25zdCBbdG9nZ2xlUGFzc3dvcmQsIHNldFRvZ2dsZVBhc3N3b3JkXSA9IHVzZVN0YXRlPGJvb2xlYW4+KGZhbHNlKTtcblxuICBjb25zdCBoYXNFcnJvciA9ICEhZXJyb3I7XG4gIGNvbnN0IGlzUGFzc3dvcmRJbnB1dCA9IHR5cGUgPT09ICdwYXNzd29yZCc7XG4gIGNvbnN0IHRvZ2dsZWRQYXNzd29yZFR5cGUgPSB0b2dnbGVQYXNzd29yZCA/ICd0ZXh0JyA6ICdwYXNzd29yZCc7XG5cbiAgY29uc3QgdG9nZ2xlU2V0UGFzc3dvcmQgPSAoKSA9PiBzZXRUb2dnbGVQYXNzd29yZChwcmV2U3RhdGUgPT4gIXByZXZTdGF0ZSk7XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2XG4gICAgICBjbGFzc05hbWU9e0lOUFVUX0dST1VQfVxuICAgICAgY3NzPXt7XG4gICAgICAgIG1hcmdpbkJvdHRvbTogaGFzRXJyb3IgPyAnMnB4JyA6ICcyMHB4JyxcbiAgICAgICAgJyY6Zm9jdXMtd2l0aGluIGxhYmVsJzoge1xuICAgICAgICAgIGNvbG9yOiBDT0xPUl9WMi5CTFVFLFxuICAgICAgICB9LFxuICAgICAgfX1cbiAgICA+XG4gICAgICB7bGFiZWwgJiYgKFxuICAgICAgICA8SW5wdXRMYWJlbCBodG1sRm9yPXtwcm9wcy5pZH0gaXNSZXF1aXJlZD17cHJvcHMucmVxdWlyZWR9IG1hcmtJbnZhbGlkPXtwcm9wcy5tYXJrSW52YWxpZH0+XG4gICAgICAgICAge2xhYmVsfVxuICAgICAgICA8L0lucHV0TGFiZWw+XG4gICAgICApfVxuXG4gICAgICA8ZGl2IGNzcz17e21hcmdpbkJvdHRvbTogaGFzRXJyb3IgJiYgJzhweCcsIHBvc2l0aW9uOiAncmVsYXRpdmUnfX0+XG4gICAgICAgIDxpbnB1dFxuICAgICAgICAgIGNsYXNzTmFtZT17SU5QVVRfQ0xBU1NOQU1FfVxuICAgICAgICAgIGNzcz17KHRoZW1lOiBUaGVtZSkgPT4gaW5wdXRTdHlsZSh0aGVtZSwgcHJvcHMsIGhhc0Vycm9yKX1cbiAgICAgICAgICByZWY9e3JlZn1cbiAgICAgICAgICB0eXBlPXtpc1Bhc3N3b3JkSW5wdXQgPyB0b2dnbGVkUGFzc3dvcmRUeXBlIDogdHlwZX1cbiAgICAgICAgICBhcmlhLXJlcXVpcmVkPXtwcm9wcy5yZXF1aXJlZH1cbiAgICAgICAgICB7Li4uZmlsdGVySW5wdXRQcm9wcyhwcm9wcyl9XG4gICAgICAgIC8+XG5cbiAgICAgICAge2hhc0Vycm9yICYmICFpc1Bhc3N3b3JkSW5wdXQgJiYgKFxuICAgICAgICAgIDxFcnJvckljb24gY3NzPXtjZW50ZXJJbnB1dEFjdGlvbn0gd2lkdGg9ezE2fSBoZWlnaHQ9ezE2fSBhcmlhLWhpZGRlbj1cInRydWVcIiAvPlxuICAgICAgICApfVxuXG4gICAgICAgIHtpc1Bhc3N3b3JkSW5wdXQgJiYgKFxuICAgICAgICAgIDxidXR0b25cbiAgICAgICAgICAgIHR5cGU9XCJidXR0b25cIlxuICAgICAgICAgICAgY3NzPXt7Li4uY2VudGVySW5wdXRBY3Rpb24sIGJhY2tncm91bmQ6ICd0cmFuc3BhcmVudCcsIGJvcmRlcjogJ25vbmUnLCBjdXJzb3I6ICdwb2ludGVyJywgcGFkZGluZzogMH19XG4gICAgICAgICAgICBvbkNsaWNrPXt0b2dnbGVTZXRQYXNzd29yZH1cbiAgICAgICAgICAgIHRpdGxlPVwiVG9nZ2xlIHBhc3N3b3JkIHZpc2liaWxpdHlcIlxuICAgICAgICAgICAgYXJpYS1jb250cm9scz17cHJvcHMuaWR9XG4gICAgICAgICAgICBhcmlhLWV4cGFuZGVkPXt0b2dnbGVQYXNzd29yZH1cbiAgICAgICAgICA+XG4gICAgICAgICAgICB7dG9nZ2xlUGFzc3dvcmQgPyA8SGlkZUljb24gY29sb3I9e0NPTE9SX1YyLkJMQUNLfSAvPiA6IDxTaG93SWNvbiBjb2xvcj17Q09MT1JfVjIuQkxBQ0t9IC8+fVxuICAgICAgICAgIDwvYnV0dG9uPlxuICAgICAgICApfVxuICAgICAgPC9kaXY+XG5cbiAgICAgIHshaGFzRXJyb3IgJiYgaGVscGVyVGV4dCAmJiAoXG4gICAgICAgIDxwIGNzcz17e2ZvbnRTaXplOiAnMTJweCcsIGZvbnRXZWlnaHQ6IDQwMCwgY29sb3I6IENPTE9SX1YyLkdSQVlfODAsIG1hcmdpblRvcDogOH19PntoZWxwZXJUZXh0fTwvcD5cbiAgICAgICl9XG5cbiAgICAgIHtlcnJvcn1cbiAgICA8L2Rpdj5cbiAgKTtcbn0pO1xuIl19 */"),
|
|
158
|
+
onClick: toggleSetPassword,
|
|
159
|
+
title: "Toggle password visibility",
|
|
160
|
+
"aria-controls": props.id,
|
|
161
|
+
"aria-expanded": togglePassword
|
|
162
|
+
}, togglePassword ? (0, _react.jsx)(_Icon.HideIcon, {
|
|
163
|
+
color: _Identity.COLOR_V2.BLACK
|
|
164
|
+
}) : (0, _react.jsx)(_Icon.ShowIcon, {
|
|
165
|
+
color: _Identity.COLOR_V2.BLACK
|
|
166
|
+
}))), !hasError && helperText && (0, _react.jsx)("p", {
|
|
167
|
+
css: /*#__PURE__*/(0, _react.css)({
|
|
168
|
+
fontSize: '12px',
|
|
169
|
+
fontWeight: 400,
|
|
170
|
+
color: _Identity.COLOR_V2.GRAY_80,
|
|
171
|
+
marginTop: 8
|
|
172
|
+
}, process.env.NODE_ENV === "production" ? "" : ";label:Input;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIklucHV0LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF3SlciLCJmaWxlIjoiSW5wdXQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIFdpcmVcbiAqIENvcHlyaWdodCAoQykgMjAxOCBXaXJlIFN3aXNzIEdtYkhcbiAqXG4gKiBUaGlzIHByb2dyYW0gaXMgZnJlZSBzb2Z0d2FyZTogeW91IGNhbiByZWRpc3RyaWJ1dGUgaXQgYW5kL29yIG1vZGlmeVxuICogaXQgdW5kZXIgdGhlIHRlcm1zIG9mIHRoZSBHTlUgR2VuZXJhbCBQdWJsaWMgTGljZW5zZSBhcyBwdWJsaXNoZWQgYnlcbiAqIHRoZSBGcmVlIFNvZnR3YXJlIEZvdW5kYXRpb24sIGVpdGhlciB2ZXJzaW9uIDMgb2YgdGhlIExpY2Vuc2UsIG9yXG4gKiAoYXQgeW91ciBvcHRpb24pIGFueSBsYXRlciB2ZXJzaW9uLlxuICpcbiAqIFRoaXMgcHJvZ3JhbSBpcyBkaXN0cmlidXRlZCBpbiB0aGUgaG9wZSB0aGF0IGl0IHdpbGwgYmUgdXNlZnVsLFxuICogYnV0IFdJVEhPVVQgQU5ZIFdBUlJBTlRZOyB3aXRob3V0IGV2ZW4gdGhlIGltcGxpZWQgd2FycmFudHkgb2ZcbiAqIE1FUkNIQU5UQUJJTElUWSBvciBGSVRORVNTIEZPUiBBIFBBUlRJQ1VMQVIgUFVSUE9TRS4gU2VlIHRoZVxuICogR05VIEdlbmVyYWwgUHVibGljIExpY2Vuc2UgZm9yIG1vcmUgZGV0YWlscy5cbiAqXG4gKiBZb3Ugc2hvdWxkIGhhdmUgcmVjZWl2ZWQgYSBjb3B5IG9mIHRoZSBHTlUgR2VuZXJhbCBQdWJsaWMgTGljZW5zZVxuICogYWxvbmcgd2l0aCB0aGlzIHByb2dyYW0uIElmIG5vdCwgc2VlIGh0dHA6Ly93d3cuZ251Lm9yZy9saWNlbnNlcy8uXG4gKlxuICovXG5cbi8qKiBAanN4IGpzeCAqL1xuaW1wb3J0IHtDU1NPYmplY3QsIGpzeH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHR5cGUge1Byb3BlcnR5fSBmcm9tICdjc3N0eXBlJztcbmltcG9ydCBSZWFjdCwge1JlYWN0RWxlbWVudCwgdXNlU3RhdGV9IGZyb20gJ3JlYWN0JztcblxuaW1wb3J0IHtDT0xPUl9WMn0gZnJvbSAnLi4vSWRlbnRpdHknO1xuaW1wb3J0IHR5cGUge1RoZW1lfSBmcm9tICcuLi9MYXlvdXQnO1xuaW1wb3J0IHR5cGUge1RleHRQcm9wc30gZnJvbSAnLi4vVGV4dCc7XG5pbXBvcnQge2ZpbHRlclByb3BzfSBmcm9tICcuLi91dGlsJztcbmltcG9ydCB7RXJyb3JJY29uLCBIaWRlSWNvbiwgU2hvd0ljb259IGZyb20gJy4uL0ljb24nO1xuaW1wb3J0IElucHV0TGFiZWwgZnJvbSAnLi9JbnB1dExhYmVsJztcblxuZXhwb3J0IGludGVyZmFjZSBJbnB1dFByb3BzPFQgPSBIVE1MSW5wdXRFbGVtZW50PiBleHRlbmRzIFRleHRQcm9wczxUPiB7XG4gIGxhYmVsPzogc3RyaW5nO1xuICBlcnJvcj86IFJlYWN0RWxlbWVudDtcbiAgbWFya0ludmFsaWQ/OiBib29sZWFuO1xuICBoZWxwZXJUZXh0Pzogc3RyaW5nO1xuICBwbGFjZWhvbGRlclRleHRUcmFuc2Zvcm0/OiBQcm9wZXJ0eS5UZXh0VHJhbnNmb3JtO1xufVxuXG5leHBvcnQgY29uc3QgaW5wdXRTdHlsZTogPFQ+KHRoZW1lOiBUaGVtZSwgcHJvcHM6IElucHV0UHJvcHM8VD4sIGhhc0Vycm9yPzogYm9vbGVhbikgPT4gQ1NTT2JqZWN0ID0gKFxuICB0aGVtZSxcbiAge21hcmtJbnZhbGlkID0gZmFsc2UsIHBsYWNlaG9sZGVyVGV4dFRyYW5zZm9ybSA9ICdub25lJywgZGlzYWJsZWQgPSBmYWxzZX0sXG4pID0+IHtcbiAgY29uc3QgcGxhY2Vob2xkZXJTdHlsZSA9IHtcbiAgICBjb2xvcjogdGhlbWUuSW5wdXQucGxhY2Vob2xkZXJDb2xvcixcbiAgICBmb250U2l6ZTogJzE2cHgnLFxuICAgIHRleHRUcmFuc2Zvcm06IHBsYWNlaG9sZGVyVGV4dFRyYW5zZm9ybSxcbiAgfTtcblxuICByZXR1cm4ge1xuICAgICcmOjotbW96LXBsYWNlaG9sZGVyJzoge1xuICAgICAgLi4ucGxhY2Vob2xkZXJTdHlsZSxcbiAgICAgIG9wYWNpdHk6IDEsXG4gICAgfSxcbiAgICAnJjo6LW1zLWlucHV0LXBsYWNlaG9sZGVyJzoge1xuICAgICAgLi4ucGxhY2Vob2xkZXJTdHlsZSxcbiAgICB9LFxuICAgICcmOjotd2Via2l0LWlucHV0LXBsYWNlaG9sZGVyJzoge1xuICAgICAgLi4ucGxhY2Vob2xkZXJTdHlsZSxcbiAgICB9LFxuICAgICcmOmZvY3VzJzoge1xuICAgICAgYm94U2hhZG93OiBgMCAwIDAgMXB4ICR7Q09MT1JfVjIuQkxVRX1gLFxuICAgIH0sXG4gICAgJyY6aW52YWxpZDpub3QoOmZvY3VzKSc6ICFtYXJrSW52YWxpZFxuICAgICAgPyB7XG4gICAgICAgICAgYm94U2hhZG93OiBgMCAwIDAgMXB4ICR7Q09MT1JfVjIuR1JBWX1gLFxuICAgICAgICB9XG4gICAgICA6IHt9LFxuICAgIGJhY2tncm91bmQ6IGRpc2FibGVkID8gdGhlbWUuSW5wdXQuYmFja2dyb3VuZENvbG9yRGlzYWJsZWQgOiB0aGVtZS5JbnB1dC5iYWNrZ3JvdW5kQ29sb3IsXG4gICAgYm9yZGVyOiAnbm9uZScsXG4gICAgYm9yZGVyUmFkaXVzOiAnNHB4JyxcbiAgICBib3hTaGFkb3c6IG1hcmtJbnZhbGlkID8gYDAgMCAwIDFweCAke0NPTE9SX1YyLlJFRH1gIDogYDAgMCAwIDFweCAke0NPTE9SX1YyLkdSQVlfNDB9YCxcbiAgICBjYXJldENvbG9yOiBDT0xPUl9WMi5CTFVFLFxuICAgIGNvbG9yOiB0aGVtZS5nZW5lcmFsLmNvbG9yLFxuICAgIGZvbnRXZWlnaHQ6IDMwMCxcbiAgICBoZWlnaHQ6ICc0OHB4JyxcbiAgICBsaW5lSGVpZ2h0OiAnMjRweCcsXG4gICAgb3V0bGluZTogJ25vbmUnLFxuICAgIHBhZGRpbmc6ICcwIDE2cHgnLFxuICAgIHdpZHRoOiAnMTAwJScsXG4gIH07XG59O1xuXG5leHBvcnQgY29uc3QgSU5QVVRfQ0xBU1NOQU1FID0gJ3dpcmVpbnB1dCc7XG5leHBvcnQgY29uc3QgSU5QVVRfR1JPVVAgPSAnaW5wdXQtZ3JvdXAnO1xuXG5jb25zdCBmaWx0ZXJJbnB1dFByb3BzID0gKHByb3BzOiBJbnB1dFByb3BzKSA9PiBmaWx0ZXJQcm9wcyhwcm9wcywgWydtYXJrSW52YWxpZCcsICdwbGFjZWhvbGRlclRleHRUcmFuc2Zvcm0nXSk7XG5cbmNvbnN0IGNlbnRlcklucHV0QWN0aW9uOiBDU1NPYmplY3QgPSB7XG4gIHBvc2l0aW9uOiAnYWJzb2x1dGUnLFxuICByaWdodDogJzE2cHgnLFxuICB0b3A6ICc1MCUnLFxuICB0cmFuc2Zvcm06ICd0cmFuc2xhdGVZKC01MCUpJyxcbn07XG5cbmV4cG9ydCBjb25zdCBJbnB1dDogUmVhY3QuRkM8SW5wdXRQcm9wczxIVE1MSW5wdXRFbGVtZW50Pj4gPSBSZWFjdC5mb3J3YXJkUmVmPFxuICBIVE1MSW5wdXRFbGVtZW50LFxuICBJbnB1dFByb3BzPEhUTUxJbnB1dEVsZW1lbnQ+XG4+KCh7dHlwZSwgbGFiZWwsIGVycm9yLCBoZWxwZXJUZXh0LCAuLi5wcm9wc30sIHJlZikgPT4ge1xuICBjb25zdCBbdG9nZ2xlUGFzc3dvcmQsIHNldFRvZ2dsZVBhc3N3b3JkXSA9IHVzZVN0YXRlPGJvb2xlYW4+KGZhbHNlKTtcblxuICBjb25zdCBoYXNFcnJvciA9ICEhZXJyb3I7XG4gIGNvbnN0IGlzUGFzc3dvcmRJbnB1dCA9IHR5cGUgPT09ICdwYXNzd29yZCc7XG4gIGNvbnN0IHRvZ2dsZWRQYXNzd29yZFR5cGUgPSB0b2dnbGVQYXNzd29yZCA/ICd0ZXh0JyA6ICdwYXNzd29yZCc7XG5cbiAgY29uc3QgdG9nZ2xlU2V0UGFzc3dvcmQgPSAoKSA9PiBzZXRUb2dnbGVQYXNzd29yZChwcmV2U3RhdGUgPT4gIXByZXZTdGF0ZSk7XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2XG4gICAgICBjbGFzc05hbWU9e0lOUFVUX0dST1VQfVxuICAgICAgY3NzPXt7XG4gICAgICAgIG1hcmdpbkJvdHRvbTogaGFzRXJyb3IgPyAnMnB4JyA6ICcyMHB4JyxcbiAgICAgICAgJyY6Zm9jdXMtd2l0aGluIGxhYmVsJzoge1xuICAgICAgICAgIGNvbG9yOiBDT0xPUl9WMi5CTFVFLFxuICAgICAgICB9LFxuICAgICAgfX1cbiAgICA+XG4gICAgICB7bGFiZWwgJiYgKFxuICAgICAgICA8SW5wdXRMYWJlbCBodG1sRm9yPXtwcm9wcy5pZH0gaXNSZXF1aXJlZD17cHJvcHMucmVxdWlyZWR9IG1hcmtJbnZhbGlkPXtwcm9wcy5tYXJrSW52YWxpZH0+XG4gICAgICAgICAge2xhYmVsfVxuICAgICAgICA8L0lucHV0TGFiZWw+XG4gICAgICApfVxuXG4gICAgICA8ZGl2IGNzcz17e21hcmdpbkJvdHRvbTogaGFzRXJyb3IgJiYgJzhweCcsIHBvc2l0aW9uOiAncmVsYXRpdmUnfX0+XG4gICAgICAgIDxpbnB1dFxuICAgICAgICAgIGNsYXNzTmFtZT17SU5QVVRfQ0xBU1NOQU1FfVxuICAgICAgICAgIGNzcz17KHRoZW1lOiBUaGVtZSkgPT4gaW5wdXRTdHlsZSh0aGVtZSwgcHJvcHMsIGhhc0Vycm9yKX1cbiAgICAgICAgICByZWY9e3JlZn1cbiAgICAgICAgICB0eXBlPXtpc1Bhc3N3b3JkSW5wdXQgPyB0b2dnbGVkUGFzc3dvcmRUeXBlIDogdHlwZX1cbiAgICAgICAgICBhcmlhLXJlcXVpcmVkPXtwcm9wcy5yZXF1aXJlZH1cbiAgICAgICAgICB7Li4uZmlsdGVySW5wdXRQcm9wcyhwcm9wcyl9XG4gICAgICAgIC8+XG5cbiAgICAgICAge2hhc0Vycm9yICYmICFpc1Bhc3N3b3JkSW5wdXQgJiYgKFxuICAgICAgICAgIDxFcnJvckljb24gY3NzPXtjZW50ZXJJbnB1dEFjdGlvbn0gd2lkdGg9ezE2fSBoZWlnaHQ9ezE2fSBhcmlhLWhpZGRlbj1cInRydWVcIiAvPlxuICAgICAgICApfVxuXG4gICAgICAgIHtpc1Bhc3N3b3JkSW5wdXQgJiYgKFxuICAgICAgICAgIDxidXR0b25cbiAgICAgICAgICAgIHR5cGU9XCJidXR0b25cIlxuICAgICAgICAgICAgY3NzPXt7Li4uY2VudGVySW5wdXRBY3Rpb24sIGJhY2tncm91bmQ6ICd0cmFuc3BhcmVudCcsIGJvcmRlcjogJ25vbmUnLCBjdXJzb3I6ICdwb2ludGVyJywgcGFkZGluZzogMH19XG4gICAgICAgICAgICBvbkNsaWNrPXt0b2dnbGVTZXRQYXNzd29yZH1cbiAgICAgICAgICAgIHRpdGxlPVwiVG9nZ2xlIHBhc3N3b3JkIHZpc2liaWxpdHlcIlxuICAgICAgICAgICAgYXJpYS1jb250cm9scz17cHJvcHMuaWR9XG4gICAgICAgICAgICBhcmlhLWV4cGFuZGVkPXt0b2dnbGVQYXNzd29yZH1cbiAgICAgICAgICA+XG4gICAgICAgICAgICB7dG9nZ2xlUGFzc3dvcmQgPyA8SGlkZUljb24gY29sb3I9e0NPTE9SX1YyLkJMQUNLfSAvPiA6IDxTaG93SWNvbiBjb2xvcj17Q09MT1JfVjIuQkxBQ0t9IC8+fVxuICAgICAgICAgIDwvYnV0dG9uPlxuICAgICAgICApfVxuICAgICAgPC9kaXY+XG5cbiAgICAgIHshaGFzRXJyb3IgJiYgaGVscGVyVGV4dCAmJiAoXG4gICAgICAgIDxwIGNzcz17e2ZvbnRTaXplOiAnMTJweCcsIGZvbnRXZWlnaHQ6IDQwMCwgY29sb3I6IENPTE9SX1YyLkdSQVlfODAsIG1hcmdpblRvcDogOH19PntoZWxwZXJUZXh0fTwvcD5cbiAgICAgICl9XG5cbiAgICAgIHtlcnJvcn1cbiAgICA8L2Rpdj5cbiAgKTtcbn0pO1xuIl19 */")
|
|
173
|
+
}, helperText), error);
|
|
89
174
|
});
|
|
90
175
|
|
|
91
176
|
exports.Input = Input;
|
package/src/Form/Input.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["Input.tsx"],"names":["inputStyle","theme","markInvalid","placeholderTextTransform","disabled","placeholderStyle","color","Input","placeholderColor","fontSize","textTransform","opacity","boxShadow","
|
|
1
|
+
{"version":3,"sources":["Input.tsx"],"names":["inputStyle","theme","markInvalid","placeholderTextTransform","disabled","placeholderStyle","color","Input","placeholderColor","fontSize","textTransform","opacity","boxShadow","COLOR_V2","BLUE","GRAY","background","backgroundColorDisabled","backgroundColor","border","borderRadius","RED","GRAY_40","caretColor","general","fontWeight","height","lineHeight","outline","padding","width","INPUT_CLASSNAME","INPUT_GROUP","filterInputProps","props","centerInputAction","position","right","top","transform","React","forwardRef","ref","type","label","error","helperText","togglePassword","setTogglePassword","hasError","isPasswordInput","toggledPasswordType","toggleSetPassword","prevState","marginBottom","id","required","cursor","BLACK","GRAY_80","marginTop"],"mappings":"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","sourcesContent":["/*\n * Wire\n * Copyright (C) 2018 Wire Swiss GmbH\n *\n * This program is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * This program is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n *\n * You should have received a copy of the GNU General Public License\n * along with this program. If not, see http://www.gnu.org/licenses/.\n *\n */\n\n/** @jsx jsx */\nimport {CSSObject, jsx} from '@emotion/react';\nimport type {Property} from 'csstype';\nimport React, {ReactElement, useState} from 'react';\n\nimport {COLOR_V2} from '../Identity';\nimport type {Theme} from '../Layout';\nimport type {TextProps} from '../Text';\nimport {filterProps} from '../util';\nimport {ErrorIcon, HideIcon, ShowIcon} from '../Icon';\nimport InputLabel from './InputLabel';\n\nexport interface InputProps<T = HTMLInputElement> extends TextProps<T> {\n label?: string;\n error?: ReactElement;\n markInvalid?: boolean;\n helperText?: string;\n placeholderTextTransform?: Property.TextTransform;\n}\n\nexport const inputStyle: <T>(theme: Theme, props: InputProps<T>, hasError?: boolean) => CSSObject = (\n theme,\n {markInvalid = false, placeholderTextTransform = 'none', disabled = false},\n) => {\n const placeholderStyle = {\n color: theme.Input.placeholderColor,\n fontSize: '16px',\n textTransform: placeholderTextTransform,\n };\n\n return {\n '&::-moz-placeholder': {\n ...placeholderStyle,\n opacity: 1,\n },\n '&::-ms-input-placeholder': {\n ...placeholderStyle,\n },\n '&::-webkit-input-placeholder': {\n ...placeholderStyle,\n },\n '&:focus': {\n boxShadow: `0 0 0 1px ${COLOR_V2.BLUE}`,\n },\n '&:invalid:not(:focus)': !markInvalid\n ? {\n boxShadow: `0 0 0 1px ${COLOR_V2.GRAY}`,\n }\n : {},\n background: disabled ? theme.Input.backgroundColorDisabled : theme.Input.backgroundColor,\n border: 'none',\n borderRadius: '4px',\n boxShadow: markInvalid ? `0 0 0 1px ${COLOR_V2.RED}` : `0 0 0 1px ${COLOR_V2.GRAY_40}`,\n caretColor: COLOR_V2.BLUE,\n color: theme.general.color,\n fontWeight: 300,\n height: '48px',\n lineHeight: '24px',\n outline: 'none',\n padding: '0 16px',\n width: '100%',\n };\n};\n\nexport const INPUT_CLASSNAME = 'wireinput';\nexport const INPUT_GROUP = 'input-group';\n\nconst filterInputProps = (props: InputProps) => filterProps(props, ['markInvalid', 'placeholderTextTransform']);\n\nconst centerInputAction: CSSObject = {\n position: 'absolute',\n right: '16px',\n top: '50%',\n transform: 'translateY(-50%)',\n};\n\nexport const Input: React.FC<InputProps<HTMLInputElement>> = React.forwardRef<\n HTMLInputElement,\n InputProps<HTMLInputElement>\n>(({type, label, error, helperText, ...props}, ref) => {\n const [togglePassword, setTogglePassword] = useState<boolean>(false);\n\n const hasError = !!error;\n const isPasswordInput = type === 'password';\n const toggledPasswordType = togglePassword ? 'text' : 'password';\n\n const toggleSetPassword = () => setTogglePassword(prevState => !prevState);\n\n return (\n <div\n className={INPUT_GROUP}\n css={{\n marginBottom: hasError ? '2px' : '20px',\n '&:focus-within label': {\n color: COLOR_V2.BLUE,\n },\n }}\n >\n {label && (\n <InputLabel htmlFor={props.id} isRequired={props.required} markInvalid={props.markInvalid}>\n {label}\n </InputLabel>\n )}\n\n <div css={{marginBottom: hasError && '8px', position: 'relative'}}>\n <input\n className={INPUT_CLASSNAME}\n css={(theme: Theme) => inputStyle(theme, props, hasError)}\n ref={ref}\n type={isPasswordInput ? toggledPasswordType : type}\n aria-required={props.required}\n {...filterInputProps(props)}\n />\n\n {hasError && !isPasswordInput && (\n <ErrorIcon css={centerInputAction} width={16} height={16} aria-hidden=\"true\" />\n )}\n\n {isPasswordInput && (\n <button\n type=\"button\"\n css={{...centerInputAction, background: 'transparent', border: 'none', cursor: 'pointer', padding: 0}}\n onClick={toggleSetPassword}\n title=\"Toggle password visibility\"\n aria-controls={props.id}\n aria-expanded={togglePassword}\n >\n {togglePassword ? <HideIcon color={COLOR_V2.BLACK} /> : <ShowIcon color={COLOR_V2.BLACK} />}\n </button>\n )}\n </div>\n\n {!hasError && helperText && (\n <p css={{fontSize: '12px', fontWeight: 400, color: COLOR_V2.GRAY_80, marginTop: 8}}>{helperText}</p>\n )}\n\n {error}\n </div>\n );\n});\n"],"file":"Input.js"}
|
package/src/Form/InputBlock.js
CHANGED
|
@@ -42,15 +42,19 @@ var _InputSubmitCombo = require("./InputSubmitCombo");
|
|
|
42
42
|
|
|
43
43
|
/** @jsx jsx */
|
|
44
44
|
var inputBlockStyle = function inputBlockStyle(props) {
|
|
45
|
-
|
|
45
|
+
var _ref;
|
|
46
|
+
|
|
47
|
+
return _ref = {
|
|
46
48
|
backgroundColor: _Identity.COLOR.GRAY_LIGHTEN_88,
|
|
47
49
|
borderRadius: '4px',
|
|
48
50
|
boxShadow: "inset 16px 16px 0 ".concat(_Identity.COLOR.WHITE, ", inset -16px -16px 0 ").concat(_Identity.COLOR.WHITE),
|
|
49
51
|
marginBottom: '16px'
|
|
50
|
-
}, ".".concat(_Input.INPUT_CLASSNAME, ", .").concat(_InputSubmitCombo.INPUT_SUBMIT_COMBO_CLASSNAME), {
|
|
52
|
+
}, (0, _defineProperty2["default"])(_ref, ".".concat(_Input.INPUT_CLASSNAME, ", .").concat(_InputSubmitCombo.INPUT_SUBMIT_COMBO_CLASSNAME), {
|
|
51
53
|
marginBottom: '1px !important',
|
|
52
54
|
marginTop: '0 !important'
|
|
53
|
-
})
|
|
55
|
+
}), (0, _defineProperty2["default"])(_ref, ".".concat(_Input.INPUT_GROUP), {
|
|
56
|
+
marginBottom: 0
|
|
57
|
+
}), _ref;
|
|
54
58
|
};
|
|
55
59
|
|
|
56
60
|
var InputBlock = function InputBlock(props) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["InputBlock.tsx"],"names":["inputBlockStyle","props","backgroundColor","COLOR","GRAY_LIGHTEN_88","borderRadius","boxShadow","WHITE","marginBottom","INPUT_CLASSNAME","INPUT_SUBMIT_COMBO_CLASSNAME","marginTop","InputBlock"],"mappings":";;;;;;;;;;;;;AAoBA;;AACA;;AAEA;;AACA;;AACA;;AAzBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AAUA,IAAMA,eAAsD,GAAG,SAAzDA,eAAyD,CAAAC,KAAK;AAAA;AAClEC,IAAAA,eAAe,EAAEC,gBAAMC,eAD2C;AAElEC,IAAAA,YAAY,EAAE,KAFoD;AAGlEC,IAAAA,SAAS,8BAAuBH,gBAAMI,KAA7B,mCAA2DJ,gBAAMI,KAAjE,CAHyD;AAIlEC,IAAAA,YAAY,EAAE;AAJoD,
|
|
1
|
+
{"version":3,"sources":["InputBlock.tsx"],"names":["inputBlockStyle","props","backgroundColor","COLOR","GRAY_LIGHTEN_88","borderRadius","boxShadow","WHITE","marginBottom","INPUT_CLASSNAME","INPUT_SUBMIT_COMBO_CLASSNAME","marginTop","INPUT_GROUP","InputBlock"],"mappings":";;;;;;;;;;;;;AAoBA;;AACA;;AAEA;;AACA;;AACA;;AAzBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AAUA,IAAMA,eAAsD,GAAG,SAAzDA,eAAyD,CAAAC,KAAK;AAAA;;AAAA;AAClEC,IAAAA,eAAe,EAAEC,gBAAMC,eAD2C;AAElEC,IAAAA,YAAY,EAAE,KAFoD;AAGlEC,IAAAA,SAAS,8BAAuBH,gBAAMI,KAA7B,mCAA2DJ,gBAAMI,KAAjE,CAHyD;AAIlEC,IAAAA,YAAY,EAAE;AAJoD,uDAK7DC,sBAL6D,gBAKxCC,8CALwC,GAKP;AACzDF,IAAAA,YAAY,EAAE,gBAD2C;AAEzDG,IAAAA,SAAS,EAAE;AAF8C,GALO,qDAS7DC,kBAT6D,GAS7C;AACnBJ,IAAAA,YAAY,EAAE;AADK,GAT6C;AAAA,CAApE;;AAcO,IAAMK,UAAU,GAAG,SAAbA,UAAa,CAACZ,KAAD;AAAA,SAA4B;AAAK,IAAA,GAAG,EAAED,eAAe,CAACC,KAAD;AAAzB,KAAsCA,KAAtC,EAA5B;AAAA,CAAnB","sourcesContent":["/*\n * Wire\n * Copyright (C) 2018 Wire Swiss GmbH\n *\n * This program is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * This program is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n *\n * You should have received a copy of the GNU General Public License\n * along with this program. If not, see http://www.gnu.org/licenses/.\n *\n */\n\n/** @jsx jsx */\nimport React from 'react';\nimport {CSSObject, jsx} from '@emotion/react';\n\nimport {COLOR} from '../Identity';\nimport {INPUT_CLASSNAME, INPUT_GROUP} from './Input';\nimport {INPUT_SUBMIT_COMBO_CLASSNAME} from './InputSubmitCombo';\n\nexport type InputBlockProps<T = HTMLDivElement> = React.HTMLProps<T>;\n\nconst inputBlockStyle: (props: InputBlockProps) => CSSObject = props => ({\n backgroundColor: COLOR.GRAY_LIGHTEN_88,\n borderRadius: '4px',\n boxShadow: `inset 16px 16px 0 ${COLOR.WHITE}, inset -16px -16px 0 ${COLOR.WHITE}`,\n marginBottom: '16px',\n [`.${INPUT_CLASSNAME}, .${INPUT_SUBMIT_COMBO_CLASSNAME}`]: {\n marginBottom: '1px !important',\n marginTop: '0 !important',\n },\n [`.${INPUT_GROUP}`]: {\n marginBottom: 0,\n },\n});\n\nexport const InputBlock = (props: InputBlockProps) => <div css={inputBlockStyle(props)} {...props} />;\n"],"file":"InputBlock.js"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":[],"names":[],"mappings":"","sourcesContent":[],"file":"InputLabel.d.js"}
|