@transferwise/components 46.1.0 → 46.2.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.
Files changed (177) hide show
  1. package/README.md +3 -5
  2. package/build/index.esm.js +44 -23
  3. package/build/index.esm.js.map +1 -1
  4. package/build/index.js +44 -23
  5. package/build/index.js.map +1 -1
  6. package/build/main.css +5494 -1
  7. package/build/styles/accordion/Accordion.css +60 -1
  8. package/build/styles/actionButton/ActionButton.css +53 -1
  9. package/build/styles/avatar/Avatar.css +205 -1
  10. package/build/styles/badge/Badge.css +68 -1
  11. package/build/styles/button/Button.css +20 -1
  12. package/build/styles/card/Card.css +100 -1
  13. package/build/styles/checkboxButton/CheckboxButton.css +24 -1
  14. package/build/styles/chips/Chip.css +190 -1
  15. package/build/styles/circularButton/CircularButton.css +211 -1
  16. package/build/styles/common/Option/Option.css +100 -1
  17. package/build/styles/common/RadioButton/RadioButton.css +4 -1
  18. package/build/styles/common/bottomSheet/BottomSheet.css +53 -1
  19. package/build/styles/common/card/Card.css +49 -1
  20. package/build/styles/common/closeButton/CloseButton.css +79 -1
  21. package/build/styles/common/panel/Panel.css +73 -1
  22. package/build/styles/criticalBanner/CriticalCommsBanner.css +76 -1
  23. package/build/styles/dateInput/DateInput.css +3 -1
  24. package/build/styles/dateLookup/DateLookup.css +98 -1
  25. package/build/styles/dateLookup/dateTrigger/DateTrigger.css +68 -1
  26. package/build/styles/decision/Decision.css +93 -1
  27. package/build/styles/definitionList/DefinitionList.css +53 -1
  28. package/build/styles/dimmer/Dimmer.css +70 -1
  29. package/build/styles/drawer/Drawer.css +100 -1
  30. package/build/styles/dropFade/DropFade.css +19 -1
  31. package/build/styles/dynamicFieldDefinitionList/FormattedValue/FormattedValue.css +5 -1
  32. package/build/styles/emphasis/Emphasis.css +31 -1
  33. package/build/styles/flowNavigation/FlowNavigation.css +72 -1
  34. package/build/styles/flowNavigation/animatedLabel/AnimatedLabel.css +21 -1
  35. package/build/styles/flowNavigation/backButton/BackButton.css +32 -1
  36. package/build/styles/header/Header.css +28 -1
  37. package/build/styles/image/Image.css +13 -1
  38. package/build/styles/info/Info.css +32 -1
  39. package/build/styles/inputs/Input.css +105 -1
  40. package/build/styles/inputs/InputGroup.css +62 -1
  41. package/build/styles/inputs/SelectInput.css +374 -1
  42. package/build/styles/inputs/TextArea.css +109 -1
  43. package/build/styles/instructionsList/InstructionsList.css +22 -1
  44. package/build/styles/link/Link.css +15 -1
  45. package/build/styles/listItem/ListItem.css +6 -1
  46. package/build/styles/loader/Loader.css +313 -1
  47. package/build/styles/logo/Logo.css +26 -1
  48. package/build/styles/main.css +5494 -1
  49. package/build/styles/modal/Modal.css +155 -1
  50. package/build/styles/moneyInput/MoneyInput.css +66 -1
  51. package/build/styles/navigationOption/NavigationOption.css +69 -1
  52. package/build/styles/navigationOptionsList/NavigationOptionsList.css +13 -1
  53. package/build/styles/nudge/Nudge.css +179 -1
  54. package/build/styles/overlayHeader/OverlayHeader.css +15 -1
  55. package/build/styles/phoneNumberInput/PhoneNumberInput.css +23 -1
  56. package/build/styles/popover/Popover.css +43 -1
  57. package/build/styles/progress/Progress.css +43 -1
  58. package/build/styles/progressBar/ProgressBar.css +14 -1
  59. package/build/styles/promoCard/PromoCard.css +186 -1
  60. package/build/styles/section/Section.css +10 -1
  61. package/build/styles/select/Select.css +309 -1
  62. package/build/styles/slidingPanel/SlidingPanel.css +105 -1
  63. package/build/styles/snackbar/Snackbar.css +93 -1
  64. package/build/styles/statusIcon/StatusIcon.css +78 -1
  65. package/build/styles/stepper/Stepper.css +108 -1
  66. package/build/styles/summary/Summary.css +81 -1
  67. package/build/styles/switch/Switch.css +68 -1
  68. package/build/styles/tabs/Tabs.css +121 -1
  69. package/build/styles/tile/Tile.css +55 -1
  70. package/build/styles/tooltip/Tooltip.css +50 -1
  71. package/build/styles/typeahead/Typeahead.css +183 -1
  72. package/build/styles/typeahead/typeaheadOption/TypeaheadOption.css +9 -1
  73. package/build/styles/upload/Upload.css +15 -1
  74. package/build/styles/uploadInput/UploadInput.css +71 -1
  75. package/build/styles/uploadInput/uploadButton/UploadButton.css +49 -1
  76. package/build/styles/uploadInput/uploadItem/UploadItem.css +74 -1
  77. package/build/types/accordion/Accordion.d.ts +1 -0
  78. package/build/types/accordion/Accordion.d.ts.map +1 -1
  79. package/build/types/accordion/AccordionItem/AccordionItem.d.ts +3 -0
  80. package/build/types/accordion/AccordionItem/AccordionItem.d.ts.map +1 -1
  81. package/build/types/inputs/SelectInput.d.ts +6 -3
  82. package/build/types/inputs/SelectInput.d.ts.map +1 -1
  83. package/build/types/inputs/_BottomSheet.d.ts +2 -1
  84. package/build/types/inputs/_BottomSheet.d.ts.map +1 -1
  85. package/build/types/inputs/_Popover.d.ts +2 -1
  86. package/build/types/inputs/_Popover.d.ts.map +1 -1
  87. package/build/types/moneyInput/MoneyInput.d.ts.map +1 -1
  88. package/build/types/select/option/Option.d.ts.map +1 -1
  89. package/build/types/typeahead/util/highlight.d.ts +1 -1
  90. package/build/types/typeahead/util/highlight.d.ts.map +1 -1
  91. package/package.json +5 -11
  92. package/src/accordion/Accordion.css +60 -1
  93. package/src/accordion/Accordion.story.tsx +8 -0
  94. package/src/accordion/Accordion.tsx +2 -0
  95. package/src/accordion/AccordionItem/AccordionItem.tsx +5 -0
  96. package/src/actionButton/ActionButton.css +53 -1
  97. package/src/avatar/Avatar.css +205 -1
  98. package/src/badge/Badge.css +68 -1
  99. package/src/button/Button.css +20 -1
  100. package/src/card/Card.css +100 -1
  101. package/src/checkboxButton/CheckboxButton.css +24 -1
  102. package/src/chips/Chip.css +190 -1
  103. package/src/circularButton/CircularButton.css +211 -1
  104. package/src/common/Option/Option.css +100 -1
  105. package/src/common/RadioButton/RadioButton.css +4 -1
  106. package/src/common/bottomSheet/BottomSheet.css +53 -1
  107. package/src/common/card/Card.css +49 -1
  108. package/src/common/closeButton/CloseButton.css +79 -1
  109. package/src/common/panel/Panel.css +73 -1
  110. package/src/criticalBanner/CriticalCommsBanner.css +76 -1
  111. package/src/dateInput/DateInput.css +3 -1
  112. package/src/dateLookup/DateLookup.css +98 -1
  113. package/src/dateLookup/DateLookup.story.js +12 -8
  114. package/src/dateLookup/dateTrigger/DateTrigger.css +68 -1
  115. package/src/decision/Decision.css +93 -1
  116. package/src/definitionList/DefinitionList.css +53 -1
  117. package/src/dimmer/Dimmer.css +70 -1
  118. package/src/drawer/Drawer.css +100 -1
  119. package/src/dropFade/DropFade.css +19 -1
  120. package/src/dynamicFieldDefinitionList/FormattedValue/FormattedValue.css +5 -1
  121. package/src/emphasis/Emphasis.css +31 -1
  122. package/src/flowNavigation/FlowNavigation.css +72 -1
  123. package/src/flowNavigation/animatedLabel/AnimatedLabel.css +21 -1
  124. package/src/flowNavigation/backButton/BackButton.css +32 -1
  125. package/src/header/Header.css +28 -1
  126. package/src/image/Image.css +13 -1
  127. package/src/info/Info.css +32 -1
  128. package/src/inputs/Input.css +105 -1
  129. package/src/inputs/InputGroup.css +62 -1
  130. package/src/inputs/SelectInput.css +374 -1
  131. package/src/inputs/SelectInput.spec.tsx +52 -3
  132. package/src/inputs/SelectInput.story.tsx +1 -1
  133. package/src/inputs/SelectInput.tsx +30 -15
  134. package/src/inputs/TextArea.css +109 -1
  135. package/src/inputs/_BottomSheet.tsx +3 -0
  136. package/src/inputs/_Popover.tsx +3 -0
  137. package/src/instructionsList/InstructionsList.css +22 -1
  138. package/src/link/Link.css +15 -1
  139. package/src/listItem/ListItem.css +6 -1
  140. package/src/loader/Loader.css +313 -1
  141. package/src/logo/Logo.css +26 -1
  142. package/src/main.css +5494 -1
  143. package/src/modal/Modal.css +155 -1
  144. package/src/moneyInput/MoneyInput.css +66 -1
  145. package/src/moneyInput/MoneyInput.js +3 -1
  146. package/src/moneyInput/MoneyInput.spec.js +4 -1
  147. package/src/navigationOption/NavigationOption.css +69 -1
  148. package/src/navigationOptionsList/NavigationOptionsList.css +13 -1
  149. package/src/nudge/Nudge.css +179 -1
  150. package/src/overlayHeader/OverlayHeader.css +15 -1
  151. package/src/phoneNumberInput/PhoneNumberInput.css +23 -1
  152. package/src/popover/Popover.css +43 -1
  153. package/src/progress/Progress.css +43 -1
  154. package/src/progressBar/ProgressBar.css +14 -1
  155. package/src/promoCard/PromoCard.css +186 -1
  156. package/src/section/Section.css +10 -1
  157. package/src/select/Select.css +309 -1
  158. package/src/select/Select.less +1 -8
  159. package/src/select/option/Option.spec.js +3 -21
  160. package/src/select/option/Option.tsx +2 -7
  161. package/src/slidingPanel/SlidingPanel.css +105 -1
  162. package/src/snackbar/Snackbar.css +93 -1
  163. package/src/statusIcon/StatusIcon.css +78 -1
  164. package/src/stepper/Stepper.css +108 -1
  165. package/src/summary/Summary.css +81 -1
  166. package/src/switch/Switch.css +68 -1
  167. package/src/tabs/Tabs.css +121 -1
  168. package/src/tile/Tile.css +55 -1
  169. package/src/tooltip/Tooltip.css +50 -1
  170. package/src/typeahead/Typeahead.css +183 -1
  171. package/src/typeahead/typeaheadOption/TypeaheadOption.css +9 -1
  172. package/src/typeahead/typeaheadOption/TypeaheadOption.js +3 -3
  173. package/src/typeahead/util/highlight.js +1 -1
  174. package/src/upload/Upload.css +15 -1
  175. package/src/uploadInput/UploadInput.css +71 -1
  176. package/src/uploadInput/uploadButton/UploadButton.css +49 -1
  177. package/src/uploadInput/uploadItem/UploadItem.css +74 -1
