@transferwise/components 0.0.0-experimental-6a6c19f → 0.0.0-experimental-e72bc9f

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 (166) hide show
  1. package/build/i18n/cs.json +1 -0
  2. package/build/i18n/cs.json.js +1 -0
  3. package/build/i18n/cs.json.js.map +1 -1
  4. package/build/i18n/cs.json.mjs +1 -0
  5. package/build/i18n/cs.json.mjs.map +1 -1
  6. package/build/i18n/de.json +1 -0
  7. package/build/i18n/de.json.js +1 -0
  8. package/build/i18n/de.json.js.map +1 -1
  9. package/build/i18n/de.json.mjs +1 -0
  10. package/build/i18n/de.json.mjs.map +1 -1
  11. package/build/i18n/es.json +1 -0
  12. package/build/i18n/es.json.js +1 -0
  13. package/build/i18n/es.json.js.map +1 -1
  14. package/build/i18n/es.json.mjs +1 -0
  15. package/build/i18n/es.json.mjs.map +1 -1
  16. package/build/i18n/fr.json +1 -0
  17. package/build/i18n/fr.json.js +1 -0
  18. package/build/i18n/fr.json.js.map +1 -1
  19. package/build/i18n/fr.json.mjs +1 -0
  20. package/build/i18n/fr.json.mjs.map +1 -1
  21. package/build/i18n/hu.json +1 -0
  22. package/build/i18n/hu.json.js +1 -0
  23. package/build/i18n/hu.json.js.map +1 -1
  24. package/build/i18n/hu.json.mjs +1 -0
  25. package/build/i18n/hu.json.mjs.map +1 -1
  26. package/build/i18n/id.json +1 -0
  27. package/build/i18n/id.json.js +1 -0
  28. package/build/i18n/id.json.js.map +1 -1
  29. package/build/i18n/id.json.mjs +1 -0
  30. package/build/i18n/id.json.mjs.map +1 -1
  31. package/build/i18n/it.json +1 -0
  32. package/build/i18n/it.json.js +1 -0
  33. package/build/i18n/it.json.js.map +1 -1
  34. package/build/i18n/it.json.mjs +1 -0
  35. package/build/i18n/it.json.mjs.map +1 -1
  36. package/build/i18n/ja.json +1 -0
  37. package/build/i18n/ja.json.js +1 -0
  38. package/build/i18n/ja.json.js.map +1 -1
  39. package/build/i18n/ja.json.mjs +1 -0
  40. package/build/i18n/ja.json.mjs.map +1 -1
  41. package/build/i18n/nl.json +4 -3
  42. package/build/i18n/pl.json +1 -0
  43. package/build/i18n/pl.json.js +1 -0
  44. package/build/i18n/pl.json.js.map +1 -1
  45. package/build/i18n/pl.json.mjs +1 -0
  46. package/build/i18n/pl.json.mjs.map +1 -1
  47. package/build/i18n/pt.json +1 -0
  48. package/build/i18n/pt.json.js +1 -0
  49. package/build/i18n/pt.json.js.map +1 -1
  50. package/build/i18n/pt.json.mjs +1 -0
  51. package/build/i18n/pt.json.mjs.map +1 -1
  52. package/build/i18n/ro.json +1 -0
  53. package/build/i18n/ro.json.js +1 -0
  54. package/build/i18n/ro.json.js.map +1 -1
  55. package/build/i18n/ro.json.mjs +1 -0
  56. package/build/i18n/ro.json.mjs.map +1 -1
  57. package/build/i18n/ru.json +1 -0
  58. package/build/i18n/ru.json.js +1 -0
  59. package/build/i18n/ru.json.js.map +1 -1
  60. package/build/i18n/ru.json.mjs +1 -0
  61. package/build/i18n/ru.json.mjs.map +1 -1
  62. package/build/i18n/th.json +1 -0
  63. package/build/i18n/th.json.js +1 -0
  64. package/build/i18n/th.json.js.map +1 -1
  65. package/build/i18n/th.json.mjs +1 -0
  66. package/build/i18n/th.json.mjs.map +1 -1
  67. package/build/i18n/tr.json +1 -0
  68. package/build/i18n/tr.json.js +1 -0
  69. package/build/i18n/tr.json.js.map +1 -1
  70. package/build/i18n/tr.json.mjs +1 -0
  71. package/build/i18n/tr.json.mjs.map +1 -1
  72. package/build/i18n/zh-CN.json +1 -0
  73. package/build/i18n/zh-CN.json.js +1 -0
  74. package/build/i18n/zh-CN.json.js.map +1 -1
  75. package/build/i18n/zh-CN.json.mjs +1 -0
  76. package/build/i18n/zh-CN.json.mjs.map +1 -1
  77. package/build/i18n/zh-HK.json +1 -0
  78. package/build/i18n/zh-HK.json.js +1 -0
  79. package/build/i18n/zh-HK.json.js.map +1 -1
  80. package/build/i18n/zh-HK.json.mjs +1 -0
  81. package/build/i18n/zh-HK.json.mjs.map +1 -1
  82. package/build/image/Image.js +10 -9
  83. package/build/image/Image.js.map +1 -1
  84. package/build/image/Image.mjs +11 -11
  85. package/build/image/Image.mjs.map +1 -1
  86. package/build/index.js +1 -0
  87. package/build/index.js.map +1 -1
  88. package/build/index.mjs +1 -1
  89. package/build/main.css +188 -0
  90. package/build/styles/listItem/ListItem.css +188 -0
  91. package/build/styles/main.css +188 -0
  92. package/build/test-utils/assets/apple-pay-logo.svg +84 -0
  93. package/build/types/image/Image.d.ts +1 -0
  94. package/build/types/image/Image.d.ts.map +1 -1
  95. package/build/types/index.d.ts +2 -0
  96. package/build/types/index.d.ts.map +1 -1
  97. package/build/types/listItem/ListItem.d.ts +43 -0
  98. package/build/types/listItem/ListItem.d.ts.map +1 -0
  99. package/build/types/listItem/ListItemAdditionalInfo.d.ts +9 -0
  100. package/build/types/listItem/ListItemAdditionalInfo.d.ts.map +1 -0
  101. package/build/types/listItem/ListItemButton.d.ts +4 -0
  102. package/build/types/listItem/ListItemButton.d.ts.map +1 -0
  103. package/build/types/listItem/ListItemCheckbox.d.ts +4 -0
  104. package/build/types/listItem/ListItemCheckbox.d.ts.map +1 -0
  105. package/build/types/listItem/ListItemIconButton.d.ts +7 -0
  106. package/build/types/listItem/ListItemIconButton.d.ts.map +1 -0
  107. package/build/types/listItem/ListItemMedia.d.ts +19 -0
  108. package/build/types/listItem/ListItemMedia.d.ts.map +1 -0
  109. package/build/types/listItem/ListItemNavigation.d.ts +4 -0
  110. package/build/types/listItem/ListItemNavigation.d.ts.map +1 -0
  111. package/build/types/listItem/ListItemSwitch.d.ts +3 -0
  112. package/build/types/listItem/ListItemSwitch.d.ts.map +1 -0
  113. package/build/types/listItem/index.d.ts +6 -0
  114. package/build/types/listItem/index.d.ts.map +1 -0
  115. package/build/types/listItem/prompt/Prompt.d.ts +12 -0
  116. package/build/types/listItem/prompt/Prompt.d.ts.map +1 -0
  117. package/build/types/listItem/useItemControl.d.ts +5 -0
  118. package/build/types/listItem/useItemControl.d.ts.map +1 -0
  119. package/build/types/test-utils/fake-data.d.ts +2 -0
  120. package/build/types/test-utils/fake-data.d.ts.map +1 -1
  121. package/package.json +3 -3
  122. package/src/i18n/cs.json +1 -0
  123. package/src/i18n/de.json +1 -0
  124. package/src/i18n/es.json +1 -0
  125. package/src/i18n/fr.json +1 -0
  126. package/src/i18n/hu.json +1 -0
  127. package/src/i18n/id.json +1 -0
  128. package/src/i18n/it.json +1 -0
  129. package/src/i18n/ja.json +1 -0
  130. package/src/i18n/nl.json +4 -3
  131. package/src/i18n/pl.json +1 -0
  132. package/src/i18n/pt.json +1 -0
  133. package/src/i18n/ro.json +1 -0
  134. package/src/i18n/ru.json +1 -0
  135. package/src/i18n/th.json +1 -0
  136. package/src/i18n/tr.json +1 -0
  137. package/src/i18n/zh-CN.json +1 -0
  138. package/src/i18n/zh-HK.json +1 -0
  139. package/src/image/Image.spec.tsx +3 -3
  140. package/src/image/Image.tsx +12 -10
  141. package/src/index.ts +2 -0
  142. package/src/legacylistItem/LegacyListItem.story.tsx +5 -5
  143. package/src/legacylistItem/LegacyListItem.tests.story.tsx +6 -6
  144. package/src/listItem/ListItem.css +188 -0
  145. package/src/listItem/ListItem.less +182 -0
  146. package/src/listItem/ListItem.story.tsx +273 -0
  147. package/src/listItem/ListItem.tsx +183 -0
  148. package/src/listItem/ListItemAdditionalInfo.tsx +31 -0
  149. package/src/listItem/ListItemButton.spec.tsx +90 -0
  150. package/src/listItem/ListItemButton.tsx +18 -0
  151. package/src/listItem/ListItemCheckbox.tsx +14 -0
  152. package/src/listItem/ListItemIconButton.tsx +13 -0
  153. package/src/listItem/ListItemMedia.tsx +52 -0
  154. package/src/listItem/ListItemNavigation.tsx +11 -0
  155. package/src/listItem/ListItemSwitch.tsx +8 -0
  156. package/src/listItem/index.ts +10 -0
  157. package/src/listItem/prompt/Prompt.spec.tsx +77 -0
  158. package/src/listItem/prompt/Prompt.story.tsx +170 -0
  159. package/src/listItem/prompt/Prompt.tsx +44 -0
  160. package/src/listItem/useItemControl.tsx +12 -0
  161. package/src/main.css +188 -0
  162. package/src/main.less +1 -0
  163. package/src/promoCard/__snapshots__/PromoCard.spec.tsx.snap +0 -1
  164. package/src/promoCard/__snapshots__/PromoCardGroup.spec.tsx.snap +0 -2
  165. package/src/test-utils/assets/apple-pay-logo.svg +84 -0
  166. package/src/test-utils/fake-data.ts +5 -0
