@transferwise/components 46.7.0 → 46.8.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/build/main.css CHANGED
@@ -4629,6 +4629,107 @@ html:not([dir="rtl"]) .np-navigation-option {
4629
4629
  .np-theme-personal .np-dropdown-menu .np-dropdown-item--focused {
4630
4630
  box-shadow: inset 0 0 0 2px var(--color-interactive-primary);
4631
4631
  }
4632
+ .segmented-control {
4633
+ box-sizing: border-box;
4634
+ --segment-highlight-width: 0;
4635
+ --segment-highlight-x: var(--size-4);
4636
+ }
4637
+ .segmented-control__segments {
4638
+ display: inline-flex;
4639
+ position: relative;
4640
+ padding: 4px;
4641
+ padding: var(--size-4);
4642
+ width: 100%;
4643
+ justify-content: center;
4644
+ align-items: center;
4645
+ background: rgba(134,167,189,0.10196);
4646
+ background: var(--color-background-neutral);
4647
+ border-radius: 24px;
4648
+ border-radius: var(--size-24);
4649
+ transition: outline 300ms;
4650
+ outline: 2px solid transparent;
4651
+ }
4652
+ .segmented-control--input:has(:focus-visible) > .segmented-control__segments::after {
4653
+ outline: 2px solid var(--color-interactive-primary);
4654
+ }
4655
+ .segmented-control__segments::after {
4656
+ content: "";
4657
+ position: absolute;
4658
+ width: var(--segment-highlight-width);
4659
+ top: 4px;
4660
+ top: var(--size-4);
4661
+ bottom: 4px;
4662
+ bottom: var(--size-4);
4663
+ left: var(--segment-highlight-x);
4664
+ z-index: 0;
4665
+ background: #ffffff;
4666
+ background: var(--color-background-screen);
4667
+ border-radius: 24px;
4668
+ border-radius: var(--size-24);
4669
+ transition: left 300ms;
4670
+ }
4671
+ .segmented-control__segments--no-animate::after {
4672
+ transition: none !important;
4673
+ }
4674
+ .segmented-control__segment {
4675
+ position: relative;
4676
+ flex: 1 1 100%;
4677
+ flex-flow: column;
4678
+ padding: 8px 16px;
4679
+ padding: var(--size-8) var(--size-16);
4680
+ margin: 0 0 0 4px;
4681
+ margin: 0 0 0 var(--size-4);
4682
+ min-width: 0;
4683
+ line-height: inherit;
4684
+ align-items: center;
4685
+ text-align: center;
4686
+ vertical-align: middle;
4687
+ border-radius: 24px;
4688
+ border-radius: var(--size-24);
4689
+ z-index: 1;
4690
+ cursor: pointer;
4691
+ transition: background 300ms;
4692
+ color: var(--color-interactive-primary);
4693
+ }
4694
+ .segmented-control__segment:first-child {
4695
+ margin-left: 0;
4696
+ }
4697
+ .segmented-control__segment:hover {
4698
+ background: rgba(0,0,0,0.10196);
4699
+ background: var(--color-background-overlay);
4700
+ }
4701
+ .segmented-control__radio-input {
4702
+ position: fixed;
4703
+ opacity: 0;
4704
+ pointer-events: none;
4705
+ }
4706
+ .segmented-control__button {
4707
+ width: 100%;
4708
+ height: 100%;
4709
+ background: none;
4710
+ -webkit-appearance: none;
4711
+ -moz-appearance: none;
4712
+ appearance: none;
4713
+ border: none;
4714
+ outline: none;
4715
+ font: inherit;
4716
+ outline: 2px solid transparent;
4717
+ }
4718
+ .segmented-control__button:focus {
4719
+ outline-offset: 0px;
4720
+ }
4721
+ .segmented-control__button:focus-visible {
4722
+ outline-color: var(--color-interactive-primary);
4723
+ }
4724
+ .segmented-control__selected-segment:hover {
4725
+ background: transparent;
4726
+ }
4727
+ .segmented-control__text {
4728
+ word-wrap: break-word;
4729
+ word-break: break-word;
4730
+ color: var(--color-interactive-primary);
4731
+ transition: font-weight 300ms;
4732
+ }
4632
4733
  .np-summary {
4633
4734
  min-width: 280px;
4634
4735
  }
@@ -4629,6 +4629,107 @@ html:not([dir="rtl"]) .np-navigation-option {
4629
4629
  .np-theme-personal .np-dropdown-menu .np-dropdown-item--focused {
4630
4630
  box-shadow: inset 0 0 0 2px var(--color-interactive-primary);
4631
4631
  }
4632
+ .segmented-control {
4633
+ box-sizing: border-box;
4634
+ --segment-highlight-width: 0;
4635
+ --segment-highlight-x: var(--size-4);
4636
+ }
4637
+ .segmented-control__segments {
4638
+ display: inline-flex;
4639
+ position: relative;
4640
+ padding: 4px;
4641
+ padding: var(--size-4);
4642
+ width: 100%;
4643
+ justify-content: center;
4644
+ align-items: center;
4645
+ background: rgba(134,167,189,0.10196);
4646
+ background: var(--color-background-neutral);
4647
+ border-radius: 24px;
4648
+ border-radius: var(--size-24);
4649
+ transition: outline 300ms;
4650
+ outline: 2px solid transparent;
4651
+ }
4652
+ .segmented-control--input:has(:focus-visible) > .segmented-control__segments::after {
4653
+ outline: 2px solid var(--color-interactive-primary);
4654
+ }
4655
+ .segmented-control__segments::after {
4656
+ content: "";
4657
+ position: absolute;
4658
+ width: var(--segment-highlight-width);
4659
+ top: 4px;
4660
+ top: var(--size-4);
4661
+ bottom: 4px;
4662
+ bottom: var(--size-4);
4663
+ left: var(--segment-highlight-x);
4664
+ z-index: 0;
4665
+ background: #ffffff;
4666
+ background: var(--color-background-screen);
4667
+ border-radius: 24px;
4668
+ border-radius: var(--size-24);
4669
+ transition: left 300ms;
4670
+ }
4671
+ .segmented-control__segments--no-animate::after {
4672
+ transition: none !important;
4673
+ }
4674
+ .segmented-control__segment {
4675
+ position: relative;
4676
+ flex: 1 1 100%;
4677
+ flex-flow: column;
4678
+ padding: 8px 16px;
4679
+ padding: var(--size-8) var(--size-16);
4680
+ margin: 0 0 0 4px;
4681
+ margin: 0 0 0 var(--size-4);
4682
+ min-width: 0;
4683
+ line-height: inherit;
4684
+ align-items: center;
4685
+ text-align: center;
4686
+ vertical-align: middle;
4687
+ border-radius: 24px;
4688
+ border-radius: var(--size-24);
4689
+ z-index: 1;
4690
+ cursor: pointer;
4691
+ transition: background 300ms;
4692
+ color: var(--color-interactive-primary);
4693
+ }
4694
+ .segmented-control__segment:first-child {
4695
+ margin-left: 0;
4696
+ }
4697
+ .segmented-control__segment:hover {
4698
+ background: rgba(0,0,0,0.10196);
4699
+ background: var(--color-background-overlay);
4700
+ }
4701
+ .segmented-control__radio-input {
4702
+ position: fixed;
4703
+ opacity: 0;
4704
+ pointer-events: none;
4705
+ }
4706
+ .segmented-control__button {
4707
+ width: 100%;
4708
+ height: 100%;
4709
+ background: none;
4710
+ -webkit-appearance: none;
4711
+ -moz-appearance: none;
4712
+ appearance: none;
4713
+ border: none;
4714
+ outline: none;
4715
+ font: inherit;
4716
+ outline: 2px solid transparent;
4717
+ }
4718
+ .segmented-control__button:focus {
4719
+ outline-offset: 0px;
4720
+ }
4721
+ .segmented-control__button:focus-visible {
4722
+ outline-color: var(--color-interactive-primary);
4723
+ }
4724
+ .segmented-control__selected-segment:hover {
4725
+ background: transparent;
4726
+ }
4727
+ .segmented-control__text {
4728
+ word-wrap: break-word;
4729
+ word-break: break-word;
4730
+ color: var(--color-interactive-primary);
4731
+ transition: font-weight 300ms;
4732
+ }
4632
4733
  .np-summary {
4633
4734
  min-width: 280px;
4634
4735
  }
@@ -0,0 +1,101 @@
1
+ .segmented-control {
2
+ box-sizing: border-box;
3
+ --segment-highlight-width: 0;
4
+ --segment-highlight-x: var(--size-4);
5
+ }
6
+ .segmented-control__segments {
7
+ display: inline-flex;
8
+ position: relative;
9
+ padding: 4px;
10
+ padding: var(--size-4);
11
+ width: 100%;
12
+ justify-content: center;
13
+ align-items: center;
14
+ background: rgba(134,167,189,0.10196);
15
+ background: var(--color-background-neutral);
16
+ border-radius: 24px;
17
+ border-radius: var(--size-24);
18
+ transition: outline 300ms;
19
+ outline: 2px solid transparent;
20
+ }
21
+ .segmented-control--input:has(:focus-visible) > .segmented-control__segments::after {
22
+ outline: 2px solid var(--color-interactive-primary);
23
+ }
24
+ .segmented-control__segments::after {
25
+ content: "";
26
+ position: absolute;
27
+ width: var(--segment-highlight-width);
28
+ top: 4px;
29
+ top: var(--size-4);
30
+ bottom: 4px;
31
+ bottom: var(--size-4);
32
+ left: var(--segment-highlight-x);
33
+ z-index: 0;
34
+ background: #ffffff;
35
+ background: var(--color-background-screen);
36
+ border-radius: 24px;
37
+ border-radius: var(--size-24);
38
+ transition: left 300ms;
39
+ }
40
+ .segmented-control__segments--no-animate::after {
41
+ transition: none !important;
42
+ }
43
+ .segmented-control__segment {
44
+ position: relative;
45
+ flex: 1 1 100%;
46
+ flex-flow: column;
47
+ padding: 8px 16px;
48
+ padding: var(--size-8) var(--size-16);
49
+ margin: 0 0 0 4px;
50
+ margin: 0 0 0 var(--size-4);
51
+ min-width: 0;
52
+ line-height: inherit;
53
+ align-items: center;
54
+ text-align: center;
55
+ vertical-align: middle;
56
+ border-radius: 24px;
57
+ border-radius: var(--size-24);
58
+ z-index: 1;
59
+ cursor: pointer;
60
+ transition: background 300ms;
61
+ color: var(--color-interactive-primary);
62
+ }
63
+ .segmented-control__segment:first-child {
64
+ margin-left: 0;
65
+ }
66
+ .segmented-control__segment:hover {
67
+ background: rgba(0,0,0,0.10196);
68
+ background: var(--color-background-overlay);
69
+ }
70
+ .segmented-control__radio-input {
71
+ position: fixed;
72
+ opacity: 0;
73
+ pointer-events: none;
74
+ }
75
+ .segmented-control__button {
76
+ width: 100%;
77
+ height: 100%;
78
+ background: none;
79
+ -webkit-appearance: none;
80
+ -moz-appearance: none;
81
+ appearance: none;
82
+ border: none;
83
+ outline: none;
84
+ font: inherit;
85
+ outline: 2px solid transparent;
86
+ }
87
+ .segmented-control__button:focus {
88
+ outline-offset: 0px;
89
+ }
90
+ .segmented-control__button:focus-visible {
91
+ outline-color: var(--color-interactive-primary);
92
+ }
93
+ .segmented-control__selected-segment:hover {
94
+ background: transparent;
95
+ }
96
+ .segmented-control__text {
97
+ word-wrap: break-word;
98
+ word-break: break-word;
99
+ color: var(--color-interactive-primary);
100
+ transition: font-weight 300ms;
101
+ }
@@ -13,6 +13,7 @@ export type { UploadedFile, UploadError, UploadResponse } from './uploadInput/ty
13
13
  export type { ModalProps } from './modal';
14
14
  export type { CurrencyHeaderItem, CurrencyItem, CurrencyOptionItem, MoneyInputProps, } from './moneyInput';
15
15
  export type { LayoutDirection, TypographyTypes, TitleTypes, BodyTypes, LinkTypes, DisplayTypes, } from './common';
16
+ export type { SegmentedControlProps } from './segmentedControl';
16
17
  /**
17
18
  * Components
18
19
  */
@@ -82,6 +83,7 @@ export { default as RadioGroup } from './radioGroup';
82
83
  export { default as RadioOption } from './radioOption';
83
84
  export { default as Section } from './section';
84
85
  export { default as Select } from './select';
86
+ export { default as SegmentedControl } from './segmentedControl';
85
87
  export { default as SlidingPanel } from './slidingPanel';
86
88
  export { default as SnackbarPortal } from './snackbar/Snackbar';
87
89
  export { default as SnackbarProvider } from './snackbar/SnackbarProvider';
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,YAAY,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AACjD,YAAY,EAAE,2BAA2B,EAAE,MAAM,0BAA0B,CAAC;AAC5E,YAAY,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AAC3D,YAAY,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;AAC7D,YAAY,EACV,oBAAoB,EACpB,eAAe,EACf,6BAA6B,EAC7B,qBAAqB,EACrB,gBAAgB,EAChB,wBAAwB,EACxB,6BAA6B,GAC9B,MAAM,sBAAsB,CAAC;AAC9B,YAAY,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AACvD,YAAY,EAAE,qBAAqB,EAAE,MAAM,qCAAqC,CAAC;AACjF,YAAY,EAAE,8BAA8B,EAAE,MAAM,6BAA6B,CAAC;AAClF,YAAY,EAAE,YAAY,EAAE,WAAW,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AACrF,YAAY,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AAC1C,YAAY,EACV,kBAAkB,EAClB,YAAY,EACZ,kBAAkB,EAClB,eAAe,GAChB,MAAM,cAAc,CAAC;AACtB,YAAY,EACV,eAAe,EACf,eAAe,EACf,UAAU,EACV,SAAS,EACT,SAAS,EACT,YAAY,GACb,MAAM,UAAU,CAAC;AAElB;;GAEG;AACH,OAAO,EAAE,OAAO,IAAI,KAAK,EAAE,MAAM,SAAS,CAAC;AAC3C,OAAO,EAAE,OAAO,IAAI,IAAI,EAAE,MAAM,QAAQ,CAAC;AACzC,OAAO,EAAE,OAAO,IAAI,SAAS,EAAE,MAAM,aAAa,CAAC;AACnD,OAAO,EAAE,OAAO,IAAI,YAAY,EAAE,MAAM,gBAAgB,CAAC;AACzD,OAAO,EAAE,OAAO,IAAI,YAAY,EAAE,MAAM,gBAAgB,CAAC;AACzD,OAAO,EAAE,OAAO,IAAI,KAAK,EAAE,MAAM,SAAS,CAAC;AAC3C,OAAO,EAAE,OAAO,IAAI,MAAM,EAAE,MAAM,UAAU,CAAC;AAC7C,OAAO,EAAE,OAAO,IAAI,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAC3D,OAAO,EAAE,OAAO,IAAI,KAAK,EAAE,MAAM,SAAS,CAAC;AAC3C,OAAO,EAAE,OAAO,IAAI,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAC9D,OAAO,EAAE,OAAO,IAAI,MAAM,EAAE,MAAM,UAAU,CAAC;AAC7C,OAAO,EAAE,OAAO,IAAI,IAAI,EAAE,MAAM,QAAQ,CAAC;AACzC,OAAO,EAAE,OAAO,IAAI,QAAQ,EAAE,MAAM,eAAe,CAAC;AACpD,OAAO,EAAE,OAAO,IAAI,QAAQ,EAAE,MAAM,YAAY,CAAC;AACjD,OAAO,EAAE,OAAO,IAAI,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAC7D,OAAO,EAAE,OAAO,IAAI,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAC7D,OAAO,EAAE,OAAO,IAAI,OAAO,EAAE,MAAM,WAAW,CAAC;AAC/C,OAAO,EAAE,OAAO,IAAI,KAAK,EAAE,IAAI,EAAE,MAAM,SAAS,CAAC;AACjD,OAAO,EAAE,OAAO,IAAI,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAC7D,OAAO,EAAE,OAAO,IAAI,SAAS,EAAE,MAAM,aAAa,CAAC;AACnD,OAAO,EAAE,OAAO,IAAI,UAAU,EAAE,MAAM,cAAc,CAAC;AACrD,OAAO,EAAE,OAAO,IAAI,QAAQ,EAAE,MAAM,YAAY,CAAC;AACjD,OAAO,EAAE,OAAO,IAAI,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAC7D,OAAO,EAAE,OAAO,IAAI,MAAM,EAAE,MAAM,UAAU,CAAC;AAC7C,OAAO,EAAE,OAAO,IAAI,OAAO,EAAE,MAAM,WAAW,CAAC;AAC/C,OAAO,EAAE,OAAO,IAAI,MAAM,EAAE,MAAM,UAAU,CAAC;AAC7C,OAAO,EAAE,OAAO,IAAI,QAAQ,EAAE,MAAM,YAAY,CAAC;AACjD,OAAO,EAAE,OAAO,IAAI,0BAA0B,EAAE,MAAM,8BAA8B,CAAC;AACrF,OAAO,EAAE,OAAO,IAAI,QAAQ,EAAE,MAAM,YAAY,CAAC;AACjD,OAAO,EAAE,OAAO,IAAI,cAAc,EAAE,MAAM,iCAAiC,CAAC;AAC5E,OAAO,EAAE,OAAO,IAAI,MAAM,EAAE,MAAM,UAAU,CAAC;AAC7C,OAAO,EAAE,OAAO,IAAI,KAAK,EAAE,MAAM,SAAS,CAAC;AAC3C,OAAO,EAAE,OAAO,IAAI,IAAI,EAAE,MAAM,QAAQ,CAAC;AACzC,OAAO,EAAE,OAAO,IAAI,WAAW,EAAE,MAAM,eAAe,CAAC;AACvD,OAAO,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAC;AACvC,OAAO,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AACjD,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AACnD,OAAO,EACL,WAAW,EACX,wBAAwB,EACxB,wBAAwB,GACzB,MAAM,sBAAsB,CAAC;AAC9B,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAC7C,OAAO,EAAE,OAAO,IAAI,sBAAsB,EAAE,MAAM,0BAA0B,CAAC;AAC7E,OAAO,EAAE,OAAO,IAAI,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AACjE,OAAO,EAAE,OAAO,IAAI,IAAI,EAAE,MAAM,QAAQ,CAAC;AACzC,OAAO,EAAE,OAAO,IAAI,MAAM,EAAE,MAAM,UAAU,CAAC;AAC7C,OAAO,EAAE,OAAO,IAAI,IAAI,EAAE,MAAM,QAAQ,CAAC;AACzC,OAAO,EAAE,OAAO,IAAI,QAAQ,EAAE,MAAM,YAAY,CAAC;AACjD,OAAO,EAAE,OAAO,IAAI,KAAK,EAAE,MAAM,SAAS,CAAC;AAC3C,OAAO,EAAE,OAAO,IAAI,KAAK,EAAE,MAAM,SAAS,CAAC;AAC3C,OAAO,EAAE,OAAO,IAAI,UAAU,EAAE,MAAM,cAAc,CAAC;AACrD,OAAO,EAAE,OAAO,IAAI,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AACjE,OAAO,EAAE,OAAO,IAAI,qBAAqB,EAAE,MAAM,yBAAyB,CAAC;AAC3E,OAAO,EAAE,OAAO,IAAI,KAAK,EAAE,MAAM,SAAS,CAAC;AAC3C,OAAO,EAAE,OAAO,IAAI,MAAM,EAAE,MAAM,iBAAiB,CAAC;AACpD,OAAO,EAAE,OAAO,IAAI,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAC3D,OAAO,EAAE,OAAO,IAAI,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AACjE,OAAO,EAAE,OAAO,IAAI,OAAO,EAAE,MAAM,WAAW,CAAC;AAC/C,OAAO,EAAE,OAAO,IAAI,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AACjE,OAAO,EAAE,OAAO,IAAI,WAAW,EAAE,MAAM,eAAe,CAAC;AACvD,OAAO,EAAE,OAAO,IAAI,QAAQ,EAAE,MAAM,YAAY,CAAC;AACjD,OAAO,EAAE,OAAO,IAAI,SAAS,EAAE,MAAM,aAAa,CAAC;AACnD,OAAO,EAAE,OAAO,IAAI,cAAc,EAAE,MAAM,aAAa,CAAC;AACxD,OAAO,EAAE,OAAO,IAAI,QAAQ,EAAE,iBAAiB,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AACtF,OAAO,EAAE,OAAO,IAAI,KAAK,EAAE,MAAM,SAAS,CAAC;AAC3C,OAAO,EAAE,OAAO,IAAI,UAAU,EAAE,MAAM,cAAc,CAAC;AACrD,OAAO,EAAE,OAAO,IAAI,WAAW,EAAE,MAAM,eAAe,CAAC;AACvD,OAAO,EAAE,OAAO,IAAI,OAAO,EAAE,MAAM,WAAW,CAAC;AAC/C,OAAO,EAAE,OAAO,IAAI,MAAM,EAAE,MAAM,UAAU,CAAC;AAC7C,OAAO,EAAE,OAAO,IAAI,YAAY,EAAE,MAAM,gBAAgB,CAAC;AACzD,OAAO,EAAE,OAAO,IAAI,cAAc,EAAE,MAAM,qBAAqB,CAAC;AAChE,OAAO,EAAE,OAAO,IAAI,gBAAgB,EAAE,MAAM,6BAA6B,CAAC;AAC1E,OAAO,EAAE,OAAO,IAAI,UAAU,EAAE,MAAM,yBAAyB,CAAC;AAChE,OAAO,EAAE,OAAO,IAAI,OAAO,EAAE,MAAM,mBAAmB,CAAC;AACvD,OAAO,EAAE,OAAO,IAAI,MAAM,EAAE,MAAM,UAAU,CAAC;AAC7C,OAAO,EAAE,OAAO,IAAI,OAAO,EAAE,MAAM,WAAW,CAAC;AAC/C,OAAO,EAAE,OAAO,IAAI,MAAM,EAAE,MAAM,UAAU,CAAC;AAC7C,OAAO,EAAE,OAAO,IAAI,YAAY,EAAE,MAAM,gBAAgB,CAAC;AACzD,OAAO,EAAE,OAAO,IAAI,IAAI,EAAE,MAAM,QAAQ,CAAC;AACzC,OAAO,EAAE,OAAO,IAAI,yBAAyB,EAAE,MAAM,6BAA6B,CAAC;AACnF,OAAO,EAAE,OAAO,IAAI,OAAO,EAAE,MAAM,WAAW,CAAC;AAC/C,OAAO,EAAE,OAAO,IAAI,SAAS,EAAE,MAAM,aAAa,CAAC;AACnD,OAAO,EAAE,OAAO,IAAI,MAAM,EAAE,MAAM,UAAU,CAAC;AAC7C,OAAO,EAAE,OAAO,IAAI,WAAW,EAAE,MAAM,eAAe,CAAC;AACvD,OAAO,EAAE,gBAAgB,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAC;AAC/E,OAAO,EAAE,OAAO,IAAI,mBAAmB,EAAE,MAAM,kBAAkB,CAAC;AAClE,OAAO,EAAE,OAAO,IAAI,QAAQ,EAAE,MAAM,YAAY,CAAC;AAEjD;;GAEG;AACH,OAAO,EAAE,OAAO,IAAI,WAAW,EAAE,MAAM,wBAAwB,CAAC;AAChE,OAAO,EAAE,YAAY,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AACzD,OAAO,EAAE,aAAa,EAAE,MAAM,8BAA8B,CAAC;AAE7D;;GAEG;AACH,OAAO,EACL,SAAS,EACT,IAAI,EACJ,KAAK,EACL,SAAS,EACT,QAAQ,EACR,WAAW,EACX,IAAI,EACJ,KAAK,EACL,QAAQ,EACR,WAAW,EACX,QAAQ,EACR,MAAM,EACN,WAAW,EACX,UAAU,EACV,MAAM,EACN,MAAM,EACN,gBAAgB,EAChB,UAAU,EACV,OAAO,GACR,MAAM,UAAU,CAAC;AAClB,OAAO,EAAE,UAAU,EAAE,MAAM,UAAU,CAAC;AACtC,OAAO,EAAE,gBAAgB,EAAE,MAAM,QAAQ,CAAC;AAC1C,OAAO,EAAE,UAAU,EAAE,MAAM,UAAU,CAAC;AACtC,OAAO,EAAE,oBAAoB,EAAE,YAAY,EAAE,MAAM,YAAY,CAAC;AAChE,OAAO,EAAE,kBAAkB,EAAE,MAAM,mBAAmB,CAAC;AACvD,OAAO,EAAE,QAAQ,EAAE,MAAM,QAAQ,CAAC;AAClC,OAAO,EAAE,QAAQ,EAAE,MAAM,UAAU,CAAC;AAEpC;;GAEG;AACH,OAAO,EACL,YAAY,EACZ,YAAY,EACZ,cAAc,EACd,oBAAoB,EACpB,sBAAsB,EACtB,iBAAiB,EACjB,SAAS,EACT,YAAY,EACZ,aAAa,EACb,mBAAmB,GACpB,MAAM,UAAU,CAAC;AAElB;;GAEG;AACH,OAAO,EAAE,OAAO,IAAI,YAAY,EAAE,MAAM,QAAQ,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,31 @@
1
+ /// <reference types="react" />
2
+ type SegmentBase = {
3
+ id: string;
4
+ label: string;
5
+ value: string;
6
+ };
7
+ type Segment = SegmentBase & {
8
+ controls?: never;
9
+ };
10
+ type SegmentWithControls = SegmentBase & {
11
+ controls: string;
12
+ };
13
+ export type Segments = Segment[] | SegmentWithControls[];
14
+ type SegmentedControlPropsBase = {
15
+ name: string;
16
+ defaultValue: string;
17
+ mode: 'input' | 'view';
18
+ onChange: (value: string) => void;
19
+ };
20
+ type SegmentedControlViewProps = {
21
+ mode: 'view';
22
+ segments: SegmentWithControls[];
23
+ };
24
+ type SegmentedControlInputProps = {
25
+ mode: 'input';
26
+ segments: Segment[];
27
+ };
28
+ export type SegmentedControlProps = SegmentedControlPropsBase & (SegmentedControlViewProps | SegmentedControlInputProps);
29
+ declare const SegmentedControl: ({ name, defaultValue, mode, segments, onChange, }: SegmentedControlProps) => import("react").JSX.Element;
30
+ export default SegmentedControl;
31
+ //# sourceMappingURL=SegmentedControl.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SegmentedControl.d.ts","sourceRoot":"","sources":["../../../src/segmentedControl/SegmentedControl.tsx"],"names":[],"mappings":";AAMA,KAAK,WAAW,GAAG;IAAE,EAAE,EAAE,MAAM,CAAC;IAAC,KAAK,EAAE,MAAM,CAAC;IAAC,KAAK,EAAE,MAAM,CAAA;CAAE,CAAC;AAEhE,KAAK,OAAO,GAAG,WAAW,GAAG;IAAE,QAAQ,CAAC,EAAE,KAAK,CAAA;CAAE,CAAC;AAClD,KAAK,mBAAmB,GAAG,WAAW,GAAG;IAAE,QAAQ,EAAE,MAAM,CAAA;CAAE,CAAC;AAE9D,MAAM,MAAM,QAAQ,GAAG,OAAO,EAAE,GAAG,mBAAmB,EAAE,CAAC;AAEzD,KAAK,yBAAyB,GAAG;IAC/B,IAAI,EAAE,MAAM,CAAC;IACb,YAAY,EAAE,MAAM,CAAC;IACrB,IAAI,EAAE,OAAO,GAAG,MAAM,CAAC;IACvB,QAAQ,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;CACnC,CAAC;AAEF,KAAK,yBAAyB,GAAG;IAC/B,IAAI,EAAE,MAAM,CAAC;IACb,QAAQ,EAAE,mBAAmB,EAAE,CAAC;CACjC,CAAC;AAEF,KAAK,0BAA0B,GAAG;IAChC,IAAI,EAAE,OAAO,CAAC;IACd,QAAQ,EAAE,OAAO,EAAE,CAAC;CACrB,CAAC;AAEF,MAAM,MAAM,qBAAqB,GAAG,yBAAyB,GAC3D,CAAC,yBAAyB,GAAG,0BAA0B,CAAC,CAAC;AAE3D,QAAA,MAAM,gBAAgB,sDAMnB,qBAAqB,gCAqIvB,CAAC;AAEF,eAAe,gBAAgB,CAAC"}
@@ -0,0 +1,3 @@
1
+ export * from './SegmentedControl';
2
+ export { default } from './SegmentedControl';
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/segmentedControl/index.ts"],"names":[],"mappings":"AAAA,cAAc,oBAAoB,CAAC;AACnC,OAAO,EAAE,OAAO,EAAE,MAAM,oBAAoB,CAAC"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@transferwise/components",
3
- "version": "46.7.0",
3
+ "version": "46.8.0",
4
4
  "description": "Neptune React components",
5
5
  "license": "Apache-2.0",
6
6
  "repository": {
@@ -21,7 +21,7 @@
21
21
  "!**/*.tsbuildinfo"
22
22
  ],
23
23
  "devDependencies": {
24
- "@babel/core": "^7.22.15",
24
+ "@babel/core": "^7.23.9",
25
25
  "@babel/plugin-transform-runtime": "^7.22.15",
26
26
  "@babel/preset-env": "^7.22.15",
27
27
  "@babel/preset-react": "^7.22.15",
@@ -53,7 +53,7 @@
53
53
  "@testing-library/react-hooks": "^8.0.0",
54
54
  "@testing-library/user-event": "^13.2.1",
55
55
  "@transferwise/icons": "^3.7.0",
56
- "@transferwise/neptune-tokens": "^8.8.0",
56
+ "@transferwise/neptune-tokens": "^8.8.1",
57
57
  "@tsconfig/recommended": "^1.0.2",
58
58
  "@types/babel__core": "^7.20.1",
59
59
  "@types/jest": "^26.0.20",
@@ -65,24 +65,23 @@
65
65
  "@types/use-sync-external-store": "^0.0.4",
66
66
  "@wise/art": "^2.7.0",
67
67
  "@wojtekmaj/enzyme-adapter-react-17": "^0.6.3",
68
- "babel-plugin-formatjs": "^10.5.3",
68
+ "babel-plugin-formatjs": "^10.5.13",
69
69
  "babel-plugin-inline-react-svg": "^2.0.2",
70
70
  "enzyme": "^3.11.0",
71
71
  "jest": "^27.0.6",
72
72
  "jest-cli": "^27.0.6",
73
73
  "jest-fetch-mock": "^3.0.3",
74
74
  "lodash.times": "^4.3.2",
75
- "npm-watch": "^0.11.0",
76
75
  "react-intl": "^5.10.0",
77
76
  "rollup": "^3.28.1",
78
77
  "storybook": "^7.4.5",
79
78
  "@transferwise/less-config": "3.1.0",
80
- "@transferwise/neptune-css": "14.9.4",
79
+ "@transferwise/neptune-css": "14.9.5",
81
80
  "@wise/components-theming": "0.8.4"
82
81
  },
83
82
  "peerDependencies": {
84
83
  "@transferwise/icons": "^3.7.0",
85
- "@transferwise/neptune-css": "^14.9.4",
84
+ "@transferwise/neptune-css": "^14.9.5",
86
85
  "@wise/art": "^2.7.0",
87
86
  "@wise/components-theming": "^0.8.4",
88
87
  "react": ">=16.14",
@@ -118,21 +117,13 @@
118
117
  "react-transition-group": "^4.4.2",
119
118
  "use-sync-external-store": "^1.2.0"
120
119
  },
121
- "watch": {
122
- "build:crowdin-source-file": "src/**/*.messages.js"
123
- },
124
- "resolutions": {
125
- "**/remark-parse/trim": "0.0.3",
126
- "**/chokidar/glob-parent": "5.1.2",
127
- "**/fast-glob/glob-parent": "5.1.2"
128
- },
129
120
  "publishConfig": {
130
121
  "access": "public"
131
122
  },
132
123
  "scripts": {
133
124
  "dev": "npm-run-all --parallel dev:* dev:*:* storybook:dev",
134
125
  "dev:less:watch": "gulp watchLess --dest=src",
135
- "dev:translations": "npx npm-watch",
126
+ "dev:translations": "pnpm build:crowdin-source-file",
136
127
  "storybook:dev": "storybook dev -p 3001",
137
128
  "storybook:build": "storybook build --webpack-stats-json",
138
129
  "build:css": "gulp compileLess --dest=src",
package/src/index.ts CHANGED
@@ -33,6 +33,7 @@ export type {
33
33
  LinkTypes,
34
34
  DisplayTypes,
35
35
  } from './common';
36
+ export type { SegmentedControlProps } from './segmentedControl';
36
37
 
37
38
  /**
38
39
  * Components
@@ -107,6 +108,7 @@ export { default as RadioGroup } from './radioGroup';
107
108
  export { default as RadioOption } from './radioOption';
108
109
  export { default as Section } from './section';
109
110
  export { default as Select } from './select';
111
+ export { default as SegmentedControl } from './segmentedControl';
110
112
  export { default as SlidingPanel } from './slidingPanel';
111
113
  export { default as SnackbarPortal } from './snackbar/Snackbar';
112
114
  export { default as SnackbarProvider } from './snackbar/SnackbarProvider';
package/src/main.css CHANGED
@@ -4629,6 +4629,107 @@ html:not([dir="rtl"]) .np-navigation-option {
4629
4629
  .np-theme-personal .np-dropdown-menu .np-dropdown-item--focused {
4630
4630
  box-shadow: inset 0 0 0 2px var(--color-interactive-primary);
4631
4631
  }
4632
+ .segmented-control {
4633
+ box-sizing: border-box;
4634
+ --segment-highlight-width: 0;
4635
+ --segment-highlight-x: var(--size-4);
4636
+ }
4637
+ .segmented-control__segments {
4638
+ display: inline-flex;
4639
+ position: relative;
4640
+ padding: 4px;
4641
+ padding: var(--size-4);
4642
+ width: 100%;
4643
+ justify-content: center;
4644
+ align-items: center;
4645
+ background: rgba(134,167,189,0.10196);
4646
+ background: var(--color-background-neutral);
4647
+ border-radius: 24px;
4648
+ border-radius: var(--size-24);
4649
+ transition: outline 300ms;
4650
+ outline: 2px solid transparent;
4651
+ }
4652
+ .segmented-control--input:has(:focus-visible) > .segmented-control__segments::after {
4653
+ outline: 2px solid var(--color-interactive-primary);
4654
+ }
4655
+ .segmented-control__segments::after {
4656
+ content: "";
4657
+ position: absolute;
4658
+ width: var(--segment-highlight-width);
4659
+ top: 4px;
4660
+ top: var(--size-4);
4661
+ bottom: 4px;
4662
+ bottom: var(--size-4);
4663
+ left: var(--segment-highlight-x);
4664
+ z-index: 0;
4665
+ background: #ffffff;
4666
+ background: var(--color-background-screen);
4667
+ border-radius: 24px;
4668
+ border-radius: var(--size-24);
4669
+ transition: left 300ms;
4670
+ }
4671
+ .segmented-control__segments--no-animate::after {
4672
+ transition: none !important;
4673
+ }
4674
+ .segmented-control__segment {
4675
+ position: relative;
4676
+ flex: 1 1 100%;
4677
+ flex-flow: column;
4678
+ padding: 8px 16px;
4679
+ padding: var(--size-8) var(--size-16);
4680
+ margin: 0 0 0 4px;
4681
+ margin: 0 0 0 var(--size-4);
4682
+ min-width: 0;
4683
+ line-height: inherit;
4684
+ align-items: center;
4685
+ text-align: center;
4686
+ vertical-align: middle;
4687
+ border-radius: 24px;
4688
+ border-radius: var(--size-24);
4689
+ z-index: 1;
4690
+ cursor: pointer;
4691
+ transition: background 300ms;
4692
+ color: var(--color-interactive-primary);
4693
+ }
4694
+ .segmented-control__segment:first-child {
4695
+ margin-left: 0;
4696
+ }
4697
+ .segmented-control__segment:hover {
4698
+ background: rgba(0,0,0,0.10196);
4699
+ background: var(--color-background-overlay);
4700
+ }
4701
+ .segmented-control__radio-input {
4702
+ position: fixed;
4703
+ opacity: 0;
4704
+ pointer-events: none;
4705
+ }
4706
+ .segmented-control__button {
4707
+ width: 100%;
4708
+ height: 100%;
4709
+ background: none;
4710
+ -webkit-appearance: none;
4711
+ -moz-appearance: none;
4712
+ appearance: none;
4713
+ border: none;
4714
+ outline: none;
4715
+ font: inherit;
4716
+ outline: 2px solid transparent;
4717
+ }
4718
+ .segmented-control__button:focus {
4719
+ outline-offset: 0px;
4720
+ }
4721
+ .segmented-control__button:focus-visible {
4722
+ outline-color: var(--color-interactive-primary);
4723
+ }
4724
+ .segmented-control__selected-segment:hover {
4725
+ background: transparent;
4726
+ }
4727
+ .segmented-control__text {
4728
+ word-wrap: break-word;
4729
+ word-break: break-word;
4730
+ color: var(--color-interactive-primary);
4731
+ transition: font-weight 300ms;
4732
+ }
4632
4733
  .np-summary {
4633
4734
  min-width: 280px;
4634
4735
  }
package/src/main.less CHANGED
@@ -53,6 +53,7 @@
53
53
  @import "./statusIcon/StatusIcon.less";
54
54
  @import "./stepper/Stepper.less";
55
55
  @import "./select/Select.less";
56
+ @import "./segmentedControl/SegmentedControl.less";
56
57
  @import "./summary/Summary.less";
57
58
  @import "./switch/Switch.less";
58
59
  @import "./tabs/Tabs.less";