@@ -1 +1,109 @@
1
- .np-form-control{--ring-width:1px;--ring-color:var(--color-interactive-secondary);background-color:transparent;border:none;box-shadow:inset 0 0 0 var(--ring-width) var(--ring-color);color:#37517e;color:var(--color-content-primary);min-height:0;padding-left:16px;padding-left:var(--size-16);padding-right:16px;padding-right:var(--size-16);transition-duration:.3s;transition-property:color,opacity,box-shadow;transition-timing-function:ease-in-out}.np-form-control:focus-visible{outline:none}.np-form-control[aria-invalid=true]{--ring-width:2px;--ring-color:var(--color-sentiment-negative)!important}.np-form-control:hover:enabled{--ring-width:2px;--ring-color:var(--color-interactive-secondary-hover)}.np-form-control:focus:enabled{--ring-width:3px;--ring-color:var(--color-interactive-primary)}.np-form-control--size-auto{font-size:1rem;font-size:var(--font-size-16);font-weight:400;font-weight:var(--font-weight-regular);letter-spacing:-.011em;line-height:150%;padding-bottom:12px;padding-bottom:var(--size-12);padding-top:12px;padding-top:var(--size-12)}.np-form-control--size-lg,.np-form-control--size-md,.np-form-control--size-sm{padding-bottom:0!important;padding-top:0!important}.np-form-control--size-sm{font-size:1rem;font-size:var(--font-size-16);font-size:.875rem;font-size:var(--font-size-14);height:32px!important;height:var(--size-32)!important;letter-spacing:-.006em;line-height:1.5;line-height:var(--line-height-body);line-height:155%}.np-form-control--size-md,.np-form-control--size-sm{font-weight:400;font-weight:var(--font-weight-regular)}.np-form-control--size-md{font-size:1rem;font-size:var(--font-size-16);height:48px!important;height:var(--size-48)!important;letter-spacing:-.011em;line-height:150%}.np-form-control--size-lg{color:#37517e;color:var(--color-content-primary);font-size:1.375rem;font-size:var(--font-size-22);font-weight:600;font-weight:var(--font-weight-semi-bold);height:72px!important;height:var(--size-72)!important;letter-spacing:0;letter-spacing:-.018em;line-height:1.2;line-height:var(--line-height-title);line-height:125%;margin:0}.np-form-control--size-lg+ol:not(.list-unstyled),.np-form-control--size-lg+p,.np-form-control--size-lg+ul:not(.list-unstyled){margin-top:8px;margin-top:var(--size-8)}.np-text-area{border-radius:10px!important;border-radius:var(--radius-small)!important;min-height:72px;min-height:var(--size-72);overscroll-behavior:none;scroll-padding-bottom:8px;scroll-padding-bottom:var(--size-8);scroll-padding-top:8px;scroll-padding-top:var(--size-8)}.np-text-area::-moz-placeholder{color:#768e9c;color:var(--color-content-tertiary)}.np-text-area::placeholder{color:#768e9c;color:var(--color-content-tertiary)}
1
+ @media (min-width: 768px) {
2
+ }@media (min-width: 768px) {
3
+ }.np-form-control {
4
+ --ring-width: 1px;
5
+ --ring-color: var(--color-interactive-secondary);
6
+ border: none;
7
+ background-color: transparent;
8
+ min-height: 0;
9
+ /* TODO: Remove this override once `.form-control` isn’t used anymore */
10
+ padding-left: 16px;
11
+ padding-left: var(--size-16);
12
+ padding-right: 16px;
13
+ padding-right: var(--size-16);
14
+ color: #37517e;
15
+ color: var(--color-content-primary);
16
+ box-shadow: inset 0 0 0 1px #c9cbce;
17
+ box-shadow: inset 0 0 0 var(--ring-width) var(--ring-color);
18
+ transition-property: color, opacity, box-shadow;
19
+ transition-timing-function: ease-in-out;
20
+ transition-duration: 300ms;
21
+ /* TODO: Remove these overrides once `.form-control` isn’t used anymore */
22
+ }.np-form-control:focus-visible {
23
+ outline: none;
24
+ }.np-form-control[aria-invalid="true"] {
25
+ --ring-width: 2px;
26
+ --ring-color: var(--color-sentiment-negative) !important;
27
+ }.np-form-control:hover:enabled {
28
+ --ring-width: 2px;
29
+ --ring-color: var(--color-interactive-secondary-hover);
30
+ }.np-form-control:focus:enabled {
31
+ --ring-width: 3px;
32
+ --ring-color: var(--color-interactive-primary);
33
+ }.np-form-control--size-auto {
34
+ font-weight: 400;
35
+ font-weight: var(--font-weight-regular);
36
+ font-size: 1rem;
37
+ font-size: var(--font-size-16);
38
+ line-height: 150%;
39
+ letter-spacing: -0.011em;
40
+ padding-top: 12px;
41
+ padding-top: var(--size-12);
42
+ padding-bottom: 12px;
43
+ padding-bottom: var(--size-12);
44
+ }.np-form-control--size-sm,
45
+ .np-form-control--size-md,
46
+ .np-form-control--size-lg {
47
+ padding-top: 0 !important;
48
+ padding-bottom: 0 !important;
49
+ }.np-form-control--size-sm {
50
+ line-height: 1.5;
51
+ line-height: var(--line-height-body);
52
+ font-size: 1rem;
53
+ font-size: var(--font-size-16);
54
+ font-size: 0.875rem;
55
+ font-size: var(--font-size-14);
56
+ line-height: 155%;
57
+ letter-spacing: -0.006em;
58
+ font-weight: 400;
59
+ font-weight: var(--font-weight-regular);
60
+ height: 32px !important;
61
+ height: var(--size-32) !important;
62
+ }.np-form-control--size-md {
63
+ font-weight: 400;
64
+ font-weight: var(--font-weight-regular);
65
+ font-size: 1rem;
66
+ font-size: var(--font-size-16);
67
+ line-height: 150%;
68
+ letter-spacing: -0.011em;
69
+ height: 48px !important;
70
+ height: var(--size-48) !important;
71
+ }.np-form-control--size-lg {
72
+ margin: 0;
73
+ color: #37517e;
74
+ color: var(--color-content-primary);
75
+ line-height: 1.2;
76
+ line-height: var(--line-height-title);
77
+ letter-spacing: 0;
78
+ margin-bottom: 0;
79
+ margin-bottom: initial;
80
+ font-size: 1.375rem;
81
+ font-size: var(--font-size-22);
82
+ font-weight: 600;
83
+ font-weight: var(--font-weight-semi-bold);
84
+ letter-spacing: -0.018em;
85
+ line-height: 125%;
86
+ height: 72px !important;
87
+ height: var(--size-72) !important;
88
+ }.np-form-control--size-lg + p,
89
+ .np-form-control--size-lg + ul:not(.list-unstyled),
90
+ .np-form-control--size-lg + ol:not(.list-unstyled) {
91
+ margin-top: 8px;
92
+ margin-top: var(--size-8);
93
+ }.np-text-area {
94
+ min-height: 72px;
95
+ min-height: var(--size-72);
96
+ scroll-padding-top: 8px;
97
+ scroll-padding-top: var(--size-8);
98
+ scroll-padding-bottom: 8px;
99
+ scroll-padding-bottom: var(--size-8);
100
+ overscroll-behavior: none;
101
+ border-radius: 10px !important;
102
+ border-radius: var(--radius-small) !important;
103
+ }.np-text-area::-moz-placeholder {
104
+ color: #768e9c;
105
+ color: var(--color-content-tertiary);
106
+ }.np-text-area::placeholder {
107
+ color: #768e9c;
108
+ color: var(--color-content-tertiary);
109
+ }
@@ -29,6 +29,7 @@ export interface BottomSheetProps {
29
29
  padding?: 'none' | 'md';
30
30
  children?: React.ReactNode;
31
31
  onClose?: () => void;
32
+ onCloseEnd?: () => void;
32
33
  }
33
34
 
34
35
  export function BottomSheet({
@@ -39,6 +40,7 @@ export function BottomSheet({
39
40
  padding = 'md',
40
41
  children,
41
42
  onClose,
43
+ onCloseEnd,
42
44
  }: BottomSheetProps) {
43
45
  const { refs, context } = useFloating<Element>({
44
46
  open,
@@ -73,6 +75,7 @@ export function BottomSheet({
73
75
  beforeEnter={() => {
74
76
  setFloatingKey((prev) => prev + 1);
75
77
  }}
78
+ afterLeave={onCloseEnd}
76
79
  >
77
80
  <FocusBoundary>
78
81
  <Transition.Child
@@ -34,6 +34,7 @@ export interface PopoverProps {
34
34
  padding?: 'none' | 'md';
35
35
  children?: React.ReactNode;
36
36
  onClose?: () => void;
37
+ onCloseEnd?: () => void;
37
38
  }
38
39
 
39
40
  const floatingPadding = 16;
@@ -47,6 +48,7 @@ export function Popover({
47
48
  padding = 'md',
48
49
  children,
49
50
  onClose,
51
+ onCloseEnd,
50
52
  }: PopoverProps) {
51
53
  const { refs, floatingStyles, context } = useFloating<Element>({
52
54
  placement,
@@ -96,6 +98,7 @@ export function Popover({
96
98
  beforeEnter={() => {
97
99
  setFloatingKey((prev) => prev + 1);
98
100
  }}
101
+ afterLeave={onCloseEnd}
99
102
  >
100
103
  <FocusBoundary>
101
104
  <FloatingFocusManager context={context} guards={false} modal={false}>
@@ -1 +1,22 @@
1
- .tw-instructions{display:flex;flex-direction:column}.tw-instructions .instruction{display:flex;margin-top:8px;margin-top:var(--padding-x-small)}.tw-instructions .instruction .do,.tw-instructions .instruction .dont{flex-shrink:0;margin-bottom:0;margin-right:8px;margin-right:var(--padding-x-small)}.tw-instructions .instruction .do{color:var(--color-sentiment-positive)}.tw-instructions .instruction .dont{color:var(--color-sentiment-negative)}
1
+ .tw-instructions {
2
+ display: flex;
3
+ flex-direction: column;
4
+ }
5
+ .tw-instructions .instruction {
6
+ display: flex;
7
+ margin-top: 8px;
8
+ margin-top: var(--padding-x-small);
9
+ }
10
+ .tw-instructions .instruction .do,
11
+ .tw-instructions .instruction .dont {
12
+ flex-shrink: 0;
13
+ margin-right: 8px;
14
+ margin-right: var(--padding-x-small);
15
+ margin-bottom: 0;
16
+ }
17
+ .tw-instructions .instruction .do {
18
+ color: var(--color-sentiment-positive);
19
+ }
20
+ .tw-instructions .instruction .dont {
21
+ color: var(--color-sentiment-negative);
22
+ }
package/src/link/Link.css CHANGED
@@ -1 +1,15 @@
1
- a{border-radius:2px}.np-link .tw-icon{align-items:center;display:flex;margin-left:4px;margin-left:var(--size-4)}[dir=rtl] .np-link .tw-icon{margin-left:0;margin-right:4px;margin-right:var(--size-4)}
1
+ a {
2
+ border-radius: 2px;
3
+ }
4
+ .np-link .tw-icon {
5
+ display: flex;
6
+ align-items: center;
7
+ margin-left: 4px;
8
+ margin-left: var(--size-4);
9
+ }
10
+ [dir="rtl"] .np-link .tw-icon {
11
+ margin-right: 4px;
12
+ margin-right: var(--size-4);
13
+ margin-left: 0;
14
+ margin-left: initial;
15
+ }
@@ -1 +1,6 @@
1
- .np-list-item{width:100%}.np-list-item__action{flex-shrink:0}
1
+ .np-list-item {
2
+ width: 100%;
3
+ }
4
+ .np-list-item__action {
5
+ flex-shrink: 0;
6
+ }