@ntbjs/react-components 1.1.1 → 1.1.3

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.
Files changed (75) hide show
  1. package/{ActionButton-c3f5ed94.js → ActionButton-06df3d6c.js} +15 -5
  2. package/Alert-13b75102.js +117 -0
  3. package/AssetGallery-d5e4f7a6.js +1857 -0
  4. package/{AssetPreviewTopBar-449e6019.js → AssetPreviewTopBar-c28715f7.js} +15 -15
  5. package/Badge-aec841c8.js +221 -0
  6. package/{Button-432f87c6.js → Button-49f82b31.js} +3 -3
  7. package/{Checkbox-d80544d6.js → Checkbox-68dc38a8.js} +13 -8
  8. package/{CompactAutocompleteSelect-0c08a1aa.js → CompactAutocompleteSelect-87c8c7e7.js} +121 -90
  9. package/{CompactStarRating-77f54a07.js → CompactStarRating-1aedbcf4.js} +103 -66
  10. package/{CompactTextInput-8750600d.js → CompactTextInput-aafb1a17.js} +88 -61
  11. package/{ContextMenu-d088833b.js → ContextMenu-4ec3d9f3.js} +1 -1
  12. package/ContextMenuItem-1fe17ed5.js +110 -0
  13. package/{InputGroup-09ce9572.js → InputGroup-49fbc423.js} +1 -1
  14. package/{Instructions-ed68e52f.js → Instructions-b9f2e184.js} +27 -14
  15. package/MultiLevelCheckboxSelect-eeb5dcef.js +698 -0
  16. package/{MultiSelect-abf02057.js → MultiSelect-4b8d3d0d.js} +2 -2
  17. package/{Popover-d3a4b72e.js → Popover-569cd272.js} +33 -7
  18. package/{Radio-70259f02.js → Radio-32d0513a.js} +1 -1
  19. package/{SectionSeparator-225719cd.js → SectionSeparator-259a22ed.js} +1 -1
  20. package/{Switch-a7cbb0c0.js → Switch-4a41585f.js} +1 -1
  21. package/{Tab-9936ddea.js → Tab-f499ecbc.js} +1 -1
  22. package/{Tabs-93f6362c.js → Tabs-4d7742bc.js} +8 -38
  23. package/TextArea-229e7abb.js +435 -0
  24. package/{TextInput-c0ef017d.js → TextInput-0d109708.js} +1 -1
  25. package/{Tooltip-1b7b0052.js → Tooltip-66daf6e3.js} +4 -4
  26. package/VerificationStatusIcon-b574fd21.js +106 -0
  27. package/data/Alert/index.js +3 -2
  28. package/data/Badge/index.js +2 -2
  29. package/data/Popover/index.js +4 -3
  30. package/data/Tab/index.js +2 -2
  31. package/data/Tabs/index.js +3 -3
  32. package/data/Tooltip/index.js +3 -3
  33. package/data/index.js +11 -8
  34. package/{defaultTheme-50f2b88f.js → defaultTheme-ea44e34a.js} +59 -1
  35. package/icons/add.svg +3 -0
  36. package/icons/album.svg +3 -0
  37. package/icons/check-rectangle-filled.svg +3 -0
  38. package/icons/corporate.svg +3 -0
  39. package/icons/download.svg +3 -3
  40. package/icons/index.js +77 -0
  41. package/icons/layers.svg +3 -0
  42. package/icons/play.svg +3 -3
  43. package/icons/shopping_cart_add.svg +3 -0
  44. package/icons/verification.svg +3 -0
  45. package/inputs/ActionButton/index.js +3 -2
  46. package/inputs/Button/index.js +6 -5
  47. package/inputs/Checkbox/index.js +2 -2
  48. package/inputs/CompactAutocompleteSelect/index.js +14 -4
  49. package/inputs/CompactStarRating/index.js +14 -3
  50. package/inputs/CompactTextInput/index.js +11 -10
  51. package/inputs/MultiSelect/index.js +3 -3
  52. package/inputs/Radio/index.js +2 -2
  53. package/inputs/Switch/index.js +2 -2
  54. package/inputs/TextArea/index.js +14 -3
  55. package/inputs/TextInput/index.js +2 -2
  56. package/inputs/index.js +29 -23
  57. package/layout/InputGroup/index.js +2 -2
  58. package/layout/SectionSeparator/index.js +2 -2
  59. package/layout/index.js +3 -3
  60. package/package.json +2 -1
  61. package/{react-select-creatable.esm-c4ae6839.js → react-select-creatable.esm-2f23d6c6.js} +8 -15
  62. package/{shift-away-subtle-cfdf1dbe.js → shift-away-subtle-0bed9a3c.js} +1 -1
  63. package/styles/config.scss +3 -1
  64. package/widgets/AssetGallery/index.js +34 -29
  65. package/widgets/AssetPreview/AssetPreviewTopBar/index.js +2 -2
  66. package/widgets/ContextMenu/ContextMenuItem/index.js +5 -105
  67. package/widgets/ContextMenu/ContextMenuItemsGroup/index.js +1 -1
  68. package/widgets/ContextMenu/index.js +2 -2
  69. package/widgets/Instructions/index.js +16 -6
  70. package/widgets/index.js +37 -31
  71. package/Alert-3e4f8be1.js +0 -62
  72. package/AssetGallery-f01f30eb.js +0 -1397
  73. package/Badge-9461fc7f.js +0 -154
  74. package/TextArea-1ed790e5.js +0 -340
  75. package/check-555d831b.js +0 -213