@@ -25,6 +25,7 @@ var zhCN = {
25
25
  "neptune.Label.optional": "(可选)",
26
26
  "neptune.Link.opensInNewTab": "(在新标签页中打开)",
27
27
  "neptune.MoneyInput.Select.placeholder": "请选择...",
28
+ "neptune.MoneyInput.Select.searchPlaceholder": "输入货币或国家/地区",
28
29
  "neptune.MoneyInput.Select.selectCurrencyLabel": "选择货币",
29
30
  "neptune.PhoneNumberInput.SelectInput.placeholder": "选择其中一项...",
30
31
  "neptune.PhoneNumberInput.countryCodeLabel": "国家/地区代码",
@@ -1 +1 @@
1
- {"version":3,"file":"zh-CN.json.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"zh-CN.json.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -21,6 +21,7 @@ var zhCN = {
21
21
  "neptune.Label.optional": "(可选)",
22
22
  "neptune.Link.opensInNewTab": "(在新标签页中打开)",
23
23
  "neptune.MoneyInput.Select.placeholder": "请选择...",
24
+ "neptune.MoneyInput.Select.searchPlaceholder": "输入货币或国家/地区",
24
25
  "neptune.MoneyInput.Select.selectCurrencyLabel": "选择货币",
25
26
  "neptune.PhoneNumberInput.SelectInput.placeholder": "选择其中一项...",
26
27
  "neptune.PhoneNumberInput.countryCodeLabel": "国家/地区代码",
@@ -1 +1 @@
1
- {"version":3,"file":"zh-CN.json.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"zh-CN.json.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -21,6 +21,7 @@
21
21
  "neptune.Label.optional": "(可選)",
22
22
  "neptune.Link.opensInNewTab": "(在新分頁中開啟)",
23
23
  "neptune.MoneyInput.Select.placeholder": "選擇一個選項…",
24
+ "neptune.MoneyInput.Select.searchPlaceholder": "輸入貨幣或國家/地區",
24
25
  "neptune.MoneyInput.Select.selectCurrencyLabel": "選擇貨幣",
25
26
  "neptune.PhoneNumberInput.SelectInput.placeholder": "選擇其中一項…",
26
27
  "neptune.PhoneNumberInput.countryCodeLabel": "國家/地區代碼",
@@ -25,6 +25,7 @@ var zhHK = {
25
25
  "neptune.Label.optional": "(可選)",
26
26
  "neptune.Link.opensInNewTab": "(在新分頁中開啟)",
27
27
  "neptune.MoneyInput.Select.placeholder": "選擇一個選項…",
28
+ "neptune.MoneyInput.Select.searchPlaceholder": "輸入貨幣或國家/地區",
28
29
  "neptune.MoneyInput.Select.selectCurrencyLabel": "選擇貨幣",
29
30
  "neptune.PhoneNumberInput.SelectInput.placeholder": "選擇其中一項…",
30
31
  "neptune.PhoneNumberInput.countryCodeLabel": "國家/地區代碼",
@@ -1 +1 @@
1
- {"version":3,"file":"zh-HK.json.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"zh-HK.json.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -21,6 +21,7 @@ var zhHK = {
21
21
  "neptune.Label.optional": "(可選)",
22
22
  "neptune.Link.opensInNewTab": "(在新分頁中開啟)",
23
23
  "neptune.MoneyInput.Select.placeholder": "選擇一個選項…",
24
+ "neptune.MoneyInput.Select.searchPlaceholder": "輸入貨幣或國家/地區",
24
25
  "neptune.MoneyInput.Select.selectCurrencyLabel": "選擇貨幣",
25
26
  "neptune.PhoneNumberInput.SelectInput.placeholder": "選擇其中一項…",
26
27
  "neptune.PhoneNumberInput.countryCodeLabel": "國家/地區代碼",
@@ -1 +1 @@
1
- {"version":3,"file":"zh-HK.json.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"zh-HK.json.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -10,6 +10,7 @@ var useHasIntersected = require('../common/hooks/useHasIntersected/useHasInterse
10
10
  require('../common/propsValues/breakpoint.js');
11
11
  var jsxRuntime = require('react/jsx-runtime');
12
12
 
13
+ const EmptyTransparentImage = 'data:image/gif;base64,R0lGODlhAQABAAAAACH5BAEKAAEALAAAAAABAAEAAAICTAEAOw==';
13
14
  const Image = ({
14
15
  id,
15
16
  src,
@@ -27,27 +28,27 @@ const Image = ({
27
28
  elRef: elementReference,
28
29
  loading
29
30
  });
30
- // Internal onLoad handler that calls user onLoad only if hasIntersected is true
31
- const handleLoad = React.useCallback(() => {
32
- if (hasIntersected && onLoad) {
33
- onLoad();
34
- }
35
- }, [hasIntersected, onLoad]);
31
+ let imageSource = src;
32
+ let imageOnLoad = onLoad;
33
+ if (loading === 'lazy' && !hasIntersected) {
34
+ imageSource = EmptyTransparentImage;
35
+ imageOnLoad = undefined;
36
+ }
36
37
  return /*#__PURE__*/jsxRuntime.jsx("img", {
37
38
  ref: elementReference,
38
39
  id: id,
39
40
  alt: alt,
40
- src: src,
41
- loading: loading,
41
+ src: imageSource,
42
42
  className: clsx.clsx(['tw-image', {
43
43
  'tw-image__stretch': stretch,
44
44
  'tw-image__shrink': shrink
45
45
  }, className]),
46
46
  role: role,
47
- onLoad: handleLoad,
47
+ onLoad: imageOnLoad,
48
48
  onError: onError
49
49
  });
50
50
  };
51
51
 
52
+ exports.EmptyTransparentImage = EmptyTransparentImage;
52
53
  exports.default = Image;
53
54
  //# sourceMappingURL=Image.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"Image.js","sources":["../../src/image/Image.tsx"],"sourcesContent":["import { clsx } from 'clsx';\nimport { useRef, useCallback } from 'react';\n\nimport { useHasIntersected } from '../common/hooks';\n\nexport interface ImageProps {\n alt: string;\n src: string;\n id?: string;\n onLoad?: () => void;\n onError?: () => void;\n className?: string;\n loading?: 'lazy' | 'eager';\n stretch?: boolean;\n role?: string;\n shrink?: boolean;\n}\n\nconst Image = ({\n id,\n src,\n alt,\n onLoad,\n onError,\n className,\n loading,\n stretch = true,\n role,\n shrink = true,\n}: ImageProps) => {\n const elementReference = useRef<HTMLImageElement>(null);\n const [hasIntersected] = useHasIntersected({ elRef: elementReference, loading });\n\n // Internal onLoad handler that calls user onLoad only if hasIntersected is true\n const handleLoad = useCallback(() => {\n if (hasIntersected && onLoad) {\n onLoad();\n }\n }, [hasIntersected, onLoad]);\n\n return (\n <img\n ref={elementReference}\n id={id}\n alt={alt}\n src={src}\n loading={loading}\n className={clsx([\n 'tw-image',\n {\n 'tw-image__stretch': stretch,\n 'tw-image__shrink': shrink,\n },\n className,\n ])}\n role={role}\n onLoad={handleLoad}\n onError={onError}\n />\n );\n};\n\nexport default Image;\n"],"names":["Image","id","src","alt","onLoad","onError","className","loading","stretch","role","shrink","elementReference","useRef","hasIntersected","useHasIntersected","elRef","handleLoad","useCallback","_jsx","ref","clsx"],"mappings":";;;;;;;;;;;;AAkBMA,MAAAA,KAAK,GAAGA,CAAC;EACbC,EAAE;EACFC,GAAG;EACHC,GAAG;EACHC,MAAM;EACNC,OAAO;EACPC,SAAS;EACTC,OAAO;AACPC,EAAAA,OAAO,GAAG,IAAI;EACdC,IAAI;AACJC,EAAAA,MAAM,GAAG;AAAI,CACF,KAAI;AACf,EAAA,MAAMC,gBAAgB,GAAGC,YAAM,CAAmB,IAAI,CAAC;AACvD,EAAA,MAAM,CAACC,cAAc,CAAC,GAAGC,mCAAiB,CAAC;AAAEC,IAAAA,KAAK,EAAEJ,gBAAgB;AAAEJ,IAAAA;AAAO,GAAE,CAAC;AAEhF;AACA,EAAA,MAAMS,UAAU,GAAGC,iBAAW,CAAC,MAAK;IAClC,IAAIJ,cAAc,IAAIT,MAAM,EAAE;AAC5BA,MAAAA,MAAM,EAAE;AACV;AACF,GAAC,EAAE,CAACS,cAAc,EAAET,MAAM,CAAC,CAAC;AAE5B,EAAA,oBACEc,cAAA,CAAA,KAAA,EAAA;AACEC,IAAAA,GAAG,EAAER,gBAAiB;AACtBV,IAAAA,EAAE,EAAEA,EAAG;AACPE,IAAAA,GAAG,EAAEA,GAAI;AACTD,IAAAA,GAAG,EAAEA,GAAI;AACTK,IAAAA,OAAO,EAAEA,OAAQ;AACjBD,IAAAA,SAAS,EAAEc,SAAI,CAAC,CACd,UAAU,EACV;AACE,MAAA,mBAAmB,EAAEZ,OAAO;AAC5B,MAAA,kBAAkB,EAAEE;KACrB,EACDJ,SAAS,CACV,CAAE;AACHG,IAAAA,IAAI,EAAEA,IAAK;AACXL,IAAAA,MAAM,EAAEY,UAAW;AACnBX,IAAAA,OAAO,EAAEA;AAAQ,GACjB,CAAA;AAEN;;;;"}
1
+ {"version":3,"file":"Image.js","sources":["../../src/image/Image.tsx"],"sourcesContent":["import { clsx } from 'clsx';\nimport { useRef } from 'react';\n\nimport { useHasIntersected } from '../common/hooks';\n\nexport interface ImageProps {\n alt: string;\n src: string;\n id?: string;\n onLoad?: () => void;\n onError?: () => void;\n className?: string;\n loading?: 'lazy' | 'eager';\n stretch?: boolean;\n role?: string;\n shrink?: boolean;\n}\n\nexport const EmptyTransparentImage =\n 'data:image/gif;base64,R0lGODlhAQABAAAAACH5BAEKAAEALAAAAAABAAEAAAICTAEAOw==';\n\nconst Image = ({\n id,\n src,\n alt,\n onLoad,\n onError,\n className,\n loading,\n stretch = true,\n role,\n shrink = true,\n}: ImageProps) => {\n const elementReference = useRef<HTMLImageElement>(null);\n const [hasIntersected] = useHasIntersected({ elRef: elementReference, loading });\n let imageSource = src;\n let imageOnLoad = onLoad;\n\n if (loading === 'lazy' && !hasIntersected) {\n imageSource = EmptyTransparentImage;\n imageOnLoad = undefined;\n }\n\n return (\n <img\n ref={elementReference}\n id={id}\n alt={alt}\n src={imageSource}\n className={clsx([\n 'tw-image',\n {\n 'tw-image__stretch': stretch,\n 'tw-image__shrink': shrink,\n },\n className,\n ])}\n role={role}\n onLoad={imageOnLoad}\n onError={onError}\n />\n );\n};\n\nexport default Image;\n"],"names":["EmptyTransparentImage","Image","id","src","alt","onLoad","onError","className","loading","stretch","role","shrink","elementReference","useRef","hasIntersected","useHasIntersected","elRef","imageSource","imageOnLoad","undefined","_jsx","ref","clsx"],"mappings":";;;;;;;;;;;;AAkBO,MAAMA,qBAAqB,GAChC;AAEIC,MAAAA,KAAK,GAAGA,CAAC;EACbC,EAAE;EACFC,GAAG;EACHC,GAAG;EACHC,MAAM;EACNC,OAAO;EACPC,SAAS;EACTC,OAAO;AACPC,EAAAA,OAAO,GAAG,IAAI;EACdC,IAAI;AACJC,EAAAA,MAAM,GAAG;AAAI,CACF,KAAI;AACf,EAAA,MAAMC,gBAAgB,GAAGC,YAAM,CAAmB,IAAI,CAAC;AACvD,EAAA,MAAM,CAACC,cAAc,CAAC,GAAGC,mCAAiB,CAAC;AAAEC,IAAAA,KAAK,EAAEJ,gBAAgB;AAAEJ,IAAAA;AAAO,GAAE,CAAC;EAChF,IAAIS,WAAW,GAAGd,GAAG;EACrB,IAAIe,WAAW,GAAGb,MAAM;AAExB,EAAA,IAAIG,OAAO,KAAK,MAAM,IAAI,CAACM,cAAc,EAAE;AACzCG,IAAAA,WAAW,GAAGjB,qBAAqB;AACnCkB,IAAAA,WAAW,GAAGC,SAAS;AACzB;AAEA,EAAA,oBACEC,cAAA,CAAA,KAAA,EAAA;AACEC,IAAAA,GAAG,EAAET,gBAAiB;AACtBV,IAAAA,EAAE,EAAEA,EAAG;AACPE,IAAAA,GAAG,EAAEA,GAAI;AACTD,IAAAA,GAAG,EAAEc,WAAY;AACjBV,IAAAA,SAAS,EAAEe,SAAI,CAAC,CACd,UAAU,EACV;AACE,MAAA,mBAAmB,EAAEb,OAAO;AAC5B,MAAA,kBAAkB,EAAEE;KACrB,EACDJ,SAAS,CACV,CAAE;AACHG,IAAAA,IAAI,EAAEA,IAAK;AACXL,IAAAA,MAAM,EAAEa,WAAY;AACpBZ,IAAAA,OAAO,EAAEA;AAAQ,GACjB,CAAA;AAEN;;;;;"}
@@ -1,11 +1,12 @@
1
1
  import { clsx } from 'clsx';
2
- import { useRef, useCallback } from 'react';
2
+ import { useRef } from 'react';
3
3
  import '@transferwise/neptune-validation';
4
4
  import '../provider/direction/DirectionProvider.mjs';
5
5
  import { useHasIntersected } from '../common/hooks/useHasIntersected/useHasIntersected.mjs';
6
6
  import '../common/propsValues/breakpoint.mjs';
7
7
  import { jsx } from 'react/jsx-runtime';
8
8
 
9
+ const EmptyTransparentImage = 'data:image/gif;base64,R0lGODlhAQABAAAAACH5BAEKAAEALAAAAAABAAEAAAICTAEAOw==';
9
10
  const Image = ({
10
11
  id,
11
12
  src,
@@ -23,27 +24,26 @@ const Image = ({
23
24
  elRef: elementReference,
24
25
  loading
25
26
  });
26
- // Internal onLoad handler that calls user onLoad only if hasIntersected is true
27
- const handleLoad = useCallback(() => {
28
- if (hasIntersected && onLoad) {
29
- onLoad();
30
- }
31
- }, [hasIntersected, onLoad]);
27
+ let imageSource = src;
28
+ let imageOnLoad = onLoad;
29
+ if (loading === 'lazy' && !hasIntersected) {
30
+ imageSource = EmptyTransparentImage;
31
+ imageOnLoad = undefined;
32
+ }
32
33
  return /*#__PURE__*/jsx("img", {
33
34
  ref: elementReference,
34
35
  id: id,
35
36
  alt: alt,
36
- src: src,
37
- loading: loading,
37
+ src: imageSource,
38
38
  className: clsx(['tw-image', {
39
39
  'tw-image__stretch': stretch,
40
40
  'tw-image__shrink': shrink
41
41
  }, className]),
42
42
  role: role,
43
- onLoad: handleLoad,
43
+ onLoad: imageOnLoad,
44
44
  onError: onError
45
45
  });
46
46
  };
47
47
 
48
- export { Image as default };
48
+ export { EmptyTransparentImage, Image as default };
49
49
  //# sourceMappingURL=Image.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"Image.mjs","sources":["../../src/image/Image.tsx"],"sourcesContent":["import { clsx } from 'clsx';\nimport { useRef, useCallback } from 'react';\n\nimport { useHasIntersected } from '../common/hooks';\n\nexport interface ImageProps {\n alt: string;\n src: string;\n id?: string;\n onLoad?: () => void;\n onError?: () => void;\n className?: string;\n loading?: 'lazy' | 'eager';\n stretch?: boolean;\n role?: string;\n shrink?: boolean;\n}\n\nconst Image = ({\n id,\n src,\n alt,\n onLoad,\n onError,\n className,\n loading,\n stretch = true,\n role,\n shrink = true,\n}: ImageProps) => {\n const elementReference = useRef<HTMLImageElement>(null);\n const [hasIntersected] = useHasIntersected({ elRef: elementReference, loading });\n\n // Internal onLoad handler that calls user onLoad only if hasIntersected is true\n const handleLoad = useCallback(() => {\n if (hasIntersected && onLoad) {\n onLoad();\n }\n }, [hasIntersected, onLoad]);\n\n return (\n <img\n ref={elementReference}\n id={id}\n alt={alt}\n src={src}\n loading={loading}\n className={clsx([\n 'tw-image',\n {\n 'tw-image__stretch': stretch,\n 'tw-image__shrink': shrink,\n },\n className,\n ])}\n role={role}\n onLoad={handleLoad}\n onError={onError}\n />\n );\n};\n\nexport default Image;\n"],"names":["Image","id","src","alt","onLoad","onError","className","loading","stretch","role","shrink","elementReference","useRef","hasIntersected","useHasIntersected","elRef","handleLoad","useCallback","_jsx","ref","clsx"],"mappings":";;;;;;;;AAkBMA,MAAAA,KAAK,GAAGA,CAAC;EACbC,EAAE;EACFC,GAAG;EACHC,GAAG;EACHC,MAAM;EACNC,OAAO;EACPC,SAAS;EACTC,OAAO;AACPC,EAAAA,OAAO,GAAG,IAAI;EACdC,IAAI;AACJC,EAAAA,MAAM,GAAG;AAAI,CACF,KAAI;AACf,EAAA,MAAMC,gBAAgB,GAAGC,MAAM,CAAmB,IAAI,CAAC;AACvD,EAAA,MAAM,CAACC,cAAc,CAAC,GAAGC,iBAAiB,CAAC;AAAEC,IAAAA,KAAK,EAAEJ,gBAAgB;AAAEJ,IAAAA;AAAO,GAAE,CAAC;AAEhF;AACA,EAAA,MAAMS,UAAU,GAAGC,WAAW,CAAC,MAAK;IAClC,IAAIJ,cAAc,IAAIT,MAAM,EAAE;AAC5BA,MAAAA,MAAM,EAAE;AACV;AACF,GAAC,EAAE,CAACS,cAAc,EAAET,MAAM,CAAC,CAAC;AAE5B,EAAA,oBACEc,GAAA,CAAA,KAAA,EAAA;AACEC,IAAAA,GAAG,EAAER,gBAAiB;AACtBV,IAAAA,EAAE,EAAEA,EAAG;AACPE,IAAAA,GAAG,EAAEA,GAAI;AACTD,IAAAA,GAAG,EAAEA,GAAI;AACTK,IAAAA,OAAO,EAAEA,OAAQ;AACjBD,IAAAA,SAAS,EAAEc,IAAI,CAAC,CACd,UAAU,EACV;AACE,MAAA,mBAAmB,EAAEZ,OAAO;AAC5B,MAAA,kBAAkB,EAAEE;KACrB,EACDJ,SAAS,CACV,CAAE;AACHG,IAAAA,IAAI,EAAEA,IAAK;AACXL,IAAAA,MAAM,EAAEY,UAAW;AACnBX,IAAAA,OAAO,EAAEA;AAAQ,GACjB,CAAA;AAEN;;;;"}
1
+ {"version":3,"file":"Image.mjs","sources":["../../src/image/Image.tsx"],"sourcesContent":["import { clsx } from 'clsx';\nimport { useRef } from 'react';\n\nimport { useHasIntersected } from '../common/hooks';\n\nexport interface ImageProps {\n alt: string;\n src: string;\n id?: string;\n onLoad?: () => void;\n onError?: () => void;\n className?: string;\n loading?: 'lazy' | 'eager';\n stretch?: boolean;\n role?: string;\n shrink?: boolean;\n}\n\nexport const EmptyTransparentImage =\n 'data:image/gif;base64,R0lGODlhAQABAAAAACH5BAEKAAEALAAAAAABAAEAAAICTAEAOw==';\n\nconst Image = ({\n id,\n src,\n alt,\n onLoad,\n onError,\n className,\n loading,\n stretch = true,\n role,\n shrink = true,\n}: ImageProps) => {\n const elementReference = useRef<HTMLImageElement>(null);\n const [hasIntersected] = useHasIntersected({ elRef: elementReference, loading });\n let imageSource = src;\n let imageOnLoad = onLoad;\n\n if (loading === 'lazy' && !hasIntersected) {\n imageSource = EmptyTransparentImage;\n imageOnLoad = undefined;\n }\n\n return (\n <img\n ref={elementReference}\n id={id}\n alt={alt}\n src={imageSource}\n className={clsx([\n 'tw-image',\n {\n 'tw-image__stretch': stretch,\n 'tw-image__shrink': shrink,\n },\n className,\n ])}\n role={role}\n onLoad={imageOnLoad}\n onError={onError}\n />\n );\n};\n\nexport default Image;\n"],"names":["EmptyTransparentImage","Image","id","src","alt","onLoad","onError","className","loading","stretch","role","shrink","elementReference","useRef","hasIntersected","useHasIntersected","elRef","imageSource","imageOnLoad","undefined","_jsx","ref","clsx"],"mappings":";;;;;;;;AAkBO,MAAMA,qBAAqB,GAChC;AAEIC,MAAAA,KAAK,GAAGA,CAAC;EACbC,EAAE;EACFC,GAAG;EACHC,GAAG;EACHC,MAAM;EACNC,OAAO;EACPC,SAAS;EACTC,OAAO;AACPC,EAAAA,OAAO,GAAG,IAAI;EACdC,IAAI;AACJC,EAAAA,MAAM,GAAG;AAAI,CACF,KAAI;AACf,EAAA,MAAMC,gBAAgB,GAAGC,MAAM,CAAmB,IAAI,CAAC;AACvD,EAAA,MAAM,CAACC,cAAc,CAAC,GAAGC,iBAAiB,CAAC;AAAEC,IAAAA,KAAK,EAAEJ,gBAAgB;AAAEJ,IAAAA;AAAO,GAAE,CAAC;EAChF,IAAIS,WAAW,GAAGd,GAAG;EACrB,IAAIe,WAAW,GAAGb,MAAM;AAExB,EAAA,IAAIG,OAAO,KAAK,MAAM,IAAI,CAACM,cAAc,EAAE;AACzCG,IAAAA,WAAW,GAAGjB,qBAAqB;AACnCkB,IAAAA,WAAW,GAAGC,SAAS;AACzB;AAEA,EAAA,oBACEC,GAAA,CAAA,KAAA,EAAA;AACEC,IAAAA,GAAG,EAAET,gBAAiB;AACtBV,IAAAA,EAAE,EAAEA,EAAG;AACPE,IAAAA,GAAG,EAAEA,GAAI;AACTD,IAAAA,GAAG,EAAEc,WAAY;AACjBV,IAAAA,SAAS,EAAEe,IAAI,CAAC,CACd,UAAU,EACV;AACE,MAAA,mBAAmB,EAAEb,OAAO;AAC5B,MAAA,kBAAkB,EAAEE;KACrB,EACDJ,SAAS,CACV,CAAE;AACHG,IAAAA,IAAI,EAAEA,IAAK;AACXL,IAAAA,MAAM,EAAEa,WAAY;AACpBZ,IAAAA,OAAO,EAAEA;AAAQ,GACjB,CAAA;AAEN;;;;"}
package/build/index.js CHANGED
@@ -274,6 +274,7 @@ Object.defineProperty(exports, "UploadStep", {
274
274
  get: function () { return Upload.UploadStep; }
275
275
  });
276
276
  exports.UploadInput = UploadInput.default;
277
+ exports.Item = Table.default;
277
278
  exports.Table = Table.default;
278
279
  exports.useDirection = useDirection.useDirection;
279
280
  exports.useLayout = useLayout.useLayout;
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
package/build/index.mjs CHANGED
@@ -105,7 +105,7 @@ export { default as Tooltip } from './tooltip/Tooltip.mjs';
105
105
  export { default as Typeahead } from './typeahead/Typeahead.mjs';
106
106
  export { default as Upload, UploadStep } from './upload/Upload.mjs';
107
107
  export { default as UploadInput } from './uploadInput/UploadInput.mjs';
108
- export { default as Table } from './table/Table.mjs';
108
+ export { default as Item, default as Table } from './table/Table.mjs';
109
109
  import '@transferwise/neptune-validation';
110
110
  export { useDirection } from './common/hooks/useDirection/useDirection.mjs';
111
111
  export { useLayout } from './common/hooks/useLayout/useLayout.mjs';
package/build/main.css CHANGED
@@ -2661,6 +2661,194 @@ html:not([dir="rtl"]) .np-flow-navigation--sm .np-flow-navigation__stepper {
2661
2661
  border-radius: 9999px !important;
2662
2662
  border-radius: var(--radius-full) !important;
2663
2663
  }
2664
+ .wds-list-item {
2665
+ padding: 16px;
2666
+ padding: var(--size-16);
2667
+ border-radius: 24px;
2668
+ border-radius: var(--radius-large);
2669
+ background-color: #ffffff;
2670
+ background-color: var(--color-background-screen);
2671
+ gap: 16px;
2672
+ gap: var(--size-16);
2673
+ }
2674
+ .wds-list-item-interactive {
2675
+ cursor: pointer;
2676
+ }
2677
+ .wds-list-item-interactive:hover {
2678
+ background-color: var(--color-background-screen-hover);
2679
+ }
2680
+ .wds-list-item-interactive:active {
2681
+ background-color: var(--color-background-screen-active);
2682
+ }
2683
+ .wds-list-item-media-image {
2684
+ width: var(--item-media-image-size);
2685
+ height: var(--item-media-image-size);
2686
+ }
2687
+ .wds-list-item-body {
2688
+ width: 100%;
2689
+ }
2690
+ .wds-list-item-title {
2691
+ color: #37517e;
2692
+ color: var(--color-content-primary);
2693
+ }
2694
+ .wds-list-item-additional-info {
2695
+ color: #768e9c;
2696
+ color: var(--color-content-tertiary);
2697
+ }
2698
+ .wds-list-item-value {
2699
+ flex: 0 0 auto;
2700
+ }
2701
+ .wds-list-item-control {
2702
+ flex: 0 0 auto;
2703
+ }
2704
+ .wds-list-item-spotlight-active {
2705
+ background-color: rgba(134,167,189,0.10196);
2706
+ background-color: var(--color-background-neutral);
2707
+ }
2708
+ .wds-list-item-spotlight-active:hover {
2709
+ background-color: var(--color-background-neutral-hover);
2710
+ }
2711
+ .wds-list-item-spotlight-active:active {
2712
+ background-color: var(--color-background-neutral-active);
2713
+ }
2714
+ .wds-list-item-spotlight-inactive {
2715
+ background-color: rgba(134, 167, 189, 0.025);
2716
+ border: 1px dashed rgba(0,0,0,0.10196);
2717
+ border: 1px dashed var(--color-border-neutral);
2718
+ }
2719
+ @supports (color: color-mix(in lch, red, blue)) {
2720
+ .wds-list-item-spotlight-inactive {
2721
+ background-color: color-mix(in srgb, var(--color-background-neutral) 25%, transparent);
2722
+ }
2723
+ }
2724
+ .wds-list-item-spotlight-inactive:hover {
2725
+ background-color: color-mix(in srgb, var(--color-background-neutral-hover) 25%, transparent);
2726
+ }
2727
+ .wds-list-item-spotlight-inactive:active {
2728
+ background-color: color-mix(in srgb, var(--color-background-neutral-active) 25%, transparent);
2729
+ }
2730
+ .wds-list-item-prompt {
2731
+ display: inline-flex;
2732
+ padding-top: calc(8px / 2);
2733
+ padding-top: calc(var(--padding-x-small) / 2);
2734
+ padding-bottom: calc(8px / 2);
2735
+ padding-bottom: calc(var(--padding-x-small) / 2);
2736
+ padding-left: calc(8px - 1px);
2737
+ padding-left: calc(var(--padding-x-small) - 1px);
2738
+ padding-right: 8px;
2739
+ padding-right: var(--padding-x-small);
2740
+ border-radius: 10px;
2741
+ border-radius: var(--radius-small);
2742
+ word-break: break-word;
2743
+ word-wrap: break-word;
2744
+ }
2745
+ .wds-list-item-prompt .np-prompt-icon {
2746
+ padding-right: calc(12px / 2);
2747
+ padding-right: calc(var(--size-12) / 2);
2748
+ padding-top: calc(4px - 1px);
2749
+ padding-top: calc(var(--size-4) - 1px);
2750
+ padding-bottom: calc(4px - 1px);
2751
+ padding-bottom: calc(var(--size-4) - 1px);
2752
+ }
2753
+ .wds-list-item-prompt .np-prompt-icon .tw-icon-tags,
2754
+ .wds-list-item-prompt .np-prompt-icon .tw-icon-confetti {
2755
+ color: var(--color-sentiment-positive-primary);
2756
+ }
2757
+ .wds-list-item-prompt a {
2758
+ text-underline-offset: calc(4px / 2);
2759
+ text-underline-offset: calc(var(--size-4) / 2);
2760
+ }
2761
+ .wds-list-item-prompt.np-prompt-interactive {
2762
+ -webkit-text-decoration: none;
2763
+ text-decoration: none;
2764
+ cursor: pointer;
2765
+ border: none;
2766
+ }
2767
+ .wds-list-item-prompt.negative {
2768
+ background-color: var(--color-sentiment-negative-secondary);
2769
+ color: var(--color-sentiment-negative-primary);
2770
+ }
2771
+ .wds-list-item-prompt.negative a {
2772
+ color: var(--color-sentiment-negative-primary);
2773
+ }
2774
+ .wds-list-item-prompt.negative a:hover {
2775
+ color: var(--color-sentiment-negative-primary-hover);
2776
+ }
2777
+ .wds-list-item-prompt.negative a:active {
2778
+ color: var(--color-sentiment-negative-primary-active);
2779
+ }
2780
+ .np-prompt-interactive.wds-list-item-prompt.negative:hover {
2781
+ background-color: color-mix(in srgb, var(--color-sentiment-negative-secondary) 95%, var(--color-sentiment-negative-primary));
2782
+ }
2783
+ .np-prompt-interactive.wds-list-item-prompt.negative:active {
2784
+ background-color: color-mix(in srgb, var(--color-sentiment-negative-secondary) 90%, var(--color-sentiment-negative-primary));
2785
+ }
2786
+ .wds-list-item-prompt.positive,
2787
+ .wds-list-item-prompt.discount,
2788
+ .wds-list-item-prompt.savings {
2789
+ background-color: var(--color-sentiment-positive-secondary);
2790
+ color: var(--color-sentiment-positive-primary);
2791
+ }
2792
+ .wds-list-item-prompt.positive a,
2793
+ .wds-list-item-prompt.discount a,
2794
+ .wds-list-item-prompt.savings a {
2795
+ color: var(--color-sentiment-positive-primary);
2796
+ }
2797
+ .wds-list-item-prompt.positive a:hover,
2798
+ .wds-list-item-prompt.discount a:hover,
2799
+ .wds-list-item-prompt.savings a:hover {
2800
+ color: var(--color-sentiment-positive-primary-hover);
2801
+ }
2802
+ .wds-list-item-prompt.positive a:active,
2803
+ .wds-list-item-prompt.discount a:active,
2804
+ .wds-list-item-prompt.savings a:active {
2805
+ color: var(--color-sentiment-positive-primary-active);
2806
+ }
2807
+ .np-prompt-interactive.wds-list-item-prompt.positive:hover,
2808
+ .np-prompt-interactive.wds-list-item-prompt.discount:hover,
2809
+ .np-prompt-interactive.wds-list-item-prompt.savings:hover {
2810
+ background-color: color-mix(in srgb, var(--color-sentiment-positive-secondary) 95%, var(--color-sentiment-positive-primary));
2811
+ }
2812
+ .np-prompt-interactive.wds-list-item-prompt.positive:active,
2813
+ .np-prompt-interactive.wds-list-item-prompt.discount:active,
2814
+ .np-prompt-interactive.wds-list-item-prompt.savings:active {
2815
+ background-color: color-mix(in srgb, var(--color-sentiment-positive-secondary) 90%, var(--color-sentiment-positive-primary));
2816
+ }
2817
+ .wds-list-item-prompt.neutral {
2818
+ background-color: rgba(134,167,189,0.10196);
2819
+ background-color: var(--color-background-neutral);
2820
+ color: #37517e;
2821
+ color: var(--color-content-primary);
2822
+ }
2823
+ .wds-list-item-prompt.neutral a {
2824
+ color: #37517e;
2825
+ color: var(--color-content-primary);
2826
+ }
2827
+ .np-prompt-interactive.wds-list-item-prompt.neutral:hover {
2828
+ background-color: var(--color-background-neutral-hover);
2829
+ }
2830
+ .np-prompt-interactive.wds-list-item-prompt.neutral:active {
2831
+ background-color: var(--color-background-neutral-active);
2832
+ }
2833
+ .wds-list-item-prompt.warning {
2834
+ background-color: var(--color-sentiment-warning-secondary);
2835
+ color: var(--color-sentiment-warning-content);
2836
+ }
2837
+ .wds-list-item-prompt.warning a {
2838
+ color: var(--color-sentiment-warning-content);
2839
+ }
2840
+ .wds-list-item-prompt.warning a:hover {
2841
+ color: var(--color-sentiment-warning-content-hover);
2842
+ }
2843
+ .wds-list-item-prompt.warning a:active {
2844
+ color: var(--color-sentiment-warning-content-active);
2845
+ }
2846
+ .np-prompt-interactive.wds-list-item-prompt.warning:hover {
2847
+ background-color: color-mix(in srgb, var(--color-sentiment-warning-secondary) 90%, var(--color-sentiment-warning-primary));
2848
+ }
2849
+ .np-prompt-interactive.wds-list-item-prompt.warning:active {
2850
+ background-color: color-mix(in srgb, var(--color-sentiment-warning-secondary) 80%, var(--color-sentiment-warning-primary));
2851
+ }
2664
2852
  .np-field-control {
2665
2853
  margin-top: 4px;
2666
2854
  margin-top: var(--size-4);
@@ -0,0 +1,188 @@
1
+ .wds-list-item {
2
+ padding: 16px;
3
+ padding: var(--size-16);
4
+ border-radius: 24px;
5
+ border-radius: var(--radius-large);
6
+ background-color: #ffffff;
7
+ background-color: var(--color-background-screen);
8
+ gap: 16px;
9
+ gap: var(--size-16);
10
+ }
11
+ .wds-list-item-interactive {
12
+ cursor: pointer;
13
+ }
14
+ .wds-list-item-interactive:hover {
15
+ background-color: var(--color-background-screen-hover);
16
+ }
17
+ .wds-list-item-interactive:active {
18
+ background-color: var(--color-background-screen-active);
19
+ }
20
+ .wds-list-item-media-image {
21
+ width: var(--item-media-image-size);
22
+ height: var(--item-media-image-size);
23
+ }
24
+ .wds-list-item-body {
25
+ width: 100%;
26
+ }
27
+ .wds-list-item-title {
28
+ color: #37517e;
29
+ color: var(--color-content-primary);
30
+ }
31
+ .wds-list-item-additional-info {
32
+ color: #768e9c;
33
+ color: var(--color-content-tertiary);
34
+ }
35
+ .wds-list-item-value {
36
+ flex: 0 0 auto;
37
+ }
38
+ .wds-list-item-control {
39
+ flex: 0 0 auto;
40
+ }
41
+ .wds-list-item-spotlight-active {
42
+ background-color: rgba(134,167,189,0.10196);
43
+ background-color: var(--color-background-neutral);
44
+ }
45
+ .wds-list-item-spotlight-active:hover {
46
+ background-color: var(--color-background-neutral-hover);
47
+ }
48
+ .wds-list-item-spotlight-active:active {
49
+ background-color: var(--color-background-neutral-active);
50
+ }
51
+ .wds-list-item-spotlight-inactive {
52
+ background-color: rgba(134, 167, 189, 0.025);
53
+ border: 1px dashed rgba(0,0,0,0.10196);
54
+ border: 1px dashed var(--color-border-neutral);
55
+ }
56
+ @supports (color: color-mix(in lch, red, blue)) {
57
+ .wds-list-item-spotlight-inactive {
58
+ background-color: color-mix(in srgb, var(--color-background-neutral) 25%, transparent);
59
+ }
60
+ }
61
+ .wds-list-item-spotlight-inactive:hover {
62
+ background-color: color-mix(in srgb, var(--color-background-neutral-hover) 25%, transparent);
63
+ }
64
+ .wds-list-item-spotlight-inactive:active {
65
+ background-color: color-mix(in srgb, var(--color-background-neutral-active) 25%, transparent);
66
+ }
67
+ .wds-list-item-prompt {
68
+ display: inline-flex;
69
+ padding-top: calc(8px / 2);
70
+ padding-top: calc(var(--padding-x-small) / 2);
71
+ padding-bottom: calc(8px / 2);
72
+ padding-bottom: calc(var(--padding-x-small) / 2);
73
+ padding-left: calc(8px - 1px);
74
+ padding-left: calc(var(--padding-x-small) - 1px);
75
+ padding-right: 8px;
76
+ padding-right: var(--padding-x-small);
77
+ border-radius: 10px;
78
+ border-radius: var(--radius-small);
79
+ word-break: break-word;
80
+ word-wrap: break-word;
81
+ }
82
+ .wds-list-item-prompt .np-prompt-icon {
83
+ padding-right: calc(12px / 2);
84
+ padding-right: calc(var(--size-12) / 2);
85
+ padding-top: calc(4px - 1px);
86
+ padding-top: calc(var(--size-4) - 1px);
87
+ padding-bottom: calc(4px - 1px);
88
+ padding-bottom: calc(var(--size-4) - 1px);
89
+ }
90
+ .wds-list-item-prompt .np-prompt-icon .tw-icon-tags,
91
+ .wds-list-item-prompt .np-prompt-icon .tw-icon-confetti {
92
+ color: var(--color-sentiment-positive-primary);
93
+ }
94
+ .wds-list-item-prompt a {
95
+ text-underline-offset: calc(4px / 2);
96
+ text-underline-offset: calc(var(--size-4) / 2);
97
+ }
98
+ .wds-list-item-prompt.np-prompt-interactive {
99
+ -webkit-text-decoration: none;
100
+ text-decoration: none;
101
+ cursor: pointer;
102
+ border: none;
103
+ }
104
+ .wds-list-item-prompt.negative {
105
+ background-color: var(--color-sentiment-negative-secondary);
106
+ color: var(--color-sentiment-negative-primary);
107
+ }
108
+ .wds-list-item-prompt.negative a {
109
+ color: var(--color-sentiment-negative-primary);
110
+ }
111
+ .wds-list-item-prompt.negative a:hover {
112
+ color: var(--color-sentiment-negative-primary-hover);
113
+ }
114
+ .wds-list-item-prompt.negative a:active {
115
+ color: var(--color-sentiment-negative-primary-active);
116
+ }
117
+ .np-prompt-interactive.wds-list-item-prompt.negative:hover {
118
+ background-color: color-mix(in srgb, var(--color-sentiment-negative-secondary) 95%, var(--color-sentiment-negative-primary));
119
+ }
120
+ .np-prompt-interactive.wds-list-item-prompt.negative:active {
121
+ background-color: color-mix(in srgb, var(--color-sentiment-negative-secondary) 90%, var(--color-sentiment-negative-primary));
122
+ }
123
+ .wds-list-item-prompt.positive,
124
+ .wds-list-item-prompt.discount,
125
+ .wds-list-item-prompt.savings {
126
+ background-color: var(--color-sentiment-positive-secondary);
127
+ color: var(--color-sentiment-positive-primary);
128
+ }
129
+ .wds-list-item-prompt.positive a,
130
+ .wds-list-item-prompt.discount a,
131
+ .wds-list-item-prompt.savings a {
132
+ color: var(--color-sentiment-positive-primary);
133
+ }
134
+ .wds-list-item-prompt.positive a:hover,
135
+ .wds-list-item-prompt.discount a:hover,
136
+ .wds-list-item-prompt.savings a:hover {
137
+ color: var(--color-sentiment-positive-primary-hover);
138
+ }
139
+ .wds-list-item-prompt.positive a:active,
140
+ .wds-list-item-prompt.discount a:active,
141
+ .wds-list-item-prompt.savings a:active {
142
+ color: var(--color-sentiment-positive-primary-active);
143
+ }
144
+ .np-prompt-interactive.wds-list-item-prompt.positive:hover,
145
+ .np-prompt-interactive.wds-list-item-prompt.discount:hover,
146
+ .np-prompt-interactive.wds-list-item-prompt.savings:hover {
147
+ background-color: color-mix(in srgb, var(--color-sentiment-positive-secondary) 95%, var(--color-sentiment-positive-primary));
148
+ }
149
+ .np-prompt-interactive.wds-list-item-prompt.positive:active,
150
+ .np-prompt-interactive.wds-list-item-prompt.discount:active,
151
+ .np-prompt-interactive.wds-list-item-prompt.savings:active {
152
+ background-color: color-mix(in srgb, var(--color-sentiment-positive-secondary) 90%, var(--color-sentiment-positive-primary));
153
+ }
154
+ .wds-list-item-prompt.neutral {
155
+ background-color: rgba(134,167,189,0.10196);
156
+ background-color: var(--color-background-neutral);
157
+ color: #37517e;
158
+ color: var(--color-content-primary);
159
+ }
160
+ .wds-list-item-prompt.neutral a {
161
+ color: #37517e;
162
+ color: var(--color-content-primary);
163
+ }
164
+ .np-prompt-interactive.wds-list-item-prompt.neutral:hover {
165
+ background-color: var(--color-background-neutral-hover);
166
+ }
167
+ .np-prompt-interactive.wds-list-item-prompt.neutral:active {
168
+ background-color: var(--color-background-neutral-active);
169
+ }
170
+ .wds-list-item-prompt.warning {
171
+ background-color: var(--color-sentiment-warning-secondary);
172
+ color: var(--color-sentiment-warning-content);
173
+ }
174
+ .wds-list-item-prompt.warning a {
175
+ color: var(--color-sentiment-warning-content);
176
+ }
177
+ .wds-list-item-prompt.warning a:hover {
178
+ color: var(--color-sentiment-warning-content-hover);
179
+ }
180
+ .wds-list-item-prompt.warning a:active {
181
+ color: var(--color-sentiment-warning-content-active);
182
+ }
183
+ .np-prompt-interactive.wds-list-item-prompt.warning:hover {
184
+ background-color: color-mix(in srgb, var(--color-sentiment-warning-secondary) 90%, var(--color-sentiment-warning-primary));
185
+ }
186
+ .np-prompt-interactive.wds-list-item-prompt.warning:active {
187
+ background-color: color-mix(in srgb, var(--color-sentiment-warning-secondary) 80%, var(--color-sentiment-warning-primary));
188
+ }