@transferwise/components 46.52.3 → 46.54.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 (156) hide show
  1. package/build/dateLookup/dateTrigger/DateTrigger.js +8 -4
  2. package/build/dateLookup/dateTrigger/DateTrigger.js.map +1 -1
  3. package/build/dateLookup/dateTrigger/DateTrigger.mjs +8 -4
  4. package/build/dateLookup/dateTrigger/DateTrigger.mjs.map +1 -1
  5. package/build/field/Field.js +36 -8
  6. package/build/field/Field.js.map +1 -1
  7. package/build/field/Field.mjs +37 -9
  8. package/build/field/Field.mjs.map +1 -1
  9. package/build/i18n/en.json +2 -0
  10. package/build/i18n/en.json.js +2 -0
  11. package/build/i18n/en.json.js.map +1 -1
  12. package/build/i18n/en.json.mjs +2 -0
  13. package/build/i18n/en.json.mjs.map +1 -1
  14. package/build/index.js +2 -2
  15. package/build/index.mjs +1 -1
  16. package/build/inlineAlert/InlineAlert.js +13 -6
  17. package/build/inlineAlert/InlineAlert.js.map +1 -1
  18. package/build/inlineAlert/InlineAlert.mjs +13 -6
  19. package/build/inlineAlert/InlineAlert.mjs.map +1 -1
  20. package/build/label/Label.js +35 -4
  21. package/build/label/Label.js.map +1 -1
  22. package/build/label/Label.messages.js +12 -0
  23. package/build/label/Label.messages.js.map +1 -0
  24. package/build/label/Label.messages.mjs +10 -0
  25. package/build/label/Label.messages.mjs.map +1 -0
  26. package/build/label/Label.mjs +36 -5
  27. package/build/label/Label.mjs.map +1 -1
  28. package/build/main.css +14 -8
  29. package/build/styles/dateLookup/dateTrigger/DateTrigger.css +0 -8
  30. package/build/styles/field/Field.css +4 -0
  31. package/build/styles/main.css +14 -8
  32. package/build/styles/upload/Upload.css +10 -0
  33. package/build/tabs/Tab.js +13 -38
  34. package/build/tabs/Tab.js.map +1 -1
  35. package/build/tabs/Tab.mjs +13 -34
  36. package/build/tabs/Tab.mjs.map +1 -1
  37. package/build/tabs/TabList.js +3 -11
  38. package/build/tabs/TabList.js.map +1 -1
  39. package/build/tabs/TabList.mjs +3 -7
  40. package/build/tabs/TabList.mjs.map +1 -1
  41. package/build/tabs/TabPanel.js +3 -16
  42. package/build/tabs/TabPanel.js.map +1 -1
  43. package/build/tabs/TabPanel.mjs +3 -12
  44. package/build/tabs/TabPanel.mjs.map +1 -1
  45. package/build/tabs/Tabs.js +24 -48
  46. package/build/tabs/Tabs.js.map +1 -1
  47. package/build/tabs/Tabs.mjs +24 -47
  48. package/build/tabs/Tabs.mjs.map +1 -1
  49. package/build/tabs/utils.js +0 -1
  50. package/build/tabs/utils.js.map +1 -1
  51. package/build/tabs/utils.mjs +0 -1
  52. package/build/tabs/utils.mjs.map +1 -1
  53. package/build/types/dateLookup/dateTrigger/DateTrigger.d.ts.map +1 -1
  54. package/build/types/field/Field.d.ts +4 -2
  55. package/build/types/field/Field.d.ts.map +1 -1
  56. package/build/types/index.d.ts +2 -1
  57. package/build/types/index.d.ts.map +1 -1
  58. package/build/types/inlineAlert/InlineAlert.d.ts +9 -0
  59. package/build/types/inlineAlert/InlineAlert.d.ts.map +1 -1
  60. package/build/types/label/Label.d.ts +21 -1
  61. package/build/types/label/Label.d.ts.map +1 -1
  62. package/build/types/label/Label.messages.d.ts +8 -0
  63. package/build/types/label/Label.messages.d.ts.map +1 -0
  64. package/build/types/label/index.d.ts +3 -0
  65. package/build/types/label/index.d.ts.map +1 -0
  66. package/build/types/tabs/Tab.d.ts +12 -1
  67. package/build/types/tabs/Tab.d.ts.map +1 -1
  68. package/build/types/tabs/TabList.d.ts +3 -8
  69. package/build/types/tabs/TabList.d.ts.map +1 -1
  70. package/build/types/tabs/TabPanel.d.ts +6 -14
  71. package/build/types/tabs/TabPanel.d.ts.map +1 -1
  72. package/build/types/tabs/Tabs.d.ts +83 -30
  73. package/build/types/tabs/Tabs.d.ts.map +1 -1
  74. package/build/types/tabs/index.d.ts +2 -1
  75. package/build/types/tabs/index.d.ts.map +1 -1
  76. package/build/types/tabs/utils.d.ts +12 -7
  77. package/build/types/tabs/utils.d.ts.map +1 -1
  78. package/build/types/upload/Upload.d.ts +1 -0
  79. package/build/types/upload/Upload.d.ts.map +1 -1
  80. package/build/types/upload/Upload.messages.d.ts +4 -0
  81. package/build/types/upload/Upload.messages.d.ts.map +1 -1
  82. package/build/types/upload/steps/completeStep/completeStep.d.ts +1 -3
  83. package/build/types/upload/steps/completeStep/completeStep.d.ts.map +1 -1
  84. package/build/types/upload/steps/uploadImageStep/uploadImageStep.d.ts +1 -0
  85. package/build/types/upload/steps/uploadImageStep/uploadImageStep.d.ts.map +1 -1
  86. package/build/upload/Upload.js +26 -12
  87. package/build/upload/Upload.js.map +1 -1
  88. package/build/upload/Upload.messages.js +3 -0
  89. package/build/upload/Upload.messages.js.map +1 -1
  90. package/build/upload/Upload.messages.mjs +3 -0
  91. package/build/upload/Upload.messages.mjs.map +1 -1
  92. package/build/upload/Upload.mjs +26 -12
  93. package/build/upload/Upload.mjs.map +1 -1
  94. package/build/upload/steps/completeStep/completeStep.js +15 -30
  95. package/build/upload/steps/completeStep/completeStep.js.map +1 -1
  96. package/build/upload/steps/completeStep/completeStep.mjs +16 -31
  97. package/build/upload/steps/completeStep/completeStep.mjs.map +1 -1
  98. package/build/upload/steps/uploadImageStep/uploadImageStep.js +56 -32
  99. package/build/upload/steps/uploadImageStep/uploadImageStep.js.map +1 -1
  100. package/build/upload/steps/uploadImageStep/uploadImageStep.mjs +56 -32
  101. package/build/upload/steps/uploadImageStep/uploadImageStep.mjs.map +1 -1
  102. package/package.json +2 -2
  103. package/src/dateInput/DateInput.tests.story.tsx +6 -42
  104. package/src/dateLookup/DateLookup.rtl.spec.tsx +1 -1
  105. package/src/dateLookup/dateTrigger/DateTrigger.css +0 -8
  106. package/src/dateLookup/dateTrigger/DateTrigger.less +0 -8
  107. package/src/dateLookup/dateTrigger/DateTrigger.spec.js +1 -1
  108. package/src/dateLookup/dateTrigger/DateTrigger.tsx +9 -4
  109. package/src/field/Field.css +4 -0
  110. package/src/field/Field.less +5 -0
  111. package/src/field/Field.spec.tsx +41 -5
  112. package/src/field/Field.story.tsx +105 -7
  113. package/src/field/Field.tsx +34 -10
  114. package/src/i18n/en.json +2 -0
  115. package/src/index.ts +2 -1
  116. package/src/inlineAlert/InlineAlert.story.tsx +7 -72
  117. package/src/inlineAlert/InlineAlert.tsx +14 -3
  118. package/src/inputWithDisplayFormat/InputWithDisplayFormat.story.js +5 -10
  119. package/src/inputs/InputGroup.spec.tsx +1 -1
  120. package/src/inputs/SearchInput.spec.tsx +1 -1
  121. package/src/inputs/SelectInput.spec.tsx +1 -1
  122. package/src/label/Label.messages.tsx +8 -0
  123. package/src/label/Label.spec.tsx +53 -4
  124. package/src/label/Label.story.tsx +32 -26
  125. package/src/label/Label.tsx +47 -2
  126. package/src/label/index.ts +2 -0
  127. package/src/main.css +14 -8
  128. package/src/main.less +1 -0
  129. package/src/moneyInput/MoneyInput.story.tsx +11 -11
  130. package/src/radioGroup/RadioGroup.rtl.spec.tsx +1 -1
  131. package/src/select/Select.rtl.spec.tsx +1 -1
  132. package/src/switch/Switch.spec.tsx +1 -1
  133. package/src/switch/Switch.story.tsx +19 -21
  134. package/src/tabs/Tab.tsx +72 -0
  135. package/src/tabs/TabList.tsx +11 -0
  136. package/src/tabs/TabPanel.tsx +14 -0
  137. package/src/tabs/{Tabs.story.js → Tabs.story.tsx} +1 -1
  138. package/src/tabs/{Tabs.js → Tabs.tsx} +111 -74
  139. package/src/tabs/index.ts +2 -0
  140. package/src/tabs/{utils.spec.js → utils.spec.ts} +24 -21
  141. package/src/tabs/{utils.js → utils.ts} +15 -9
  142. package/src/upload/Upload.css +10 -0
  143. package/src/upload/Upload.less +9 -0
  144. package/src/upload/Upload.messages.ts +4 -0
  145. package/src/upload/Upload.spec.js +8 -7
  146. package/src/upload/Upload.story.tsx +1 -0
  147. package/src/upload/Upload.tsx +39 -20
  148. package/src/upload/steps/completeStep/completeStep.spec.js +0 -9
  149. package/src/upload/steps/completeStep/completeStep.tsx +14 -29
  150. package/src/upload/steps/uploadImageStep/uploadImageStep.spec.js +12 -0
  151. package/src/upload/steps/uploadImageStep/uploadImageStep.tsx +43 -24
  152. package/src/field/Field.tests.story.tsx +0 -33
  153. package/src/tabs/Tab.js +0 -71
  154. package/src/tabs/TabList.js +0 -15
  155. package/src/tabs/TabPanel.js +0 -20
  156. package/src/tabs/index.js +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"uploadImageStep.mjs","sources":["../../../../src/upload/steps/uploadImageStep/uploadImageStep.tsx"],"sourcesContent":["import { Upload as UploadIcon } from '@transferwise/icons';\nimport { createRef, PureComponent } from 'react';\n\nexport interface UploadImageStepProps {\n fileDropped: (file: File) => void;\n isComplete: boolean;\n usAccept: string;\n usButtonText: string;\n usDisabled: boolean;\n usHelpImage: React.ReactNode;\n usLabel: string;\n usPlaceholder: string;\n}\n\nexport default class UploadImageStep extends PureComponent<UploadImageStepProps> {\n uploadInputRef = createRef<HTMLInputElement>();\n\n onManualUpload = () => {\n const { fileDropped } = this.props;\n const file = this.uploadInputRef.current?.files?.[0];\n if (file != null) {\n fileDropped(file);\n }\n };\n\n getImage = () => {\n const { usHelpImage, usLabel } = this.props;\n\n if (!usHelpImage) {\n return (\n <div className=\"circle circle-sm circle-inverse p-t-1\">\n <UploadIcon size={24} />\n </div>\n );\n }\n\n if (typeof usHelpImage === 'string') {\n return <img src={usHelpImage} alt={usLabel} className=\"thumbnail text-xs-center\" />;\n }\n\n return usHelpImage;\n };\n\n render() {\n const { isComplete, usAccept, usButtonText, usDisabled, usLabel, usPlaceholder } = this.props;\n\n return (\n <div>\n <div className=\"droppable-default-card\" aria-hidden={isComplete}>\n <div className=\"droppable-card-content\">\n <div className=\"m-b-3\">{this.getImage()}</div>\n {usLabel && <h4 className=\"np-text-title-body m-b-1\">{usLabel}</h4>}\n {usPlaceholder && <p className=\"np-text-body-large m-b-3\">{String(usPlaceholder)}</p>}\n <label className={`btn btn-primary btn-md ${usDisabled ? 'disabled' : ''}`}>\n {usButtonText ? (\n <span>{usButtonText}</span>\n ) : (\n <UploadIcon size={24} className=\"m-r-0\" />\n )}\n <input\n ref={this.uploadInputRef}\n type=\"file\"\n accept={usAccept === '*' ? undefined : usAccept}\n className=\"tw-droppable-input hidden\"\n disabled={usDisabled}\n name=\"file-upload\"\n onChange={() => this.onManualUpload()}\n />\n </label>\n </div>\n </div>\n </div>\n );\n }\n}\n"],"names":["UploadImageStep","PureComponent","uploadInputRef","createRef","onManualUpload","fileDropped","props","file","current","files","getImage","usHelpImage","usLabel","_jsx","className","children","UploadIcon","size","src","alt","render","isComplete","usAccept","usButtonText","usDisabled","usPlaceholder","_jsxs","String","ref","type","accept","undefined","disabled","name","onChange"],"mappings":"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"}