package/Badge-9461fc7f.js DELETED
@@ -1,154 +0,0 @@
1
- 'use strict';
2
-
3
- var defaultTheme = require('./defaultTheme-50f2b88f.js');
4
- var React = require('react');
5
- var styled = require('styled-components');
6
-
7
- function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
8
-
9
- var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
10
- var styled__default = /*#__PURE__*/_interopDefaultLegacy(styled);
11
-
12
- var _templateObject, _templateObject2, _templateObject3, _templateObject4;
13
- var Badge$1 = styled__default['default'].span.attrs(defaultTheme.applyDefaultTheme)(_templateObject || (_templateObject = defaultTheme._taggedTemplateLiteral(["\n align-content: center;\n display: ", ";\n font-family: ", ";\n font-size: 1rem;\n font-weight: 500;\n min-height: 26px;\n position: relative;\n width: ", ";\n"])), function (props) {
14
- return props.elevated || !props.hasChildren ? 'inline-flex' : 'flex';
15
- }, function (props) {
16
- return props.theme.primaryFontFamily;
17
- }, function (props) {
18
- return props.elevated ? 'fit-content' : 'initial';
19
- });
20
- var BadgeChildrenContainer = styled__default['default'].span.attrs(defaultTheme.applyDefaultTheme)(_templateObject2 || (_templateObject2 = defaultTheme._taggedTemplateLiteral(["\n align-self: center;\n height: fit-content;\n margin-right: 8px;\n"])));
21
- var BadgeLabel = styled__default['default'].span.attrs(defaultTheme.applyDefaultTheme)(_templateObject3 || (_templateObject3 = defaultTheme._taggedTemplateLiteral(["\n border-radius: ", ";\n display: inline-block;\n font-size: ", ";\n font-weight: normal;\n height: fit-content;\n letter-spacing: 0.32px;\n margin-left: ", ";\n padding ", ";\n position: ", ";\n right: 0;\n transform: ", ";\n\n ", "\n\n ", "\n\n ", "\n"])), function (props) {
22
- return props.elevated ? '12px' : '14px';
23
- }, function (props) {
24
- return props.elevated ? '0.625rem' : '0.750rem';
25
- }, function (props) {
26
- return props.elevated ? '15px' : 'auto';
27
- }, function (props) {
28
- return props.elevated ? '4px 7px' : '6px 10px';
29
- }, function (props) {
30
- return props.elevated ? 'absolute' : 'initial';
31
- }, function (props) {
32
- return props.elevated ? 'translate(33%, -8px)' : 'initial';
33
- }, function (props) {
34
- return props.paddingY && props.paddingX && styled.css(_templateObject4 || (_templateObject4 = defaultTheme._taggedTemplateLiteral(["\n padding-top: ", "px;\n padding-bottom: ", "px;\n padding-left: ", "px;\n padding-right: ", "px;\n "])), props.paddingY, props.paddingY, props.paddingX, props.paddingX);
35
- }, function (props) {
36
- return props.theme.themeProp('background', function () {
37
- var active = props.active;
38
- var error = props.error;
39
- var warning = props.warning;
40
-
41
- switch (true) {
42
- case !error && !warning && !active:
43
- return props.theme.getColor('gray-600');
44
-
45
- case !error && !warning && active:
46
- return props.theme.getColor('gray-700');
47
-
48
- case error && active:
49
- return props.theme.getColor('red-500');
50
-
51
- case error:
52
- return props.theme.getColor('red-200');
53
-
54
- case warning && active:
55
- return props.theme.getColor('signal-yellow-500');
56
-
57
- case warning:
58
- return props.theme.getColor('signal-yellow-400');
59
-
60
- default:
61
- return props.theme.getColor('gray-600');
62
- }
63
- }, function () {
64
- var active = props.active;
65
- var error = props.error;
66
- var warning = props.warning;
67
-
68
- switch (true) {
69
- case !error && !warning && !active:
70
- return props.theme.getColor('gray-200');
71
-
72
- case !error && !warning && active:
73
- return props.theme.getColor('white');
74
-
75
- case error && active:
76
- return props.theme.getColor('red-500');
77
-
78
- case error:
79
- return props.theme.getColor('red-200');
80
-
81
- case warning && active:
82
- return props.theme.getColor('signal-yellow-500');
83
-
84
- case warning:
85
- return props.theme.getColor('signal-yellow-400');
86
-
87
- default:
88
- return props.theme.getColor('gray-200');
89
- }
90
- });
91
- }, function (props) {
92
- return props.theme.themeProp('color', function () {
93
- if (props.warning && !props.error || props.error && !props.active) {
94
- return props.theme.getColor('gray-900');
95
- } else {
96
- return props.theme.getColor('white');
97
- }
98
- }, function () {
99
- if (props.error && props.active) {
100
- return props.theme.getColor('white');
101
- } else {
102
- return props.theme.getColor('gray-900');
103
- }
104
- });
105
- });
106
-
107
- var Badge = React__default['default'].forwardRef(function Badge(_ref, forwardedRef) {
108
- var badgeContent = _ref.badgeContent,
109
- paddingY = _ref.paddingY,
110
- paddingX = _ref.paddingX,
111
- children = _ref.children,
112
- elevated = _ref.elevated,
113
- active = _ref.active,
114
- error = _ref.error,
115
- warning = _ref.warning,
116
- props = defaultTheme._objectWithoutProperties(_ref, ["badgeContent", "paddingY", "paddingX", "children", "elevated", "active", "error", "warning"]);
117
-
118
- if (typeof badgeContent === 'number') {
119
- badgeContent = Intl.NumberFormat('en', {
120
- notation: 'compact'
121
- }).format(badgeContent);
122
- }
123
-
124
- return React__default['default'].createElement(Badge$1, defaultTheme._extends({
125
- ref: forwardedRef,
126
- elevated: elevated,
127
- hasChildren: Boolean(children)
128
- }, props), children && React__default['default'].createElement(BadgeChildrenContainer, null, children), badgeContent && React__default['default'].createElement(BadgeLabel, {
129
- elevated: elevated,
130
- active: active,
131
- paddingY: paddingY,
132
- paddingX: paddingX,
133
- error: error,
134
- warning: warning
135
- }, badgeContent));
136
- });
137
- Badge.propTypes = process.env.NODE_ENV !== "production" ? {
138
- badgeContent: defaultTheme.PropTypes.oneOfType([defaultTheme.PropTypes.string, defaultTheme.PropTypes.number]),
139
- paddingY: defaultTheme.PropTypes.number,
140
- paddingX: defaultTheme.PropTypes.number,
141
- children: defaultTheme.PropTypes.oneOfType([defaultTheme.PropTypes.node, defaultTheme.PropTypes.string]),
142
- elevated: defaultTheme.PropTypes.bool,
143
- active: defaultTheme.PropTypes.bool,
144
- error: defaultTheme.PropTypes.bool,
145
- warning: defaultTheme.PropTypes.bool
146
- } : {};
147
- Badge.defaultProps = {
148
- elevated: false,
149
- active: false,
150
- error: false,
151
- warning: false
152
- };
153
-
154
- exports.Badge = Badge;
@@ -1,340 +0,0 @@
1
- 'use strict';
2
-
3
- var defaultTheme = require('./defaultTheme-50f2b88f.js');
4
- var React = require('react');
5
- var useMergedRefs = require('./useMergedRefs-b6d2f8fc.js');
6
- var nanoid = require('nanoid');
7
- var check = require('./check-555d831b.js');
8
- var editNote = require('./edit-note-c47d292e.js');
9
- var styled = require('styled-components');
10
-
11
- function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
12
-
13
- var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
14
- var styled__default = /*#__PURE__*/_interopDefaultLegacy(styled);
15
-
16
- var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8, _templateObject9, _templateObject10, _templateObject11, _templateObject12, _templateObject13, _templateObject14, _templateObject15, _templateObject16, _templateObject17, _templateObject18, _templateObject19, _templateObject20, _templateObject21, _templateObject22, _templateObject23, _templateObject24, _templateObject25, _templateObject26, _templateObject27, _templateObject28, _templateObject29, _templateObject30, _templateObject31, _templateObject32, _templateObject33, _templateObject34, _templateObject35, _templateObject36, _templateObject37, _templateObject38, _templateObject39, _templateObject40, _templateObject41, _templateObject42, _templateObject43, _templateObject44;
17
- var fadeInCheck = styled.keyframes(_templateObject || (_templateObject = defaultTheme._taggedTemplateLiteral(["\n from {\n opacity: 0\n }\n to {\n opacity: 1\n }\n"])));
18
- var fadeOutCheck = styled.keyframes(_templateObject2 || (_templateObject2 = defaultTheme._taggedTemplateLiteral(["\n from {\n opacity: 1\n }\n to {\n opacity: 0\n }\n"])));
19
- var activeLabel = styled.css(_templateObject3 || (_templateObject3 = defaultTheme._taggedTemplateLiteral(["\n font-size: 0.75rem;\n padding: 0 3px;\n top: -7px;\n letter-spacing: 0.03em;\n left: 8px !important;\n opacity: 1 !important;\n"])));
20
- var placeholderBaseStyle = styled.css(_templateObject4 || (_templateObject4 = defaultTheme._taggedTemplateLiteral(["\n ", "\n\n ", "\n"])), function (props) {
21
- return props.theme.themeProp('color', props.theme.getColor('gray-300'), props.theme.getColor('gray-600'));
22
- }, function (props) {
23
- return props.theme.themeProp('opacity', 0.6, 0.5);
24
- });
25
- var InputIconContainer = styled__default['default'].div.attrs(defaultTheme.applyDefaultTheme)(_templateObject5 || (_templateObject5 = defaultTheme._taggedTemplateLiteral(["\n opacity: 0;\n pointer-events: none;\n border-top-right-radius: 3px;\n border-bottom-right-radius: 3px;\n display: flex;\n align-items: flex-start;\n position: absolute;\n right: 15px;\n top: 10px;\n bottom: 0;\n svg {\n width: 15px;\n opacity: 0.7;\n transition: opacity 250ms;\n ", "\n ", "\n }\n"])), function (props) {
26
- return props.theme.themeProp('color', props.theme.getColor('gray-400'), props.theme.getColor('gray-900'), '!important');
27
- }, function (props) {
28
- return props.disabled && styled.css(_templateObject6 || (_templateObject6 = defaultTheme._taggedTemplateLiteral(["\n display: none;\n "])));
29
- });
30
- var TextInputField = styled__default['default'].textarea.attrs(defaultTheme.applyDefaultTheme)(_templateObject7 || (_templateObject7 = defaultTheme._taggedTemplateLiteral(["\n width: 100%;\n font-family: inherit;\n font-size: 0.875rem;\n border-radius: 2px;\n padding: 5px 10px;\n resize: vertical;\n z-index: 0;\n border-radius: 3px;\n box-sizing: border-box;\n appearance: none;\n border: 1px solid;\n\n ", "\n\n ", "\n\n ", "\n\n ", "\n ", "\n\n transition: height 550ms ease-in-out; border-color 350ms;\n\n ", "\n\n ", "\n\n ", "\n\n ", "\n \n ", "\n \n ", "\n\n ", "\n \n\n ", "\n \n\n ", "\n\n ", " \n ", "\n\n &&:hover:not(:focus) {\n ", ";\n }\n\n ", " \n\n ", " \n ", "\n ", ";\n\n ", ";\n\n ", ";\n\n &&:hover:not(:focus) {\n ", ";\n transition: background 350ms;\n & + ", " {\n opacity: 1;\n ", ";\n transition: opacity 350ms;\n }\n }\n\n ", "\n ", "\n ", "\n\n &::placeholder {\n ", "\n\n ", "\n }\n\n &&:focus {\n outline: none;\n ", "\n\n ", ";\n\n ", "\n ", "\n }\n\n &&:not(:hover):not(:focus) {\n ", ";\n\n ", ";\n }\n"])), function (props) {
31
- return props.padding === 'small' && styled.css(_templateObject8 || (_templateObject8 = defaultTheme._taggedTemplateLiteral(["\n padding: 5px 10px;\n "])));
32
- }, function (props) {
33
- return props.padding === 'medium' && styled.css(_templateObject9 || (_templateObject9 = defaultTheme._taggedTemplateLiteral(["\n padding: 13px 15px;\n "])));
34
- }, function (props) {
35
- return props.padding === 'large' && styled.css(_templateObject10 || (_templateObject10 = defaultTheme._taggedTemplateLiteral(["\n padding: 15px 55px;\n "])));
36
- }, function (props) {
37
- return props.showMore && !props.expanded && props.defaultHeight < props.maxHeight && styled.css(_templateObject11 || (_templateObject11 = defaultTheme._taggedTemplateLiteral(["\n height: ", "px;\n -webkit-mask-image: linear-gradient(0deg, transparent 5px, white 45px);\n "])), props.defaultHeight);
38
- }, function (props) {
39
- return props.expanded && styled.css(_templateObject12 || (_templateObject12 = defaultTheme._taggedTemplateLiteral(["\n height: ", "px;\n "])), props.maxHeight);
40
- }, function (props) {
41
- return props.theme.themeProp('color', 'white', 'black');
42
- }, function (props) {
43
- return props.readOnly && styled.css(_templateObject13 || (_templateObject13 = defaultTheme._taggedTemplateLiteral(["\n cursor: default;\n border-color: transparent !important;\n "])));
44
- }, function (props) {
45
- return props.disabled && styled.css(_templateObject14 || (_templateObject14 = defaultTheme._taggedTemplateLiteral(["\n cursor: not-allowed;\n "])));
46
- }, function (props) {
47
- return props.readOnly && styled.css(_templateObject15 || (_templateObject15 = defaultTheme._taggedTemplateLiteral(["\n padding: 12px 10px; ;\n "])));
48
- }, function (props) {
49
- return props.showMore && styled.css(_templateObject16 || (_templateObject16 = defaultTheme._taggedTemplateLiteral(["\n overflow: hidden;\n "])));
50
- }, function (props) {
51
- return props.theme.themeProp('color', props.theme.getColor('gray-100'), props.theme.getColor('gray-900'));
52
- }, function (props) {
53
- return (props.state === 'warning' || props.state === 'error') && props.theme.themeProp('color', props.theme.getColor('gray-900'), props.theme.getColor('gray-900'));
54
- }, function (props) {
55
- return props.theme.themeProp('background', props.theme.getColor('gray-900'), props.theme.getColor('white'));
56
- }, function (props) {
57
- return props.theme.themeProp('border-color', props.theme.getColor('gray-500'), props.theme.getColor('gray-400'));
58
- }, function (props) {
59
- return props.noBorder && styled.css(_templateObject17 || (_templateObject17 = defaultTheme._taggedTemplateLiteral(["\n border-color: transparent !important;\n "])));
60
- }, function (props) {
61
- return props.state === 'error-border' && styled.css(_templateObject18 || (_templateObject18 = defaultTheme._taggedTemplateLiteral(["\n ", "\n "])), props.theme.themeProp('border-color', props.theme.getColor('red-200'), props.theme.getColor('red-500')));
62
- }, function (props) {
63
- return !props.readOnly && props.theme.themeProp('background', props.theme.getColor('gray-700'), props.theme.getColor('gray-100'));
64
- }, function (props) {
65
- return props.state === 'warning' && styled.css(_templateObject19 || (_templateObject19 = defaultTheme._taggedTemplateLiteral(["\n padding: 13px 15px 13px 10px;\n ", "\n ", "\n &&:hover:not(:focus) {\n ", "\n ", "\n }\n &&:read-only:hover {\n ", "\n }\n "])), props.theme.themeProp('color', 'white', 'black'), props.theme.themeProp('background', '#634E01 ', props.theme.getColor('signal-yellow-400')), function (props) {
66
- return props.disabled && styled.css(_templateObject20 || (_templateObject20 = defaultTheme._taggedTemplateLiteral(["\n background: none !important;\n "])));
67
- }, props.theme.themeProp('background', '#816600', '#F4E21E'), props.theme.themeProp('background', props.theme.getColor('signal-yellow-500'), props.theme.getColor('signal-yellow-400')));
68
- }, function (props) {
69
- return props.state === 'error' && styled.css(_templateObject21 || (_templateObject21 = defaultTheme._taggedTemplateLiteral(["\n padding: 13px 15px 13px 10px;\n background: ", " !important;\n :focus {\n background: white !important;\n }\n &&:hover:not(:focus) {\n background: #f7d5d0 !important;\n }\n &&:read-only:hover {\n background: ", " !important;\n }\n "])), props.theme.getColor('red-200'), props.theme.getColor('red-200'));
70
- }, function (props) {
71
- return props.lightBackground && styled.css(_templateObject22 || (_templateObject22 = defaultTheme._taggedTemplateLiteral(["\n ", "\n ", "\n &&:hover {\n ", "\n }\n "])), props.theme.themeProp('background', '#FFFDDE', '#fffde8'), props.theme.themeProp('color', props.theme.getColor('gray-900'), props.theme.getColor('gray-900')), props.theme.themeProp('background', 'white', 'white'));
72
- }, function (props) {
73
- return props.edit && props.theme.themeProp('background', '#505050', '#eff1f4');
74
- }, function (props) {
75
- return props.edit && !props.state === 'warning' && props.theme.themeProp('background', '#505050', '#eff1f4');
76
- }, function (props) {
77
- return props.edit && props.state === 'warning' && props.theme.themeProp('background', '#AD8800', '#FFF3A7');
78
- }, function (props) {
79
- return props.noBorder && !props.readOnly && props.state != 'warning' ? props.theme.themeProp('background', props.theme.getColor('gray-700'), props.theme.getColor('gray-100')) : 'background: transparent';
80
- }, InputIconContainer, function (props) {
81
- return props.state === 'success' && styled.css(_templateObject23 || (_templateObject23 = defaultTheme._taggedTemplateLiteral(["\n opacity: 0;\n "])));
82
- }, function (props) {
83
- return props.state === 'warning' && styled.css(_templateObject24 || (_templateObject24 = defaultTheme._taggedTemplateLiteral(["\n border-color: ", ";\n "])), props.theme.getColor('orange-500'));
84
- }, function (props) {
85
- return props.state === 'error' && styled.css(_templateObject25 || (_templateObject25 = defaultTheme._taggedTemplateLiteral(["\n border-color: ", ";\n "])), props.theme.getColor('red-500'));
86
- }, function (props) {
87
- return props.hasIcon && styled.css(_templateObject26 || (_templateObject26 = defaultTheme._taggedTemplateLiteral(["\n padding-left: 55px;\n padding-right: 25px;\n "])));
88
- }, function (props) {
89
- return props.theme.themeProp('color', props.theme.getColor('gray-300'), props.theme.getColor('gray-600'), 1);
90
- }, function (props) {
91
- return props.theme.themeProp('opacity', 0.6, 0.5, 1);
92
- }, function (props) {
93
- return props.theme.themeProp('border-color', props.theme.getColor('gray-500'), props.theme.getColor('gray-600'));
94
- }, function (props) {
95
- return props.theme.themeProp('background', props.theme.getColor('gray-700'), props.theme.getColor('gray-100'));
96
- }, function (props) {
97
- return props.state === 'warning' && styled.css(_templateObject27 || (_templateObject27 = defaultTheme._taggedTemplateLiteral(["\n ", "\n ", "\n "])), props.theme.themeProp('background', 'white', 'white'), props.theme.themeProp('color', 'black', 'black'));
98
- }, function (props) {
99
- return props.state === 'error' && styled.css(_templateObject28 || (_templateObject28 = defaultTheme._taggedTemplateLiteral(["\n ", "\n ", "\n "])), props.theme.themeProp('background', 'white', 'white'), props.theme.themeProp('color', 'black', 'black'));
100
- }, function (props) {
101
- return props.edit && props.theme.themeProp('background', '#505050', '#eff1f4');
102
- }, function (props) {
103
- return props.edit && props.state === 'warning' && props.theme.themeProp('background', '#AD8800', '#FFF3A7');
104
- });
105
- var TextInputLabel = styled__default['default'].label.attrs(defaultTheme.applyDefaultTheme)(_templateObject29 || (_templateObject29 = defaultTheme._taggedTemplateLiteral(["\n position: absolute;\n top: 13px;\n left: 11px;\n line-height: 1.2;\n font-size: 0.875rem;\n transition: all 150ms;\n margin-botton: 50px;\n\n ", ";\n\n ", "\n\n ", "\n\n ", "\n content: \"\";\n\n ", "\n"])), placeholderBaseStyle, function (props) {
106
- return props.theme.themeProp('background', "linear-gradient(0deg, ".concat(props.theme.getColor('gray-900'), " calc(50% + 1px), transparent 50%)"), "linear-gradient(0deg, ".concat(props.theme.getColor('white'), " calc(50% + 1px), transparent 50%)"));
107
- }, function (props) {
108
- return !props.inputIsEmpty && styled.css(_templateObject30 || (_templateObject30 = defaultTheme._taggedTemplateLiteral(["\n ", "\n "])), activeLabel);
109
- }, function (props) {
110
- return props.hasPlaceholder && styled.css(_templateObject31 || (_templateObject31 = defaultTheme._taggedTemplateLiteral(["\n ", ";\n "])), activeLabel);
111
- }, function (props) {
112
- return props.hasIcon && styled.css(_templateObject32 || (_templateObject32 = defaultTheme._taggedTemplateLiteral(["\n left: 55px;\n "])));
113
- });
114
- var TextInputFieldIcon = styled__default['default'].div.attrs(defaultTheme.applyDefaultTheme)(_templateObject33 || (_templateObject33 = defaultTheme._taggedTemplateLiteral(["\n position: absolute;\n top: 0;\n left: 0;\n height: 2.625rem;\n display: flex;\n padding: 0 10px;\n\n svg {\n width: 15px;\n opacity: 0.6;\n transition: opacity 250ms;\n }\n"])));
115
- var TextInputFieldIconAlert = styled__default['default'].div.attrs(defaultTheme.applyDefaultTheme)(_templateObject34 || (_templateObject34 = defaultTheme._taggedTemplateLiteral(["\n position: absolute;\n top: 2.8px;\n height: 2.625rem;\n display: flex;\n padding: 0 10px 0 30px;\n svg {\n width: 15px;\n opacity: 0.6;\n transition: opacity 250ms;\n margin-top: -3px;\n ", "\n }\n"])), function (props) {
116
- return props.theme.themeProp('color', props.theme.getColor('gray-100'), props.theme.getColor('gray-600'));
117
- });
118
- var TextInput = styled__default['default'].div.attrs(defaultTheme.applyDefaultTheme)(_templateObject35 || (_templateObject35 = defaultTheme._taggedTemplateLiteral(["\n position: relative;\n\n ", "\n\n ", "\n\n &:focus-within {\n ", " {\n ", ";\n }\n\n ", " {\n svg {\n opacity: 1;\n }\n }\n }\n\n ", ":not(:placeholder-shown) + ", " {\n ", ";\n ", "\n }\n }\n"])), function (props) {
119
- return props.readOnly && styled.css(_templateObject36 || (_templateObject36 = defaultTheme._taggedTemplateLiteral(["\n pointer-events: none;\n "])));
120
- }, function (props) {
121
- return props.disabled && styled.css(_templateObject37 || (_templateObject37 = defaultTheme._taggedTemplateLiteral(["\n opacity: 0.5;\n\n > * {\n cursor: not-allowed;\n }\n "])));
122
- }, TextInputLabel, activeLabel, TextInputFieldIcon, TextInputField, TextInputLabel, activeLabel, function (props) {
123
- return props.state === 'error' && props.theme.themeProp('color', props.theme.getColor('red-200'), props.theme.getColor('red-500'));
124
- });
125
- var Description = styled__default['default'].div.attrs(defaultTheme.applyDefaultTheme)(_templateObject38 || (_templateObject38 = defaultTheme._taggedTemplateLiteral(["\n margin: 8px 0 0 0;\n padding: 0 0.6875rem;\n font-size: 0.75rem;\n line-height: 1.333;\n\n ", ";\n\n ", "\n\n ", "\n"])), function (props) {
126
- return props.theme.themeProp('color', props.theme.getColor('gray-400'), props.theme.getColor('gray-500'));
127
- }, function (props) {
128
- return (props.state === 'warning-border' || props.state === 'warning') && styled.css(_templateObject39 || (_templateObject39 = defaultTheme._taggedTemplateLiteral(["\n ", "\n "])), props.theme.themeProp('color', props.theme.getColor('red-200'), props.theme.getColor('orange-500')));
129
- }, function (props) {
130
- return (props.state === 'error-border' || props.state === 'error') && styled.css(_templateObject40 || (_templateObject40 = defaultTheme._taggedTemplateLiteral(["\n ", "\n "])), props.theme.themeProp('color', props.theme.getColor('red-200'), props.theme.getColor('red-500')));
131
- });
132
- var SuccessContainer = styled__default['default'].div.attrs(defaultTheme.applyDefaultTheme)(_templateObject41 || (_templateObject41 = defaultTheme._taggedTemplateLiteral(["\n opacity: 1;\n pointer-events: none;\n opacity: ", ";\n animation: ", " 0.5s ease-in-out;\n transition: opacity 0.5s ease-in-out;\n position: absolute;\n margin-top: -35px;\n margin-left: 5px;\n width: 15px;\n height: 15px;\n padding: 5px;\n ", "\n\n > svg {\n width: 15px;\n }\n"])), function (props) {
133
- return props.fadeIn ? 0 : 1;
134
- }, function (props) {
135
- return props.fadeIn ? fadeOutCheck : fadeInCheck;
136
- }, function (props) {
137
- return props.theme.themeProp('color', props.theme.getColor('gray-300'), props.theme.getColor('gray-500'));
138
- });
139
- var ShowMoreText = styled__default['default'].div.attrs(defaultTheme.applyDefaultTheme)(_templateObject42 || (_templateObject42 = defaultTheme._taggedTemplateLiteral(["\n margin-top: -18px;\n margin-bottom: 0;\n display: block;\n position: absolute;\n font-size: 0.875rem;\n cursor: pointer;\n padding: 2px 10px;\n margin-right: 10px;\n\n ", "\n transition: margin-top 550ms ease-in-out;\n -webkit-mask-image: linear-gradient(180deg, transparent 1px, white 5px);\n ", "\n\n ", ";\n\n ", "\n"])), function (props) {
140
- return props.expanded && styled.css(_templateObject43 || (_templateObject43 = defaultTheme._taggedTemplateLiteral(["\n margin-top: 0px;\n "])));
141
- }, function (props) {
142
- return props.theme.themeProp('background', props.theme.getColor('gray-900'), props.theme.getColor('white'));
143
- }, function (props) {
144
- return props.theme.themeProp('color', props.theme.getColor('gray-300'), props.theme.getColor('emerald-500'));
145
- }, function (props) {
146
- return props.state === 'error' && styled.css(_templateObject44 || (_templateObject44 = defaultTheme._taggedTemplateLiteral(["\n content: 'error';\n ", "\n "])), props.theme.themeProp('color', props.theme.getColor('red-200'), props.theme.getColor('red-500')));
147
- });
148
-
149
- var TextArea = React__default['default'].forwardRef(function TextArea(_ref, forwardedRef) {
150
- var value = _ref.value,
151
- defaultValue = _ref.defaultValue,
152
- name = _ref.name,
153
- label = _ref.label,
154
- placeholder = _ref.placeholder,
155
- required = _ref.required,
156
- disabled = _ref.disabled,
157
- hidden = _ref.hidden,
158
- readOnly = _ref.readOnly,
159
- edit = _ref.edit,
160
- showMore = _ref.showMore,
161
- showMoreText = _ref.showMoreText,
162
- showLessText = _ref.showLessText,
163
- autoComplete = _ref.autoComplete,
164
- description = _ref.description,
165
- state = _ref.state,
166
- icon = _ref.icon,
167
- rows = _ref.rows,
168
- className = _ref.className,
169
- style = _ref.style,
170
- _onChange = _ref.onChange,
171
- onBlur = _ref.onBlur,
172
- lightBackground = _ref.lightBackground,
173
- noBorder = _ref.noBorder,
174
- instructionsTextArea = _ref.instructionsTextArea,
175
- isExpanded = _ref.isExpanded,
176
- rest = defaultTheme._objectWithoutProperties(_ref, ["value", "defaultValue", "name", "label", "placeholder", "required", "disabled", "hidden", "readOnly", "edit", "showMore", "showMoreText", "showLessText", "autoComplete", "description", "state", "icon", "rows", "className", "style", "onChange", "onBlur", "lightBackground", "noBorder", "instructionsTextArea", "isExpanded"]);
177
-
178
- var textInputDomNode = React.useRef(null);
179
- var textInputRef = useMergedRefs.useMergedRefs(forwardedRef, textInputDomNode);
180
-
181
- var _useState = React.useState(!(value || defaultValue)),
182
- _useState2 = defaultTheme._slicedToArray(_useState, 2),
183
- inputIsEmpty = _useState2[0],
184
- setInputIsEmpty = _useState2[1];
185
-
186
- var _useState3 = React.useState(''),
187
- _useState4 = defaultTheme._slicedToArray(_useState3, 2),
188
- maxContentRows = _useState4[0],
189
- setMaxContentRows = _useState4[1];
190
-
191
- var _useState5 = React.useState(false),
192
- _useState6 = defaultTheme._slicedToArray(_useState5, 2),
193
- expanded = _useState6[0],
194
- setExpanded = _useState6[1];
195
-
196
- var _useState7 = React.useState(''),
197
- _useState8 = defaultTheme._slicedToArray(_useState7, 2),
198
- maxHeight = _useState8[0],
199
- setMaxHeight = _useState8[1];
200
-
201
- var _useState9 = React.useState(''),
202
- _useState10 = defaultTheme._slicedToArray(_useState9, 2),
203
- defaultHeight = _useState10[0],
204
- setDefaultHeight = _useState10[1];
205
-
206
- var _useState11 = React.useState(nanoid.nanoid()),
207
- _useState12 = defaultTheme._slicedToArray(_useState11, 1),
208
- uniqueId = _useState12[0];
209
-
210
- var handleTextAreaChange = function handleTextAreaChange() {
211
- setExpanded(!expanded);
212
- isExpanded(expanded);
213
- };
214
-
215
- var calculateRows = function calculateRows() {
216
- var textareaRefCurrent = textInputDomNode === null || textInputDomNode === void 0 ? void 0 : textInputDomNode.current;
217
-
218
- if (textareaRefCurrent !== null) {
219
- var textAreaHeight = textareaRefCurrent === null || textareaRefCurrent === void 0 ? void 0 : textareaRefCurrent.scrollHeight;
220
- var lineHeight = 16;
221
- var calculatedRows = Math.floor(textAreaHeight / lineHeight);
222
- var defaultRowsHeight = rows * lineHeight;
223
- setMaxContentRows(calculatedRows);
224
-
225
- if (calculatedRows > rows) {
226
- setDefaultHeight(defaultRowsHeight);
227
- setMaxHeight(textAreaHeight);
228
- } else {
229
- setMaxHeight();
230
- }
231
- }
232
- };
233
-
234
- React.useEffect(function () {
235
- calculateRows();
236
- }, [value, defaultValue]);
237
- if (hidden) return null;
238
- return React__default['default'].createElement(TextInput, {
239
- disabled: disabled,
240
- readOnly: readOnly,
241
- state: state,
242
- className: className,
243
- style: style
244
- }, React__default['default'].createElement(TextInputFieldIconAlert, null, icon), React__default['default'].createElement(TextInputField, defaultTheme._extends({
245
- ref: textInputRef,
246
- rows: rows,
247
- expanded: expanded,
248
- defaultHeight: defaultHeight,
249
- maxHeight: maxHeight,
250
- value: value,
251
- defaultValue: defaultValue,
252
- name: name,
253
- placeholder: placeholder || ' ',
254
- required: required,
255
- readOnly: readOnly,
256
- disabled: disabled,
257
- edit: edit,
258
- instructionsTextArea: instructionsTextArea,
259
- showMore: showMore,
260
- state: state,
261
- autoComplete: autoComplete,
262
- hasIcon: Boolean(icon),
263
- icon: icon,
264
- id: "text-input-".concat(uniqueId),
265
- lightBackground: lightBackground,
266
- onChange: function onChange(e) {
267
- if (e.target.value) {
268
- setInputIsEmpty(false);
269
- } else {
270
- setInputIsEmpty(true);
271
- }
272
-
273
- _onChange(e);
274
- },
275
- onBlur: onBlur,
276
- noBorder: noBorder
277
- }, rest)), (state === 'loading' || state === 'success') && React__default['default'].createElement(SuccessContainer, null, state === 'loading' && React__default['default'].createElement(check._default, {
278
- color: '#b0b6b9',
279
- size: 12
280
- }), state === 'success' && React__default['default'].createElement(check.SvgCheck, null)), !readOnly && noBorder && React__default['default'].createElement(InputIconContainer, {
281
- disabled: disabled
282
- }, React__default['default'].createElement(editNote.SvgEditNote, null)), label && React__default['default'].createElement(TextInputLabel, {
283
- htmlFor: "text-input-".concat(uniqueId),
284
- hasPlaceholder: Boolean(placeholder),
285
- hasIcon: Boolean(icon),
286
- inputIsEmpty: inputIsEmpty
287
- }, label, required && ' *'), typeof description === 'string' && description.length > 0 && React__default['default'].createElement(Description, {
288
- state: state
289
- }, description), maxContentRows > rows && showMore && React__default['default'].createElement(ShowMoreText, {
290
- onClick: handleTextAreaChange,
291
- expanded: expanded
292
- }, !expanded ? showMoreText : showLessText));
293
- });
294
- TextArea.defaultProps = {
295
- rows: 4,
296
- noBorder: false,
297
- readOnly: false,
298
- edit: false,
299
- hidden: false,
300
- showMore: false,
301
- showMoreText: '',
302
- showLessText: '',
303
- state: '',
304
- padding: 'medium',
305
- instructionsTextArea: false,
306
- isExpanded: function isExpanded() {}
307
- };
308
- TextArea.propTypes = process.env.NODE_ENV !== "production" ? {
309
- value: defaultTheme.PropTypes.string,
310
- defaultValue: defaultTheme.PropTypes.string,
311
- name: defaultTheme.PropTypes.string,
312
- label: defaultTheme.PropTypes.string,
313
- placeholder: defaultTheme.PropTypes.string,
314
- required: defaultTheme.PropTypes.bool,
315
- disabled: defaultTheme.PropTypes.bool,
316
- hidden: defaultTheme.PropTypes.bool,
317
- readOnly: defaultTheme.PropTypes.bool,
318
- showMore: defaultTheme.PropTypes.bool,
319
- showMoreText: defaultTheme.PropTypes.string,
320
- showLessText: defaultTheme.PropTypes.string,
321
- edit: defaultTheme.PropTypes.bool,
322
- autoComplete: defaultTheme.PropTypes.string,
323
- description: defaultTheme.PropTypes.string,
324
- error: defaultTheme.PropTypes.oneOfType([defaultTheme.PropTypes.bool, defaultTheme.PropTypes.string]),
325
- warning: defaultTheme.PropTypes.oneOfType([defaultTheme.PropTypes.bool, defaultTheme.PropTypes.string]),
326
- icon: defaultTheme.PropTypes.element,
327
- rows: defaultTheme.PropTypes.oneOfType([defaultTheme.PropTypes.number, defaultTheme.PropTypes.string]),
328
- className: defaultTheme.PropTypes.string,
329
- style: defaultTheme.PropTypes.object,
330
- padding: defaultTheme.PropTypes.oneOf(['', 'small', 'medium', 'large']),
331
- lightBackground: defaultTheme.PropTypes.bool,
332
- onChange: defaultTheme.PropTypes.func,
333
- onBlur: defaultTheme.PropTypes.func,
334
- noBorder: defaultTheme.PropTypes.bool,
335
- isExpanded: defaultTheme.PropTypes.func,
336
- state: defaultTheme.PropTypes.oneOf(['', 'error', 'error-border', 'warning', 'loading', 'success']),
337
- instructionsTextArea: defaultTheme.PropTypes.bool
338
- } : {};
339
-
340
- exports.TextArea = TextArea;