1
+ {"version":3,"file":"uploadImageStep.mjs","sources":["../../../../src/upload/steps/uploadImageStep/uploadImageStep.tsx"],"sourcesContent":["import { Upload as UploadIcon } from '@transferwise/icons';\nimport { createRef, PureComponent } from 'react';\nimport StatusIcon from '../../../statusIcon';\nimport { Sentiment, Size } from '../../../common';\nimport InlineAlert from '../../../inlineAlert';\n\nexport interface UploadImageStepProps {\n fileDropped: (file: File) => void;\n isComplete: boolean;\n usAccept: string;\n usButtonText: string;\n usDisabled: boolean;\n usHelpImage: React.ReactNode;\n usLabel: string;\n usPlaceholder: string;\n errorMessage?: string | string[];\n}\n\nexport default class UploadImageStep extends PureComponent<UploadImageStepProps> {\n uploadInputRef = createRef<HTMLInputElement>();\n\n onManualUpload = () => {\n const { fileDropped } = this.props;\n const file = this.uploadInputRef.current?.files?.[0];\n if (file != null) {\n fileDropped(file);\n }\n };\n\n getImage = () => {\n const { usHelpImage, usLabel } = this.props;\n const { errorMessage } = this.props;\n\n if (errorMessage) {\n return (\n <div className=\"d-flex flex-column align-items-center\">\n <StatusIcon size={Size.LARGE} sentiment={Sentiment.NEGATIVE} />\n </div>\n );\n }\n\n if (!usHelpImage) {\n return (\n <div className=\"circle circle-sm circle-inverse p-t-1\">\n <UploadIcon size={24} />\n </div>\n );\n }\n\n if (typeof usHelpImage === 'string') {\n return <img src={usHelpImage} alt={usLabel} className=\"thumbnail text-xs-center\" />;\n }\n\n return usHelpImage;\n };\n\n render() {\n const { isComplete, usAccept, usButtonText, usDisabled, usLabel, usPlaceholder, errorMessage } =\n this.props;\n\n return (\n <div className=\"droppable-default-card\" aria-hidden={isComplete}>\n <div className=\"droppable-card-content\">\n <div className=\"m-b-3\">{this.getImage()}</div>\n {usLabel && <h4 className=\"np-text-title-body m-b-1\">{usLabel}</h4>}\n {usPlaceholder && <p className=\"np-text-body-large m-b-3\">{String(usPlaceholder)}</p>}\n <label className={`btn btn-primary btn-md ${usDisabled ? 'disabled' : ''}`}>\n {usButtonText ? (\n <span>{usButtonText}</span>\n ) : (\n <UploadIcon size={24} className=\"m-r-0\" />\n )}\n <input\n ref={this.uploadInputRef}\n type=\"file\"\n accept={usAccept === '*' ? undefined : usAccept}\n className=\"tw-droppable-input hidden\"\n disabled={usDisabled}\n name=\"file-upload\"\n onChange={() => this.onManualUpload()}\n />\n </label>\n {errorMessage && (\n <div className=\"upload-error-message\">\n <div className=\"m-t-3 has-error\">\n <InlineAlert type={Sentiment.NEGATIVE}>{errorMessage}</InlineAlert>\n </div>\n </div>\n )}\n </div>\n </div>\n );\n }\n}\n"],"names":["UploadImageStep","PureComponent","uploadInputRef","createRef","onManualUpload","fileDropped","props","file","current","files","getImage","usHelpImage","usLabel","errorMessage","_jsx","className","children","StatusIcon","size","Size","LARGE","sentiment","Sentiment","NEGATIVE","UploadIcon","src","alt","render","isComplete","usAccept","usButtonText","usDisabled","usPlaceholder","_jsxs","String","ref","type","accept","undefined","disabled","name","onChange","InlineAlert"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@transferwise/components",
3
- "version": "46.52.3",
3
+ "version": "46.54.0",
4
4
  "description": "Neptune React components",
5
5
  "license": "Apache-2.0",
6
6
  "repository": {
@@ -92,8 +92,8 @@
92
92
  "rollup": "^4.18.1",
93
93
  "rollup-preserve-directives": "^1.1.1",
94
94
  "storybook": "^8.2.2",
95
- "@transferwise/neptune-css": "14.12.1",
96
95
  "@transferwise/less-config": "3.1.0",
96
+ "@transferwise/neptune-css": "14.13.1",
97
97
  "@wise/components-theming": "1.5.0"
98
98
  },
99
99
  "peerDependencies": {
@@ -1,7 +1,7 @@
1
1
  import { Meta, StoryObj } from '@storybook/react';
2
2
  import { userEvent, within, fn } from '@storybook/test';
3
3
 
4
- import { DateInput, DateMode, Info, InlineAlert, Title, Typography } from '..';
4
+ import { DateInput, Field } from '..';
5
5
  import { lorem10, storyConfig } from '../test-utils';
6
6
 
7
7
  import Provider from '../provider/Provider';
@@ -38,45 +38,10 @@ export const WithLabel = {
38
38
  onChange: fn(),
39
39
  },
40
40
  render: (args) => {
41
- const id1 = 'date-input-group-label-1';
42
- const label = 'Date of Birth';
43
-
44
41
  return (
45
- <>
46
- <Title type={Typography.TITLE_SUBSECTION}>
47
- label (as <code>div</code> element) is linked with <code>DateInput</code> via{' '}
48
- <code>aria-labelledby</code> prop
49
- </Title>
50
- <div className="control-label" id={id1}>
51
- Date of Delivery
52
- </div>
53
- <DateInput {...args} aria-labelledby={id1} />
54
-
55
- <br />
56
-
57
- <Title type={Typography.TITLE_SUBSECTION}>
58
- label (as <code>div</code> element) is detached but <code>DateInput</code> has same label
59
- via <code>aria-label</code> attribute
60
- </Title>
61
- <div className="control-label">
62
- {label}{' '}
63
- <Info aria-label="Fast transfer hint" title="Fast transfer hint" content={lorem10} />
64
- </div>
65
- <DateInput {...args} aria-label={label} />
66
-
67
- <br />
68
-
69
- <Title type={Typography.TITLE_SUBSECTION}>
70
- <code>DateInput</code> wrapped in <code>fieldset</code> + using <code>legend</code> as
71
- label (rare use case)
72
- </Title>
73
- <fieldset>
74
- <legend className="control-label">
75
- Expiry Date for Credit Card (example of MONTH_YEAR mode)
76
- </legend>
77
- <DateInput {...args} mode={DateMode.MONTH_YEAR} />
78
- </fieldset>
79
- </>
42
+ <Field label="Date of Delivery">
43
+ <DateInput {...args} />
44
+ </Field>
80
45
  );
81
46
  },
82
47
  } satisfies Story;
@@ -84,10 +49,9 @@ export const WithLabel = {
84
49
  export const InputError = {
85
50
  ...Basic,
86
51
  render: (args) => (
87
- <div className="form-group has-error">
52
+ <Field sentiment="negative" message={lorem10}>
88
53
  <DateInput {...args} value={new Date('2010-04-05')} />
89
- <InlineAlert type="error">{lorem10}</InlineAlert>
90
- </div>
54
+ </Field>
91
55
  ),
92
56
  } satisfies Story;
93
57
 
@@ -28,7 +28,7 @@ describe('DateLookup', () => {
28
28
  </Field>,
29
29
  );
30
30
  // TODO: Replace with `.toHaveAttribute('aria-haspopup')`
31
- expect(screen.getByLabelText('Date of birth')).toHaveTextContent(
31
+ expect(screen.getByLabelText(/Date of birth/)).toHaveTextContent(
32
32
  initialValue.getFullYear().toString(),
33
33
  );
34
34
  });
@@ -4,18 +4,10 @@
4
4
  white-space: nowrap;
5
5
  width: 100%;
6
6
  }
7
- .np-date-trigger .control-label {
8
- font-weight: 400;
9
- font-weight: var(--font-weight-regular);
10
- }
11
7
  .np-theme-personal .np-date-trigger {
12
8
  padding-left: 16px;
13
9
  padding-left: var(--size-16);
14
10
  }
15
- .np-theme-personal .np-date-trigger .control-label + span {
16
- font-weight: 400;
17
- font-weight: var(--font-weight-regular);
18
- }
19
11
  .clear-btn {
20
12
  transition: color 0.15s ease-in-out;
21
13
  color: #c9cbce;
@@ -7,16 +7,8 @@
7
7
  white-space: nowrap;
8
8
  width: 100%;
9
9
 
10
- .control-label {
11
- font-weight: var(--font-weight-regular);
12
- }
13
-
14
10
  .np-theme-personal & {
15
11
  padding-left: var(--size-16);
16
-
17
- .control-label + span {
18
- font-weight: var(--font-weight-regular);
19
- }
20
12
  }
21
13
  }
22
14
 
@@ -119,5 +119,5 @@ describe('DateTrigger', () => {
119
119
  const button = () => component.find('.np-date-trigger');
120
120
  const clearButton = () => component.find('.clear-btn');
121
121
  const chevron = () => component.find(Chevron);
122
- const label = () => component.find('.control-label');
122
+ const label = () => component.find('.np-date-trigger-label');
123
123
  });
@@ -2,12 +2,13 @@ import { formatDate } from '@transferwise/formatting';
2
2
  import { useIntl } from 'react-intl';
3
3
 
4
4
  import Chevron from '../../chevron';
5
- import { Size, Position, SizeSmall, SizeMedium, SizeLarge } from '../../common';
5
+ import { Size, Position, SizeSmall, SizeMedium, SizeLarge, Typography } from '../../common';
6
6
  import { CloseButton } from '../../common/closeButton/CloseButton';
7
7
 
8
8
  import messages from './DateTrigger.messages';
9
9
  import { useContext } from 'react';
10
10
  import { OverlayIdContext } from '../../provider/overlay/OverlayIdProvider';
11
+ import Body from '../../body';
11
12
 
12
13
  interface DateTriggerProps {
13
14
  selectedDate: Date | null;
@@ -45,15 +46,19 @@ const DateTrigger: React.FC<DateTriggerProps> = ({
45
46
  type="button"
46
47
  onClick={onClick}
47
48
  >
48
- {label && <span className="control-label small m-r-1">{label}</span>}
49
+ {label && (
50
+ <Body as="span" className="np-date-trigger-label m-r-1">
51
+ {label}
52
+ </Body>
53
+ )}
49
54
  {selectedDate ? (
50
- <span className="font-weight-normal">
55
+ <Body as="span" type={Typography.BODY_LARGE}>
51
56
  {formatDate(selectedDate, locale, {
52
57
  day: 'numeric',
53
58
  month: monthFormat,
54
59
  year: 'numeric',
55
60
  })}
56
- </span>
61
+ </Body>
57
62
  ) : (
58
63
  <span
59
64
  className="form-control-placeholder visible-xs-inline visible-sm-inline
@@ -0,0 +1,4 @@
1
+ .np-field-control {
2
+ margin-top: 4px;
3
+ margin-top: var(--size-4);
4
+ }
@@ -0,0 +1,5 @@
1
+ .np-field {
2
+ &-control {
3
+ margin-top: var(--size-4);
4
+ }
5
+ }
@@ -14,7 +14,7 @@ describe('Field', () => {
14
14
  </Field>,
15
15
  );
16
16
 
17
- expect(screen.getByLabelText('Phone number')).toBeInTheDocument();
17
+ expect(screen.getByLabelText(/Phone number/)).toBeInTheDocument();
18
18
  expect(screen.getByRole('textbox')).not.toHaveAttribute('aria-describedby');
19
19
  });
20
20
 
@@ -25,7 +25,7 @@ describe('Field', () => {
25
25
  </Field>,
26
26
  );
27
27
 
28
- const textbox = screen.getByRole('textbox', { description: 'This is help text' });
28
+ const textbox = screen.getByRole('textbox', { description: /This is help text/ });
29
29
  expect(textbox).toBeInTheDocument();
30
30
  expect(textbox).not.toBeInvalid();
31
31
  });
@@ -42,15 +42,51 @@ describe('Field', () => {
42
42
  expect(textbox).toBeInvalid();
43
43
  });
44
44
 
45
- it('should prefer error text over help text if both are provided', () => {
45
+ it('should shows error text and help text when both are provided', () => {
46
46
  render(
47
47
  <Field label="Phone number" error="This is error text" hint="This is help text">
48
48
  <Input />
49
49
  </Field>,
50
50
  );
51
51
 
52
- expect(screen.getByRole('textbox', { description: 'This is error text' })).toBeInTheDocument();
53
- expect(screen.queryByText('This is help text')).not.toBeInTheDocument();
52
+ expect(screen.getByRole('textbox', { description: /This is error text/ })).toBeInTheDocument();
53
+ expect(screen.getByText('This is help text')).toBeInTheDocument();
54
+ expect(screen.getByLabelText(/Phone number/)).toHaveAttribute('aria-describedby');
55
+ });
56
+
57
+ it('should shows message and description when both are provided', () => {
58
+ render(
59
+ <Field
60
+ label="Phone number"
61
+ description="This is help text"
62
+ sentiment="negative"
63
+ message="This is error text"
64
+ >
65
+ <Input />
66
+ </Field>,
67
+ );
68
+
69
+ expect(screen.getByRole('textbox', { description: /This is error text/ })).toBeInTheDocument();
70
+ expect(screen.getByText('This is help text')).toBeInTheDocument();
71
+ expect(screen.getByLabelText(/Phone number/)).toHaveAttribute('aria-describedby');
72
+ });
73
+
74
+ it('should show or hide (Optional) suffix depending on required prop', () => {
75
+ render(
76
+ <Field label="Phone number" description="This is help text">
77
+ <Input />
78
+ </Field>,
79
+ );
80
+
81
+ expect(screen.getByText('(Optional)')).toBeInTheDocument();
82
+
83
+ render(
84
+ <Field label="Phone number" description="This is help text" required>
85
+ <Input />
86
+ </Field>,
87
+ );
88
+
89
+ expect(screen.getByLabelText('Phone number')).toBeInTheDocument();
54
90
  });
55
91
 
56
92
  it('avoids triggering button within label inadvertently', async () => {
@@ -3,6 +3,12 @@ import { useState } from 'react';
3
3
  import { Input } from '../inputs/Input';
4
4
  import { Field } from './Field';
5
5
  import { Sentiment } from '../common';
6
+ import DateInput from '../dateInput';
7
+ import { fn } from '@storybook/test';
8
+ import { lorem10, lorem40 } from '../test-utils';
9
+ import { TextArea } from '../inputs/TextArea';
10
+ import { SearchInput } from '../inputs/SearchInput';
11
+ import Info from '../info';
6
12
 
7
13
  export default {
8
14
  component: Field,
@@ -13,9 +19,66 @@ export default {
13
19
  export const Basic = () => {
14
20
  const [value, setValue] = useState<string | undefined>('This is some text');
15
21
  return (
16
- <Field label="Phone number">
17
- <Input value={value} onChange={({ target }) => setValue(target.value)} />
18
- </Field>
22
+ <div className="row">
23
+ <div className="col-md-8 col-md-offset-2">
24
+ <Field label="Required Text Input" required>
25
+ <Input value={value} onChange={({ target }) => setValue(target.value)} />
26
+ </Field>
27
+ <Field label="Text Input">
28
+ <Input value={value} onChange={({ target }) => setValue(target.value)} />
29
+ </Field>
30
+ <Field label="Text Input with Description" description="This a field Description">
31
+ <Input value={value} onChange={({ target }) => setValue(target.value)} />
32
+ </Field>
33
+ <Field
34
+ label="Text Input with Validation Error"
35
+ description="This a field Description"
36
+ sentiment={Sentiment.NEGATIVE}
37
+ message="Validation error, please take a look"
38
+ >
39
+ <Input value={value} onChange={({ target }) => setValue(target.value)} />
40
+ </Field>
41
+
42
+ <Field label="Date Of Birth">
43
+ <DateInput onChange={fn} />
44
+ </Field>
45
+
46
+ <Field label="Date Of Birth with Description" description={lorem10}>
47
+ <DateInput onChange={fn} />
48
+ </Field>
49
+
50
+ <Field label="Search business">
51
+ <SearchInput />
52
+ </Field>
53
+
54
+ <Field label="Textarea">
55
+ <TextArea />
56
+ </Field>
57
+
58
+ <Field label="Textarea with Description" description="This a TextArea Description">
59
+ <TextArea />
60
+ </Field>
61
+
62
+ <Field
63
+ label="Textarea with Validation Error"
64
+ description="This a TextArea Description"
65
+ message={lorem10}
66
+ sentiment="negative"
67
+ >
68
+ <TextArea />
69
+ </Field>
70
+
71
+ <Field
72
+ label={
73
+ <>
74
+ Label with Suffix <Info content={lorem40} />
75
+ </>
76
+ }
77
+ >
78
+ <TextArea />
79
+ </Field>
80
+ </div>
81
+ </div>
19
82
  );
20
83
  };
21
84
 
@@ -23,16 +86,51 @@ export const WithStatusMessages = () => {
23
86
  const [value, setValue] = useState<string | undefined>('This is some text');
24
87
  return (
25
88
  <div>
26
- <Field label="Phone number" sentiment={Sentiment.POSITIVE} message="Positive message">
89
+ <Field
90
+ label="Text Input with Positive Message"
91
+ sentiment={Sentiment.POSITIVE}
92
+ message="Positive message"
93
+ >
27
94
  <Input value={value} onChange={({ target }) => setValue(target.value)} />
28
95
  </Field>
29
- <Field label="Phone number" sentiment={Sentiment.WARNING} message="Warning message">
96
+
97
+ <Field
98
+ label="Text Input with Warning Message"
99
+ sentiment={Sentiment.WARNING}
100
+ message="Warning message"
101
+ >
30
102
  <Input value={value} onChange={({ target }) => setValue(target.value)} />
31
103
  </Field>
32
- <Field label="Phone number" sentiment={Sentiment.NEGATIVE} message="This is a required field">
104
+
105
+ <Field
106
+ label="Text Input with Validation Error"
107
+ sentiment={Sentiment.NEGATIVE}
108
+ message="This is a required field"
109
+ >
110
+ <Input value={value} onChange={({ target }) => setValue(target.value)} />
111
+ </Field>
112
+
113
+ {/* instance with deprecated `hint` prop */}
114
+ <Field
115
+ label="Text Input with deprecated `hint` prop"
116
+ hint="This is a helpful message"
117
+ sentiment={Sentiment.NEGATIVE}
118
+ message="Validation error, please take a look"
119
+ >
33
120
  <Input value={value} onChange={({ target }) => setValue(target.value)} />
34
121
  </Field>
35
- <Field label="Phone number" message="This is a helpful message">
122
+
123
+ {/* instance with deprecated `error` & `hint` props */}
124
+ <Field
125
+ label="Text Input with deprecated `error` & `hint` props"
126
+ hint="This is a helpful message"
127
+ error="Validation error, please take a look"
128
+ >
129
+ <Input value={value} onChange={({ target }) => setValue(target.value)} />
130
+ </Field>
131
+
132
+ {/* instance of info via `message` property, this is rare case (e.g MoneyInput) */}
133
+ <Field label="Text Input with Info under the field" message="This is a helpful message">
36
134
  <Input value={value} onChange={({ target }) => setValue(target.value)} />
37
135
  </Field>
38
136
  </div>
@@ -9,16 +9,18 @@ import {
9
9
  InputIdContextProvider,
10
10
  InputInvalidProvider,
11
11
  } from '../inputs/contexts';
12
- import { Label } from '../label/Label';
12
+ import { Label } from '../label';
13
13
 
14
14
  export type FieldProps = {
15
15
  /** `null` disables auto-generating the `id` attribute, falling back to nesting-based label association over setting `htmlFor` explicitly. */
16
16
  id?: string | null;
17
17
  /** Should be specified unless the wrapped control has its own labeling mechanism, e.g. `Checkbox`. */
18
18
  label?: React.ReactNode;
19
- /** @deprecated use `message` and `type={Sentiment.NEUTRAL}` prop instead */
19
+ required?: boolean;
20
+ /** @deprecated use `description` prop instead */
20
21
  hint?: React.ReactNode;
21
22
  message?: React.ReactNode;
23
+ description?: React.ReactNode;
22
24
  /** @deprecated use `message` and `type={Sentiment.NEGATIVE}` prop instead */
23
25
  error?: React.ReactNode;
24
26
  sentiment?: `${Sentiment.NEGATIVE | Sentiment.NEUTRAL | Sentiment.POSITIVE | Sentiment.WARNING}`;
@@ -29,14 +31,17 @@ export type FieldProps = {
29
31
  export const Field = ({
30
32
  id,
31
33
  label,
34
+ required = false,
32
35
  message: propMessage,
36
+ hint,
37
+ description = hint,
33
38
  sentiment: propType = Sentiment.NEUTRAL,
34
39
  className,
35
40
  children,
36
41
  ...props
37
42
  }: FieldProps) => {
38
43
  const sentiment = props.error ? Sentiment.NEGATIVE : propType;
39
- const message = props.error || props.hint || propMessage;
44
+ const message = propMessage || props.error;
40
45
  const hasError = sentiment === Sentiment.NEGATIVE;
41
46
 
42
47
  const labelId = useId();
@@ -44,16 +49,32 @@ export const Field = ({
44
49
  const fallbackInputId = useId();
45
50
  const inputId = id !== null ? (id ?? fallbackInputId) : undefined;
46
51
 
52
+ const messageId = useId();
47
53
  const descriptionId = useId();
48
54
 
55
+ /**
56
+ * form control can have multiple messages to describe it,
57
+ * e.g the description underneath the label and inline alert
58
+ */
59
+ function ariaDescribedbyByIds() {
60
+ const messageIds = [];
61
+ if (description) {
62
+ messageIds.push(descriptionId);
63
+ }
64
+ if (message) {
65
+ messageIds.push(messageId);
66
+ }
67
+ return messageIds.length > 0 ? messageIds.join(' ') : undefined;
68
+ }
69
+
49
70
  return (
50
71
  <FieldLabelIdContextProvider value={labelId}>
51
72
  <InputIdContextProvider value={inputId}>
52
- <InputDescribedByProvider value={message ? descriptionId : undefined}>
73
+ <InputDescribedByProvider value={ariaDescribedbyByIds()}>
53
74
  <InputInvalidProvider value={hasError}>
54
75
  <div
55
76
  className={clsx(
56
- 'form-group d-block',
77
+ 'np-field form-group d-block',
57
78
  {
58
79
  'has-success': sentiment === Sentiment.POSITIVE,
59
80
  'has-warning': sentiment === Sentiment.WARNING,
@@ -64,16 +85,19 @@ export const Field = ({
64
85
  )}
65
86
  >
66
87
  {label != null ? (
67
- <Label id={labelId} htmlFor={inputId}>
68
- {label}
69
- {children}
70
- </Label>
88
+ <>
89
+ <Label id={labelId} htmlFor={inputId}>
90
+ {required ? label : <Label.Optional>{label}</Label.Optional>}
91
+ </Label>
92
+ <Label.Description id={descriptionId}>{description}</Label.Description>
93
+ <div className="np-field-control">{children}</div>
94
+ </>
71
95
  ) : (
72
96
  children
73
97
  )}
74
98
 
75
99
  {message && (
76
- <InlineAlert type={sentiment} id={descriptionId}>
100
+ <InlineAlert type={sentiment} id={messageId}>
77
101
  {message}
78
102
  </InlineAlert>
79
103
  )}
package/src/i18n/en.json CHANGED
@@ -18,6 +18,7 @@
18
18
  "neptune.DateLookup.year": "year",
19
19
  "neptune.FlowNavigation.back": "back to previous step",
20
20
  "neptune.Info.ariaLabel": "More information",
21
+ "neptune.Label.optional": "(Optional)",
21
22
  "neptune.Link.opensInNewTab": "(opens in new tab)",
22
23
  "neptune.MoneyInput.Select.placeholder": "Select an option...",
23
24
  "neptune.PhoneNumberInput.SelectInput.placeholder": "Select an option...",
@@ -35,6 +36,7 @@
35
36
  "neptune.Upload.csWrongTypeMessage": "File type not supported. Please try again with a different file",
36
37
  "neptune.Upload.psButtonText": "Cancel",
37
38
  "neptune.Upload.psProcessingText": "Uploading...",
39
+ "neptune.Upload.retry": "Retry",
38
40
  "neptune.Upload.usButtonText": "Or select a file",
39
41
  "neptune.Upload.usDropMessage": "Drop file to start upload",
40
42
  "neptune.Upload.usPlaceholder": "Drag and drop a file less than {maxSize}MB",
package/src/index.ts CHANGED
@@ -44,7 +44,7 @@ export type {
44
44
  } from './inputs/SelectInput';
45
45
  export type { TextAreaProps } from './inputs/TextArea';
46
46
  export type { InstructionsListProps } from './instructionsList';
47
- export type { LabelProps } from './label/Label';
47
+ export type { LabelProps, LabelOptionalProps, LabelDescriptionProps } from './label/Label';
48
48
  export type { LoaderProps } from './loader';
49
49
  export type { MarkdownProps } from './markdown';
50
50
  export type { ModalProps } from './modal';
@@ -75,6 +75,7 @@ export type { StickyProps } from './sticky';
75
75
  export type { SummaryProps } from './summary';
76
76
  export type { SwitchProps } from './switch';
77
77
  export type { SwitchOptionProps } from './switchOption';
78
+ export type { TabItem, TabsProps } from './tabs';
78
79
  export type { TextareaWithDisplayFormatProps } from './textareaWithDisplayFormat';
79
80
  export type { TooltipProps } from './tooltip';
80
81
  export type { TypeaheadOption, TypeaheadProps } from './typeahead';