@learncard/react 2.6.79 → 2.7.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 (165) hide show
  1. package/dist/cjs/{CertificateDisplayCard-2283f3de.js → CertificateDisplayCard-74de3c56.js} +72 -52
  2. package/dist/cjs/CertificateDisplayCard-74de3c56.js.map +1 -0
  3. package/dist/{esm/numeral-804ed0c4.js → cjs/CircleIcon-5587a585.js} +97 -2
  4. package/dist/cjs/CircleIcon-5587a585.js.map +1 -0
  5. package/dist/cjs/{User-dde46685.js → Coins-acd63f46.js} +1 -85
  6. package/dist/cjs/Coins-acd63f46.js.map +1 -0
  7. package/dist/cjs/{Notification-0bc2680c.js → Notification-d212fa7b.js} +2 -2
  8. package/dist/cjs/{Notification-0bc2680c.js.map → Notification-d212fa7b.js.map} +1 -1
  9. package/dist/cjs/{NotificationBoostCard-194ae55a.js → NotificationBoostCard-70dfa17e.js} +2 -2
  10. package/dist/cjs/{NotificationBoostCard-194ae55a.js.map → NotificationBoostCard-70dfa17e.js.map} +1 -1
  11. package/dist/cjs/PuzzlePiece-937c216a.js +31 -0
  12. package/dist/cjs/PuzzlePiece-937c216a.js.map +1 -0
  13. package/dist/cjs/{react-barcode-1a2c5694.js → SchoolIDCard-c7b4153a.js} +61 -1185
  14. package/dist/cjs/SchoolIDCard-c7b4153a.js.map +1 -0
  15. package/dist/cjs/User-301088ac.js +93 -0
  16. package/dist/cjs/User-301088ac.js.map +1 -0
  17. package/dist/cjs/{VCCard-55f7738e.js → VCCard-98ab4879.js} +4 -31
  18. package/dist/{esm/VCCard-caeb4bbd.js.map → cjs/VCCard-98ab4879.js.map} +1 -1
  19. package/dist/cjs/{VCDisplayBackFace-42f41d3f.js → VCDisplayBackFace-a3cd6ad2.js} +3 -3
  20. package/dist/cjs/{VCDisplayBackFace-42f41d3f.js.map → VCDisplayBackFace-a3cd6ad2.js.map} +1 -1
  21. package/dist/cjs/{VCDisplayCard-3c50142e.js → VCDisplayCard-f0783ca4.js} +3 -3
  22. package/dist/cjs/{VCDisplayCard-3c50142e.js.map → VCDisplayCard-f0783ca4.js.map} +1 -1
  23. package/dist/cjs/{VCDisplayCard2-de2f603c.js → VCDisplayCard2-e09f4a0a.js} +272 -39
  24. package/dist/cjs/VCDisplayCard2-e09f4a0a.js.map +1 -0
  25. package/dist/cjs/VCVerificationPill-43201cac.js +75 -0
  26. package/dist/cjs/VCVerificationPill-43201cac.js.map +1 -0
  27. package/dist/cjs/{constants-93a826a5.js → constants-3359aea1.js} +52 -2
  28. package/dist/cjs/constants-3359aea1.js.map +1 -0
  29. package/dist/cjs/{credential.helpers-adf7af7c.js → credential.helpers-ccf9ea86.js} +8 -48
  30. package/dist/cjs/{credential.helpers-adf7af7c.js.map → credential.helpers-ccf9ea86.js.map} +1 -1
  31. package/dist/cjs/index-838fa72c.js +1186 -0
  32. package/dist/cjs/index-838fa72c.js.map +1 -0
  33. package/dist/cjs/index.js +35 -34
  34. package/dist/cjs/index.js.map +1 -1
  35. package/dist/cjs/index13.js +35 -34
  36. package/dist/cjs/index13.js.map +1 -1
  37. package/dist/cjs/index22.js +5 -3
  38. package/dist/cjs/index22.js.map +1 -1
  39. package/dist/cjs/index23.js +5 -3
  40. package/dist/cjs/index23.js.map +1 -1
  41. package/dist/cjs/index28.js +3 -5
  42. package/dist/cjs/index28.js.map +1 -1
  43. package/dist/cjs/index29.js +2 -2
  44. package/dist/cjs/index35.js +3 -2
  45. package/dist/cjs/index35.js.map +1 -1
  46. package/dist/cjs/index36.js +17 -79
  47. package/dist/cjs/index36.js.map +1 -1
  48. package/dist/cjs/index37.js +6 -85
  49. package/dist/cjs/index37.js.map +1 -1
  50. package/dist/cjs/index38.js +9 -86
  51. package/dist/cjs/index38.js.map +1 -1
  52. package/dist/cjs/index39.js +10 -79
  53. package/dist/cjs/index39.js.map +1 -1
  54. package/dist/cjs/index40.js +1 -87
  55. package/dist/cjs/index40.js.map +1 -1
  56. package/dist/cjs/index43.js +2 -1
  57. package/dist/cjs/index43.js.map +1 -1
  58. package/dist/cjs/index6.js +10 -82
  59. package/dist/cjs/index6.js.map +1 -1
  60. package/dist/cjs/index8.js +1 -2
  61. package/dist/cjs/index8.js.map +1 -1
  62. package/dist/cjs/{types-7f6324ea.js → types-8eab1382.js} +6 -26
  63. package/dist/cjs/types-8eab1382.js.map +1 -0
  64. package/dist/{esm/VCVerificationPill-2c48beee.js → cjs/types.esm-2ec4fa7e.js} +3 -63
  65. package/dist/cjs/types.esm-2ec4fa7e.js.map +1 -0
  66. package/dist/esm/{CertificateDisplayCard-711f2e93.js → CertificateDisplayCard-b3c93952.js} +66 -46
  67. package/dist/esm/CertificateDisplayCard-b3c93952.js.map +1 -0
  68. package/dist/{cjs/numeral-d057158c.js → esm/CircleIcon-b527bf95.js} +89 -3
  69. package/dist/esm/CircleIcon-b527bf95.js.map +1 -0
  70. package/dist/esm/{User-9f253521.js → Coins-ed119ec6.js} +2 -83
  71. package/dist/esm/Coins-ed119ec6.js.map +1 -0
  72. package/dist/esm/{Notification-78a215ff.js → Notification-95d159d2.js} +2 -2
  73. package/dist/esm/{Notification-78a215ff.js.map → Notification-95d159d2.js.map} +1 -1
  74. package/dist/esm/{NotificationBoostCard-9e7197eb.js → NotificationBoostCard-e614c341.js} +2 -2
  75. package/dist/esm/{NotificationBoostCard-9e7197eb.js.map → NotificationBoostCard-e614c341.js.map} +1 -1
  76. package/dist/esm/PuzzlePiece-1fb12c2e.js +25 -0
  77. package/dist/esm/PuzzlePiece-1fb12c2e.js.map +1 -0
  78. package/dist/esm/{react-barcode-150610c2.js → SchoolIDCard-01422d53.js} +60 -1184
  79. package/dist/esm/SchoolIDCard-01422d53.js.map +1 -0
  80. package/dist/esm/User-161c7f37.js +85 -0
  81. package/dist/esm/User-161c7f37.js.map +1 -0
  82. package/dist/esm/{VCCard-caeb4bbd.js → VCCard-b0347a85.js} +4 -31
  83. package/dist/{cjs/VCCard-55f7738e.js.map → esm/VCCard-b0347a85.js.map} +1 -1
  84. package/dist/esm/{VCDisplayBackFace-e13869e2.js → VCDisplayBackFace-1a581f1c.js} +3 -3
  85. package/dist/esm/{VCDisplayBackFace-e13869e2.js.map → VCDisplayBackFace-1a581f1c.js.map} +1 -1
  86. package/dist/esm/{VCDisplayCard-04dcc183.js → VCDisplayCard-ac914ce3.js} +3 -3
  87. package/dist/esm/{VCDisplayCard-04dcc183.js.map → VCDisplayCard-ac914ce3.js.map} +1 -1
  88. package/dist/esm/{VCDisplayCard2-e2e1d9f1.js → VCDisplayCard2-b0f44405.js} +251 -19
  89. package/dist/esm/VCDisplayCard2-b0f44405.js.map +1 -0
  90. package/dist/esm/VCVerificationPill-3e38a718.js +65 -0
  91. package/dist/esm/VCVerificationPill-3e38a718.js.map +1 -0
  92. package/dist/esm/constants-f2a32f0c.js +107 -0
  93. package/dist/esm/constants-f2a32f0c.js.map +1 -0
  94. package/dist/esm/{credential.helpers-20680b00.js → credential.helpers-c06a1aa8.js} +5 -45
  95. package/dist/esm/{credential.helpers-20680b00.js.map → credential.helpers-c06a1aa8.js.map} +1 -1
  96. package/dist/esm/index-4fa491c1.js +1184 -0
  97. package/dist/esm/index-4fa491c1.js.map +1 -0
  98. package/dist/esm/index.js +26 -26
  99. package/dist/esm/index13.js +26 -26
  100. package/dist/esm/index22.js +5 -3
  101. package/dist/esm/index22.js.map +1 -1
  102. package/dist/esm/index23.js +5 -3
  103. package/dist/esm/index23.js.map +1 -1
  104. package/dist/esm/index28.js +2 -4
  105. package/dist/esm/index28.js.map +1 -1
  106. package/dist/esm/index29.js +2 -2
  107. package/dist/esm/index35.js +2 -1
  108. package/dist/esm/index35.js.map +1 -1
  109. package/dist/esm/index36.js +17 -79
  110. package/dist/esm/index36.js.map +1 -1
  111. package/dist/esm/index37.js +6 -85
  112. package/dist/esm/index37.js.map +1 -1
  113. package/dist/esm/index38.js +9 -86
  114. package/dist/esm/index38.js.map +1 -1
  115. package/dist/esm/index39.js +9 -78
  116. package/dist/esm/index39.js.map +1 -1
  117. package/dist/esm/index40.js +1 -87
  118. package/dist/esm/index40.js.map +1 -1
  119. package/dist/esm/index43.js +2 -1
  120. package/dist/esm/index43.js.map +1 -1
  121. package/dist/esm/index6.js +9 -82
  122. package/dist/esm/index6.js.map +1 -1
  123. package/dist/esm/index8.js +1 -2
  124. package/dist/esm/index8.js.map +1 -1
  125. package/dist/esm/{types-c31e4bae.js → types-cfde3c2b.js} +5 -24
  126. package/dist/esm/types-cfde3c2b.js.map +1 -0
  127. package/dist/{cjs/VCVerificationPill-b4b96a9f.js → esm/types.esm-8f6a5623.js} +2 -75
  128. package/dist/esm/types.esm-8f6a5623.js.map +1 -0
  129. package/dist/index.d.ts +10 -1
  130. package/dist/main.css +1 -1
  131. package/dist/main.js +1 -1
  132. package/package.json +1 -1
  133. package/dist/cjs/CertificateDisplayCard-2283f3de.js.map +0 -1
  134. package/dist/cjs/CircleIcon-dace003c.js +0 -98
  135. package/dist/cjs/CircleIcon-dace003c.js.map +0 -1
  136. package/dist/cjs/RoundedSquare-fc16f13f.js +0 -58
  137. package/dist/cjs/RoundedSquare-fc16f13f.js.map +0 -1
  138. package/dist/cjs/SchoolIDCard-44ef96bd.js +0 -68
  139. package/dist/cjs/SchoolIDCard-44ef96bd.js.map +0 -1
  140. package/dist/cjs/User-dde46685.js.map +0 -1
  141. package/dist/cjs/VCDisplayCard2-de2f603c.js.map +0 -1
  142. package/dist/cjs/VCVerificationPill-b4b96a9f.js.map +0 -1
  143. package/dist/cjs/constants-93a826a5.js.map +0 -1
  144. package/dist/cjs/index.es-05e5f438.js +0 -194
  145. package/dist/cjs/index.es-05e5f438.js.map +0 -1
  146. package/dist/cjs/numeral-d057158c.js.map +0 -1
  147. package/dist/cjs/react-barcode-1a2c5694.js.map +0 -1
  148. package/dist/cjs/types-7f6324ea.js.map +0 -1
  149. package/dist/esm/CertificateDisplayCard-711f2e93.js.map +0 -1
  150. package/dist/esm/CircleIcon-b45511e1.js +0 -91
  151. package/dist/esm/CircleIcon-b45511e1.js.map +0 -1
  152. package/dist/esm/RoundedSquare-0d25f9ef.js +0 -52
  153. package/dist/esm/RoundedSquare-0d25f9ef.js.map +0 -1
  154. package/dist/esm/SchoolIDCard-91bade9a.js +0 -62
  155. package/dist/esm/SchoolIDCard-91bade9a.js.map +0 -1
  156. package/dist/esm/User-9f253521.js.map +0 -1
  157. package/dist/esm/VCDisplayCard2-e2e1d9f1.js.map +0 -1
  158. package/dist/esm/VCVerificationPill-2c48beee.js.map +0 -1
  159. package/dist/esm/constants-ee2b8bc3.js +0 -59
  160. package/dist/esm/constants-ee2b8bc3.js.map +0 -1
  161. package/dist/esm/index.es-0cc0c240.js +0 -187
  162. package/dist/esm/index.es-0cc0c240.js.map +0 -1
  163. package/dist/esm/numeral-804ed0c4.js.map +0 -1
  164. package/dist/esm/react-barcode-150610c2.js.map +0 -1
  165. package/dist/esm/types-c31e4bae.js.map +0 -1
@@ -1,91 +0,0 @@
1
- import React from 'react';
2
- import { n as numeral } from './numeral-804ed0c4.js';
3
- import { C as CircleLoadingState, a as CircleSpinner } from './CircleSpinner-9b8b1a6b.js';
4
- import { I as Icons } from './index-43f63ea7.js';
5
- import { I as ICONS_TO_SOURCE } from './icons-6ed3416f.js';
6
-
7
- var __defProp = Object.defineProperty;
8
- var __defProps = Object.defineProperties;
9
- var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
10
- var __getOwnPropSymbols = Object.getOwnPropertySymbols;
11
- var __hasOwnProp = Object.prototype.hasOwnProperty;
12
- var __propIsEnum = Object.prototype.propertyIsEnumerable;
13
- var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
14
- var __spreadValues = (a, b) => {
15
- for (var prop in b || (b = {}))
16
- if (__hasOwnProp.call(b, prop))
17
- __defNormalProp(a, prop, b[prop]);
18
- if (__getOwnPropSymbols)
19
- for (var prop of __getOwnPropSymbols(b)) {
20
- if (__propIsEnum.call(b, prop))
21
- __defNormalProp(a, prop, b[prop]);
22
- }
23
- return a;
24
- };
25
- var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
26
- const CountCircle = ({
27
- size = "auto",
28
- count = "28",
29
- innerPadding = "3px 5px",
30
- onClick = () => {
31
- },
32
- bgColor = "bg-grayscale-50",
33
- loading
34
- }) => {
35
- const _count = Number(count) >= 1e3 ? numeral(Number(count)).format("0.0a") : count;
36
- const circleLoadingState = loading ? CircleLoadingState.spin : CircleLoadingState.stop;
37
- const style = {
38
- width: size,
39
- height: size,
40
- padding: !loading ? innerPadding : "0px",
41
- backgroundColor: bgColor
42
- };
43
- const spinnerStyle = {
44
- transform: "translateX(-2px) translateY(1px)"
45
- };
46
- return /* @__PURE__ */ React.createElement("section", {
47
- onClick,
48
- className: `text-grayscale-50 rounded-full`,
49
- style
50
- }, !loading && count && /* @__PURE__ */ React.createElement("p", {
51
- className: ""
52
- }, _count), loading && /* @__PURE__ */ React.createElement("div", {
53
- style: spinnerStyle
54
- }, /* @__PURE__ */ React.createElement(CircleSpinner, {
55
- loadingState: circleLoadingState,
56
- thickness: 3,
57
- size: 20
58
- })));
59
- };
60
- const CircleIcon = ({
61
- iconSrc = ICONS_TO_SOURCE[Icons.coinsIcon],
62
- size = "52px",
63
- count = "28",
64
- onClick = () => {
65
- },
66
- loading,
67
- iconCircleClass = ""
68
- }) => {
69
- const style = {
70
- width: size,
71
- height: size,
72
- backgroundColor: `rgba(24, 34, 78, 0.85)`
73
- };
74
- return /* @__PURE__ */ React.createElement("div", {
75
- style,
76
- className: `rounded-full ${iconCircleClass}`
77
- }, /* @__PURE__ */ React.createElement("section", {
78
- onClick,
79
- className: `flex flex-row-reverse justify-center items-center rounded-full relative overflow-hidden w-16 `,
80
- style: __spreadProps(__spreadValues({}, style), { backgroundColor: "transparent" })
81
- }, /* @__PURE__ */ React.createElement(CountCircle, {
82
- count,
83
- loading
84
- }), /* @__PURE__ */ React.createElement("img", {
85
- src: iconSrc != null ? iconSrc : "",
86
- alt: "Icon image"
87
- })));
88
- };
89
-
90
- export { CountCircle as C, CircleIcon as a };
91
- //# sourceMappingURL=CircleIcon-b45511e1.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"CircleIcon-b45511e1.js","sources":["../../src/components/CircleIcon/CircleIcon.tsx"],"sourcesContent":["import React from 'react';\nimport numeral from 'numeral';\nimport CircleSpinner, { CircleLoadingState } from '../Loading/CircleSpinner';\nimport { Icons } from '../../types';\nimport { ICONS_TO_SOURCE } from '../../constants/icons';\n\nexport type CircleIconProps = {\n iconSrc?: string;\n count?: string | number;\n onClick?: () => void;\n bgColor?: string;\n innerPadding?: string;\n size?: string;\n borderColor?: string;\n loading?: boolean;\n iconCircleClass?: string;\n};\n\nexport type CountCircleProps = {\n size?: string;\n count?: string | number;\n innerPadding?: string;\n onClick?: () => {};\n bgColor?: string;\n className?: string;\n loading?: boolean;\n};\n\nexport const CountCircle: React.FC<CountCircleProps> = ({\n size = 'auto',\n count = '28',\n innerPadding = '3px 5px',\n onClick = () => {},\n bgColor = 'bg-grayscale-50',\n loading,\n}) => {\n const _count = Number(count) >= 1000 ? numeral(Number(count)).format('0.0a') : count;\n const circleLoadingState = loading ? CircleLoadingState.spin : CircleLoadingState.stop;\n const style = {\n width: size,\n height: size,\n padding: !loading ? innerPadding : '0px',\n backgroundColor: bgColor,\n };\n\n const spinnerStyle = {\n transform: 'translateX(-2px) translateY(1px)',\n };\n\n return (\n <section onClick={onClick} className={`text-grayscale-50 rounded-full`} style={style}>\n {!loading && count && <p className=\"\">{_count}</p>}\n {loading && (\n <div style={spinnerStyle}>\n <CircleSpinner loadingState={circleLoadingState} thickness={3} size={20} />\n </div>\n )}\n </section>\n );\n};\n\nexport const CircleIcon: React.FC<CircleIconProps> = ({\n iconSrc = ICONS_TO_SOURCE[Icons.coinsIcon],\n size = '52px',\n count = '28',\n onClick = () => {},\n loading,\n iconCircleClass = '',\n}) => {\n const style = {\n width: size,\n height: size,\n backgroundColor: `rgba(24, 34, 78, 0.85)`,\n };\n\n return (\n <div style={style} className={`rounded-full ${iconCircleClass}`}>\n <section\n onClick={onClick}\n className={`flex flex-row-reverse justify-center items-center rounded-full relative overflow-hidden w-16 `}\n style={{ ...style, backgroundColor: 'transparent' }}\n >\n <CountCircle count={count} loading={loading} />\n <img src={iconSrc ?? ''} alt=\"Icon image\" />\n </section>\n </div>\n );\n};\n\nexport default CircleIcon;\n"],"names":[],"mappings":"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"}
@@ -1,52 +0,0 @@
1
- import React from 'react';
2
- import { a as CircleIcon } from './CircleIcon-b45511e1.js';
3
- import { I as Icons, W as WalletCategoryTypes } from './index-43f63ea7.js';
4
- import { I as ICONS_TO_SOURCE } from './icons-6ed3416f.js';
5
- import { a as TYPE_TO_IMG_SRC, c as TYPE_TO_WALLET_COLOR } from './index-09573aa0.js';
6
-
7
- const RoundedSquare = ({
8
- title = "Currencies",
9
- description = "Lorem ipsum sit dalor amet",
10
- iconSrc = ICONS_TO_SOURCE[Icons.trophyIcon],
11
- imgSrc,
12
- type = WalletCategoryTypes.achievements,
13
- count = "28",
14
- onClick = () => {
15
- },
16
- bgColor,
17
- iconCircleClass = "",
18
- loading,
19
- containerClass = ""
20
- }) => {
21
- const imgSource = imgSrc || TYPE_TO_IMG_SRC[type];
22
- const backgroundColor = bgColor != null ? bgColor : `bg-${TYPE_TO_WALLET_COLOR[type]}`;
23
- const circleClass = `flex w-full justify-end icon-display absolute right-[15px] bottom-[10px] max-h-[40px] max-w-[40px] rounded-full`;
24
- const iconAltDescription = `${title} Icon`;
25
- return /* @__PURE__ */ React.createElement("button", {
26
- onClick,
27
- className: `flex relative ${backgroundColor} py-[15px] px-[15px] w-[170px] h-[170px] rounded-[40px] rounded-square-card-container ${containerClass}`
28
- }, /* @__PURE__ */ React.createElement("div", {
29
- className: "w-full relative"
30
- }, /* @__PURE__ */ React.createElement("section", {
31
- className: "title-headline-container flex items-center"
32
- }, /* @__PURE__ */ React.createElement("h3", {
33
- className: "line-clamp-2 font-bold text-[13px] text-grayscale-900 ml-[5px]"
34
- }, title)), /* @__PURE__ */ React.createElement("div", {
35
- className: "graphic-background relative flex justify-center"
36
- }, /* @__PURE__ */ React.createElement("img", {
37
- alt: iconAltDescription,
38
- className: "max-w-[130px]",
39
- src: imgSource
40
- }))), /* @__PURE__ */ React.createElement("div", {
41
- className: `${circleClass}`
42
- }, /* @__PURE__ */ React.createElement(CircleIcon, {
43
- iconCircleClass,
44
- iconSrc,
45
- count,
46
- size: "40",
47
- loading
48
- })));
49
- };
50
-
51
- export { RoundedSquare as R };
52
- //# sourceMappingURL=RoundedSquare-0d25f9ef.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"RoundedSquare-0d25f9ef.js","sources":["../../src/components/RoundedSquare/RoundedSquare.tsx"],"sourcesContent":["import React from 'react';\n\nimport CircleIcon from '../CircleIcon/CircleIcon';\nimport { Icons, WalletCategoryTypes } from '../../types';\nimport { ICONS_TO_SOURCE } from '../../constants/icons';\nimport { TYPE_TO_IMG_SRC, TYPE_TO_WALLET_COLOR } from '../../constants';\n\nexport type RoundedSquareProps = {\n title?: string;\n description?: string;\n type?: WalletCategoryTypes;\n iconSrc?: string;\n imgSrc?: string;\n count?: string | number;\n onClick?: () => void;\n bgColor?: string;\n iconCircleClass?: string;\n loading?: boolean;\n containerClass?: string;\n};\n\nexport const RoundedSquare: React.FC<RoundedSquareProps> = ({\n title = 'Currencies',\n description = 'Lorem ipsum sit dalor amet',\n iconSrc = ICONS_TO_SOURCE[Icons.trophyIcon],\n imgSrc,\n type = WalletCategoryTypes.achievements,\n count = '28',\n onClick = () => {},\n bgColor,\n iconCircleClass = '',\n loading,\n containerClass = '',\n}) => {\n const imgSource = imgSrc || TYPE_TO_IMG_SRC[type];\n const backgroundColor = bgColor ?? `bg-${TYPE_TO_WALLET_COLOR[type]}`;\n const circleClass = `flex w-full justify-end icon-display absolute right-[15px] bottom-[10px] max-h-[40px] max-w-[40px] rounded-full`;\n const iconAltDescription = `${title} Icon`;\n return (\n <button\n onClick={onClick}\n className={`flex relative ${backgroundColor} py-[15px] px-[15px] w-[170px] h-[170px] rounded-[40px] rounded-square-card-container ${containerClass}`}\n >\n <div className=\"w-full relative\">\n <section className=\"title-headline-container flex items-center\">\n <h3 className=\"line-clamp-2 font-bold text-[13px] text-grayscale-900 ml-[5px]\">\n {title}\n </h3>\n </section>\n\n <div className=\"graphic-background relative flex justify-center\">\n <img alt={iconAltDescription} className=\"max-w-[130px]\" src={imgSource} />\n </div>\n </div>\n\n <div className={`${circleClass}`}>\n <CircleIcon\n iconCircleClass={iconCircleClass}\n iconSrc={iconSrc}\n count={count}\n size=\"40\"\n loading={loading}\n />\n </div>\n </button>\n );\n};\n\nexport default RoundedSquare;\n"],"names":[],"mappings":";;;;;;AAKY,MAAC,aAAa,GAAG,CAAC;AAC9B,EAAE,KAAK,GAAG,YAAY;AACtB,EAAE,WAAW,GAAG,4BAA4B;AAC5C,EAAE,OAAO,GAAG,eAAe,CAAC,KAAK,CAAC,UAAU,CAAC;AAC7C,EAAE,MAAM;AACR,EAAE,IAAI,GAAG,mBAAmB,CAAC,YAAY;AACzC,EAAE,KAAK,GAAG,IAAI;AACd,EAAE,OAAO,GAAG,MAAM;AAClB,GAAG;AACH,EAAE,OAAO;AACT,EAAE,eAAe,GAAG,EAAE;AACtB,EAAE,OAAO;AACT,EAAE,cAAc,GAAG,EAAE;AACrB,CAAC,KAAK;AACN,EAAE,MAAM,SAAS,GAAG,MAAM,IAAI,eAAe,CAAC,IAAI,CAAC,CAAC;AACpD,EAAE,MAAM,eAAe,GAAG,OAAO,IAAI,IAAI,GAAG,OAAO,GAAG,CAAC,GAAG,EAAE,oBAAoB,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;AACzF,EAAE,MAAM,WAAW,GAAG,CAAC,+GAA+G,CAAC,CAAC;AACxI,EAAE,MAAM,kBAAkB,GAAG,CAAC,EAAE,KAAK,CAAC,KAAK,CAAC,CAAC;AAC7C,EAAE,uBAAuB,KAAK,CAAC,aAAa,CAAC,QAAQ,EAAE;AACvD,IAAI,OAAO;AACX,IAAI,SAAS,EAAE,CAAC,cAAc,EAAE,eAAe,CAAC,sFAAsF,EAAE,cAAc,CAAC,CAAC;AACxJ,GAAG,kBAAkB,KAAK,CAAC,aAAa,CAAC,KAAK,EAAE;AAChD,IAAI,SAAS,EAAE,iBAAiB;AAChC,GAAG,kBAAkB,KAAK,CAAC,aAAa,CAAC,SAAS,EAAE;AACpD,IAAI,SAAS,EAAE,4CAA4C;AAC3D,GAAG,kBAAkB,KAAK,CAAC,aAAa,CAAC,IAAI,EAAE;AAC/C,IAAI,SAAS,EAAE,gEAAgE;AAC/E,GAAG,EAAE,KAAK,CAAC,CAAC,kBAAkB,KAAK,CAAC,aAAa,CAAC,KAAK,EAAE;AACzD,IAAI,SAAS,EAAE,iDAAiD;AAChE,GAAG,kBAAkB,KAAK,CAAC,aAAa,CAAC,KAAK,EAAE;AAChD,IAAI,GAAG,EAAE,kBAAkB;AAC3B,IAAI,SAAS,EAAE,eAAe;AAC9B,IAAI,GAAG,EAAE,SAAS;AAClB,GAAG,CAAC,CAAC,CAAC,kBAAkB,KAAK,CAAC,aAAa,CAAC,KAAK,EAAE;AACnD,IAAI,SAAS,EAAE,CAAC,EAAE,WAAW,CAAC,CAAC;AAC/B,GAAG,kBAAkB,KAAK,CAAC,aAAa,CAAC,UAAU,EAAE;AACrD,IAAI,eAAe;AACnB,IAAI,OAAO;AACX,IAAI,KAAK;AACT,IAAI,IAAI,EAAE,IAAI;AACd,IAAI,OAAO;AACX,GAAG,CAAC,CAAC,CAAC,CAAC;AACP;;;;"}
@@ -1,62 +0,0 @@
1
- import React from 'react';
2
- import { r as reactBarcode } from './react-barcode-150610c2.js';
3
-
4
- const SchoolIDCard = ({
5
- userImage,
6
- userName,
7
- text = null,
8
- extraText,
9
- subjectInitials,
10
- subjectInitialsClass,
11
- showBarcode = true,
12
- backgroundImage,
13
- className,
14
- containerClassName
15
- }) => {
16
- let textEl = null;
17
- if (typeof text === "string") {
18
- textEl = /* @__PURE__ */ React.createElement("h3", {
19
- className: "text-xs font-bold uppercase text-black"
20
- }, text);
21
- } else {
22
- textEl = text;
23
- }
24
- let issueeImageEl = null;
25
- const initialsClass = `subject-initials h-[70px] w-[70px] rounded-full mr-[10px] flex flex-row items-center justify-center h-full w-full overflow-hidden bg-emerald-700 text-white font-medium text-3xl ${subjectInitialsClass}`;
26
- if (userImage && (userImage == null ? void 0 : userImage.trim()) !== "") {
27
- issueeImageEl = /* @__PURE__ */ React.createElement("div", {
28
- className: "h-[80px] w-[80px] rounded-full overflow-hidden bg-no-repeat bg-cover bg-center border-solid border-[2px] border-white mr-2",
29
- style: { backgroundImage: `url(${userImage})` }
30
- });
31
- } else if (subjectInitials && (!userImage || (userImage == null ? void 0 : userImage.trim()) === "")) {
32
- issueeImageEl = /* @__PURE__ */ React.createElement("div", {
33
- className: initialsClass
34
- }, subjectInitials);
35
- }
36
- return /* @__PURE__ */ React.createElement("div", {
37
- style: { backgroundImage: `url(${backgroundImage})` },
38
- className: `h-[200px] w-[320px] rounded-[20px] overflow-hidden ${className}`
39
- }, /* @__PURE__ */ React.createElement("div", {
40
- className: `h-full w-full flex items-center justify-start relative ${containerClassName}`
41
- }, /* @__PURE__ */ React.createElement("div", {
42
- className: "w-full flex justify-start items-center pl-3 mt-10"
43
- }, issueeImageEl, /* @__PURE__ */ React.createElement("div", {
44
- className: "h-full flex items-start justify-center flex-col mt-7"
45
- }, userName && /* @__PURE__ */ React.createElement("p", {
46
- className: "text-sm text-black font-light"
47
- }, userName), textEl && textEl)), showBarcode && /* @__PURE__ */ React.createElement("div", {
48
- className: "barcode-container"
49
- }, /* @__PURE__ */ React.createElement("div", {
50
- className: "barcode-wrap"
51
- }, /* @__PURE__ */ React.createElement(reactBarcode, {
52
- value: "barcode-example",
53
- height: "22px",
54
- width: "1px",
55
- fontSize: 0
56
- }))), extraText && /* @__PURE__ */ React.createElement("div", null, /* @__PURE__ */ React.createElement("p", {
57
- className: "absolute bottom-3 left-0 w-full flex items-center justify-center text-white text-xs font-semibold"
58
- }, extraText))));
59
- };
60
-
61
- export { SchoolIDCard as S };
62
- //# sourceMappingURL=SchoolIDCard-91bade9a.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"SchoolIDCard-91bade9a.js","sources":["../../src/components/SchoolIdCard/SchoolIDCard.tsx"],"sourcesContent":["import React from 'react';\n\nimport Barcode from 'react-barcode';\n\nimport { SchoolIDCardProps } from './types';\n\nexport const SchoolIDCard: React.FC<SchoolIDCardProps> = ({\n userImage,\n userName,\n text = null,\n extraText,\n subjectInitials,\n subjectInitialsClass,\n showBarcode = true,\n backgroundImage,\n className,\n containerClassName,\n}) => {\n let textEl: React.ReactNode | null = null;\n if (typeof text === 'string') {\n textEl = <h3 className=\"text-xs font-bold uppercase text-black\">{text}</h3>;\n } else {\n textEl = text;\n }\n\n let issueeImageEl: React.ReactNode | null = null;\n const initialsClass = `subject-initials h-[70px] w-[70px] rounded-full mr-[10px] flex flex-row items-center justify-center h-full w-full overflow-hidden bg-emerald-700 text-white font-medium text-3xl ${subjectInitialsClass}`;\n\n if (userImage && userImage?.trim() !== '') {\n issueeImageEl = (\n <div\n className=\"h-[80px] w-[80px] rounded-full overflow-hidden bg-no-repeat bg-cover bg-center border-solid border-[2px] border-white mr-2\"\n style={{ backgroundImage: `url(${userImage})` }}\n />\n );\n } else if (subjectInitials && (!userImage || userImage?.trim() === '')) {\n issueeImageEl = <div className={initialsClass}>{subjectInitials}</div>;\n }\n\n return (\n <div\n style={{ backgroundImage: `url(${backgroundImage})` }}\n className={`h-[200px] w-[320px] rounded-[20px] overflow-hidden ${className}`}\n >\n <div\n className={`h-full w-full flex items-center justify-start relative ${containerClassName}`}\n >\n <div className=\"w-full flex justify-start items-center pl-3 mt-10\">\n {issueeImageEl}\n <div className=\"h-full flex items-start justify-center flex-col mt-7\">\n {userName && <p className=\"text-sm text-black font-light\">{userName}</p>}\n {textEl && textEl}\n </div>\n </div>\n\n {showBarcode && (\n <div className=\"barcode-container\">\n <div className=\"barcode-wrap\">\n <Barcode\n value=\"barcode-example\"\n height=\"22px\"\n width=\"1px\"\n fontSize={0}\n />\n </div>\n </div>\n )}\n\n {extraText && (\n <div>\n <p className=\"absolute bottom-3 left-0 w-full flex items-center justify-center text-white text-xs font-semibold\">\n {extraText}\n </p>\n </div>\n )}\n </div>\n </div>\n );\n};\n\nexport default SchoolIDCard;\n"],"names":["Barcode"],"mappings":"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"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"User-9f253521.js","sources":["../../src/components/svgs/Briefcase.tsx","../../src/components/svgs/Coins.tsx","../../src/components/svgs/Graduation.tsx","../../src/components/svgs/User.tsx"],"sourcesContent":["import React from 'react';\n\nexport const Briefcase: React.FC<{ className?: string; size?: string }> = ({\n className = '',\n size = '',\n}) => {\n return (\n <svg\n height={size}\n width={size}\n viewBox=\"0 0 31 31\"\n fill=\"none\"\n className={className}\n data-testid=\"job-icon\"\n >\n <path\n d=\"M25.8135 8.9375H5.18848C4.67071 8.9375 4.25098 9.35723 4.25098 9.875V24.875C4.25098 25.3928 4.67071 25.8125 5.18848 25.8125H25.8135C26.3312 25.8125 26.751 25.3928 26.751 24.875V9.875C26.751 9.35723 26.3312 8.9375 25.8135 8.9375Z\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n <path\n d=\"M20.1875 8.9375V7.0625C20.1875 6.56522 19.99 6.08831 19.6383 5.73667C19.2867 5.38504 18.8098 5.1875 18.3125 5.1875H12.6875C12.1902 5.1875 11.7133 5.38504 11.3617 5.73667C11.01 6.08831 10.8125 6.56522 10.8125 7.0625V8.9375\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n <path\n d=\"M26.7509 15.3018C23.3317 17.2799 19.4502 18.3186 15.5 18.3124C11.5504 18.3186 7.66951 17.2803 4.25073 15.3027\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n <path\n d=\"M14.0938 14.5625H16.9062\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n );\n};\n\nexport default Briefcase;\n","import React from 'react';\n\nexport const Coins: React.FC<{ className?: string }> = ({ className = '' }) => {\n return (\n <svg viewBox=\"0 0 31 30\" fill=\"none\" className={className} data-testid=\"currency-icon\">\n <path\n d=\"M5.74324 21.5007C5.74324 21.0133 5.7219 20.5247 5.75357 20.0393C5.76624 19.8405 5.69757 19.7748 5.5449 19.691C4.93921 19.3584 4.38253 18.9628 3.96552 18.4038C3.66551 18.0003 3.49884 17.5566 3.50651 17.0456C3.51951 16.3066 3.53684 15.5668 3.50384 14.8281C3.44817 13.5639 4.00019 12.6165 4.98621 11.8722C5.86691 11.2064 6.8716 10.7934 7.92363 10.4785C8.09863 10.426 8.27497 10.3763 8.45331 10.3379C8.57498 10.3116 8.62331 10.2617 8.61998 10.1305C8.60965 9.75296 8.63365 9.37472 8.61331 8.99714C8.54665 7.7461 9.10833 6.80822 10.08 6.06785C11.0004 5.3656 12.0524 4.9384 13.1578 4.62424C14.4715 4.25126 15.8152 4.06887 17.1789 4.01827C19.3693 3.93546 21.5263 4.12244 23.6157 4.82141C24.6491 5.16678 25.6191 5.63079 26.4271 6.37215C26.9858 6.88446 27.3985 7.48715 27.4855 8.2548C27.5165 8.52952 27.4882 8.81082 27.4882 9.08915C27.4882 9.78451 27.4678 10.4808 27.4938 11.1752C27.5198 11.8696 27.2418 12.4272 26.7628 12.9083C26.1245 13.5482 25.3488 13.9846 24.5114 14.3076C23.8574 14.5603 23.1787 14.7519 22.5077 14.9612C22.4077 14.9941 22.3744 15.0269 22.3764 15.1255C22.38 15.7331 22.3814 16.3414 22.3764 16.9487C22.3764 17.0502 22.4227 17.0936 22.4987 17.138C23.0954 17.487 23.6401 17.8981 24.0544 18.4557C24.4687 19.0134 24.6651 19.6328 24.6211 20.3446C24.5776 21.0938 24.5776 21.8448 24.6211 22.594C24.6681 23.4527 24.2931 24.0922 23.6734 24.6314C22.8684 25.3324 21.9133 25.7665 20.912 26.1102C19.3756 26.636 17.7872 26.9038 16.1662 26.9761C13.7541 27.0832 11.3881 26.842 9.10766 26.0139C8.2223 25.6925 7.38695 25.2762 6.68159 24.6436C6.22025 24.2298 5.85157 23.7517 5.76557 23.1234C5.72657 22.8378 5.74757 22.5444 5.74457 22.2545C5.74124 22.0031 5.74324 21.7514 5.74324 21.5007ZM18.4032 11.724C18.7839 11.6964 19.4996 11.6626 20.211 11.5896C21.4303 11.4647 22.6187 11.2002 23.7537 10.7326C24.4177 10.4588 25.0468 10.1246 25.5581 9.61001C26.2311 8.93273 26.2435 8.25151 25.5914 7.55681C25.1814 7.11942 24.6731 6.81775 24.1337 6.56603C22.829 5.95711 21.439 5.66135 20.0153 5.5138C18.4017 5.34176 16.7719 5.38453 15.1698 5.64098C14.0031 5.8296 12.8698 6.12733 11.8127 6.66166C11.2554 6.94329 10.7344 7.2765 10.357 7.78455C9.97968 8.29259 9.97002 8.81279 10.3384 9.3182C10.4419 9.46061 10.5594 9.59269 10.689 9.71254C11.2801 10.2561 11.9924 10.5975 12.7408 10.8703C14.4585 11.4973 16.2485 11.7003 18.4032 11.724ZM20.4366 15.3789L20.414 15.346C20.383 15.346 20.3516 15.3437 20.321 15.346C19.8843 15.3828 19.4483 15.4344 19.0109 15.4558C17.691 15.5233 16.3676 15.4589 15.0608 15.2635C13.7458 15.0641 12.4634 14.746 11.2517 14.1886C10.538 13.86 9.87068 13.4657 9.32667 12.8909C9.0155 12.5718 8.78903 12.1819 8.66731 11.7559C7.61929 12.049 6.60993 12.398 5.76424 13.0789C5.51156 13.2823 5.29389 13.5445 5.11455 13.815C4.88121 14.166 4.88455 14.5659 5.11055 14.9201C5.27583 15.1847 5.47943 15.4241 5.7149 15.6306C6.42425 16.2356 7.27794 16.5787 8.1613 16.8531C9.56401 17.2885 11.007 17.4751 12.4728 17.5103C14.0675 17.5478 15.6448 17.4173 17.1899 17.0088C18.1592 16.7525 19.0923 16.4084 19.9113 15.8182C20.0966 15.6842 20.2626 15.5258 20.4373 15.3789H20.4366ZM7.29461 20.4586C7.40895 20.7787 7.60295 21.0173 7.83063 21.2269C8.43064 21.7803 9.15066 22.1267 9.91002 22.4034C11.2434 22.8891 12.6291 23.1181 14.0435 23.199C15.7262 23.2949 17.3949 23.2013 19.0409 22.8266C20.018 22.6042 20.963 22.2936 21.8283 21.7813C22.2697 21.5201 22.6754 21.2158 22.9617 20.784C23.2617 20.3305 23.2767 19.8721 22.966 19.4166C22.688 19.0091 22.3034 18.7189 21.885 18.461C21.7667 18.5839 21.6613 18.7038 21.545 18.8123C20.9983 19.3229 20.3593 19.6946 19.6783 19.9976C17.9616 20.76 16.1449 21.1149 14.2781 21.2407C12.3391 21.3722 10.4177 21.2361 8.52398 20.7882C8.12163 20.6929 7.72429 20.5746 7.29461 20.4586ZM4.96121 16.881C4.89655 17.1863 4.97921 17.4396 5.17855 17.6605C5.58123 18.109 6.09558 18.4012 6.63459 18.6519C7.87596 19.2293 9.193 19.5428 10.5484 19.7146C12.6548 19.9818 14.7485 19.9167 16.8192 19.4416C17.8936 19.1951 18.9309 18.8445 19.8826 18.2812C20.226 18.0778 20.552 17.8511 20.8016 17.5323C20.9523 17.3397 20.962 17.1284 20.9296 16.8869C20.8823 16.9198 20.8503 16.9388 20.82 16.9608C20.3244 17.3134 19.7888 17.6076 19.2239 17.8376C17.7926 18.4314 16.2905 18.7298 14.7505 18.8563C12.7354 19.0223 10.7344 18.9394 8.75832 18.4883C7.41828 18.182 6.14158 17.7245 5.02255 16.9076C5.00326 16.8968 4.98294 16.8879 4.96188 16.881H4.96121ZM7.19161 22.6084C7.12494 22.9259 7.21994 23.1934 7.44361 23.408C7.62294 23.5866 7.81755 23.7497 8.0253 23.8953C8.84165 24.4444 9.75534 24.7826 10.7034 25.0271C13.489 25.7413 16.2851 25.7817 19.0916 25.1483C20.172 24.9055 21.2117 24.5443 22.1637 23.9699C22.491 23.7727 22.8014 23.5526 23.0384 23.247C23.187 23.0544 23.198 22.8444 23.1614 22.6127C21.9353 23.3685 21.5397 23.5657 20.6783 23.8496C18.8153 24.4618 16.8945 24.6712 14.9398 24.6501C13.7685 24.6438 12.6005 24.5287 11.4511 24.3064C10.3204 24.083 9.224 23.7553 8.2043 23.2147C7.85963 23.032 7.53395 22.8151 7.19227 22.6084H7.19161ZM26.0291 11.094C25.9941 11.1164 25.9661 11.1315 25.9408 11.1499C25.3891 11.5538 24.7841 11.8624 24.1487 12.1118C22.4047 12.796 20.5786 13.0648 18.7153 13.1242C17.3384 13.1742 15.9601 13.0782 14.6041 12.8377C13.3871 12.6175 12.2064 12.2827 11.1087 11.7079C10.7534 11.5212 10.4184 11.2975 10.0707 11.0888C9.99768 11.4121 10.115 11.6777 10.3404 11.9136C10.6574 12.2445 11.038 12.4894 11.4427 12.6974C12.8714 13.4308 14.4128 13.7782 15.9992 13.953C17.3296 14.1019 18.6727 14.1045 20.0036 13.9606C21.2887 13.8212 22.5427 13.5534 23.7457 13.0789C24.4491 12.8012 25.1258 12.4755 25.6948 11.9682C25.9508 11.7408 26.1228 11.4779 26.0291 11.094Z\"\n fill=\"currentColor\"\n />\n </svg>\n );\n};\n\nexport default Coins;\n","import React from 'react';\n\nexport const Graduation: React.FC<{ className?: string; size?: string }> = ({\n className = '',\n size = '',\n}) => {\n return (\n <svg\n height={size}\n width={size}\n viewBox=\"0 0 31 31\"\n fill=\"none\"\n className={className}\n data-testid=\"learning-icon\"\n >\n <path\n d=\"M27.3626 13.2376L26.1126 12.5501L14.8626 6.3001H14.7251C14.6485 6.2677 14.5689 6.24259 14.4876 6.2251H14.2501H14.0251C13.9397 6.2426 13.856 6.2677 13.7751 6.3001H13.6376L2.38759 12.5501C2.19522 12.6591 2.03521 12.8172 1.92388 13.0083C1.81256 13.1993 1.75391 13.4165 1.75391 13.6376C1.75391 13.8587 1.81256 14.0759 1.92388 14.2669C2.03521 14.458 2.19522 14.6161 2.38759 14.7251L5.50009 16.4501V22.3751C5.50009 23.3697 5.89518 24.3235 6.59844 25.0267C7.3017 25.73 8.25553 26.1251 9.25009 26.1251H19.2501C20.2447 26.1251 21.1985 25.73 21.9017 25.0267C22.605 24.3235 23.0001 23.3697 23.0001 22.3751V16.4501L25.5001 15.0501V18.6251C25.5001 18.9566 25.6318 19.2746 25.8662 19.509C26.1006 19.7434 26.4186 19.8751 26.7501 19.8751C27.0816 19.8751 27.3996 19.7434 27.634 19.509C27.8684 19.2746 28.0001 18.9566 28.0001 18.6251V14.3251C27.9997 14.1036 27.9405 13.8862 27.8285 13.6951C27.7165 13.504 27.5557 13.3461 27.3626 13.2376V13.2376ZM20.5001 22.3751C20.5001 22.7066 20.3684 23.0246 20.134 23.259C19.8996 23.4934 19.5816 23.6251 19.2501 23.6251H9.25009C8.91857 23.6251 8.60063 23.4934 8.36621 23.259C8.13179 23.0246 8.00009 22.7066 8.00009 22.3751V17.8376L13.6376 20.9626L13.8251 21.0376H13.9376C14.0413 21.0507 14.1463 21.0507 14.2501 21.0376C14.3538 21.0507 14.4588 21.0507 14.5626 21.0376H14.6751C14.7415 21.0236 14.8049 20.9982 14.8626 20.9626L20.5001 17.8376V22.3751ZM14.2501 18.4501L5.57509 13.6251L14.2501 8.8001L22.9251 13.6251L14.2501 18.4501Z\"\n fill=\"currentColor\"\n />\n </svg>\n );\n};\n\nexport default Graduation;\n","import React from 'react';\n\nexport const User: React.FC<{ className?: string; size?: string }> = ({\n className = '',\n size = '',\n}) => {\n return (\n <svg\n height={size}\n width={size}\n viewBox=\"0 0 31 31\"\n fill=\"none\"\n className={className}\n data-testid=\"id-icon\"\n >\n <path\n d=\"M15.5 19.25C19.6421 19.25 23 15.8921 23 11.75C23 7.60786 19.6421 4.25 15.5 4.25C11.3579 4.25 8 7.60786 8 11.75C8 15.8921 11.3579 19.25 15.5 19.25Z\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n <path\n d=\"M4.13159 25.8114C5.2842 23.8164 6.94153 22.1598 8.93708 21.008C10.9326 19.8563 13.1961 19.25 15.5002 19.25C17.8043 19.25 20.0678 19.8564 22.0633 21.0082C24.0588 22.1599 25.7161 23.8166 26.8687 25.8116\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n );\n};\n\nexport default User;\n"],"names":[],"mappings":"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"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"VCDisplayCard2-e2e1d9f1.js","sources":["../../src/components/svgs/RoundedX.tsx","../../src/components/VCDisplayCard2/FitText.tsx","../../src/components/VCDisplayCard2/InfoBox.tsx","../../src/components/VCDisplayCard2/IssueHistoryBox.tsx","../../src/components/VCDisplayCard2/MediaAttachmentsBox.tsx","../../src/components/VCDisplayCard2/RibbonEnd.tsx","../../src/components/VCDisplayCard2/TruncateTextBox.tsx","../../src/components/VCDisplayCard2/VerificationRow.tsx","../../src/components/VCDisplayCard2/VerificationsBox.tsx","../../src/components/VCDisplayCard2/VC2BackFace.tsx","../../src/components/VCDisplayCard2/VC2FrontFaceInfo.tsx","../../src/components/VCDisplayCard2/VCDisplayCardCategoryType.tsx","../../src/components/VCDisplayCard2/VCIDDisplayFrontFace.tsx","../../src/components/VCDisplayCard2/VCIDDIsplayCard.tsx","../../src/components/VCDisplayCard2/VCDisplayCard2.tsx"],"sourcesContent":["import React from 'react';\n\ntype RoundedXProps = {\n className?: string;\n};\n\nconst RoundedX: React.FC<RoundedXProps> = ({ className = '' }) => {\n return (\n <svg\n width=\"24\"\n height=\"24\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n className={className}\n >\n <path\n d=\"M18.75 5.25L5.25 18.75\"\n stroke=\"#18224E\"\n strokeWidth=\"4\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n <path\n d=\"M18.75 18.75L5.25 5.25\"\n stroke=\"#18224E\"\n strokeWidth=\"4\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n );\n};\n\nexport default RoundedX;\n","import React, { useEffect, useRef } from 'react';\n\ninterface FitTextProps {\n text: string;\n width: string;\n className?: string;\n minFontSize?: number;\n maxFontSize?: number;\n}\n\nconst FitText: React.FC<FitTextProps> = ({\n text,\n width,\n className = '',\n minFontSize = 10,\n maxFontSize = 100,\n}) => {\n const textRef = useRef<HTMLDivElement>(null);\n let animationFrameId: number | null = null;\n\n const adjustFontSize = () => {\n if (textRef.current) {\n const currentFontSize = parseFloat(\n window.getComputedStyle(textRef.current).getPropertyValue('font-size')\n );\n\n // Need to calculate spacing based on nowrap to prevent thrashing\n textRef.current.style.whiteSpace = 'nowrap';\n const parentWidth = (textRef.current.parentNode as any)?.clientWidth;\n const scrollWidth = textRef.current.scrollWidth || textRef.current.offsetWidth;\n\n // Sometimes scrollWidth can temporarily be 0. If so, just try again next frame\n if (scrollWidth === 0) {\n if (animationFrameId !== null) {\n cancelAnimationFrame(animationFrameId);\n }\n\n animationFrameId = requestAnimationFrame(adjustFontSize);\n\n return;\n }\n\n const newFontSize = Math.min(\n Math.max((parentWidth / scrollWidth) * currentFontSize, minFontSize),\n maxFontSize\n );\n\n textRef.current.style.fontSize = `${newFontSize}px`;\n textRef.current.style.whiteSpace = newFontSize === minFontSize ? 'normal' : 'nowrap';\n }\n };\n\n const handleResize = () => {\n if (animationFrameId !== null) {\n cancelAnimationFrame(animationFrameId);\n }\n\n animationFrameId = requestAnimationFrame(adjustFontSize);\n };\n\n useEffect(() => {\n window.addEventListener('resize', handleResize);\n adjustFontSize();\n\n return () => {\n window.removeEventListener('resize', handleResize);\n if (animationFrameId !== null) {\n cancelAnimationFrame(animationFrameId);\n }\n };\n }, [text]);\n\n return (\n <div style={{ width }} className={`text-center ${className}`}>\n <span\n className={`text-[${minFontSize}px] transition-[font-size] whitespace-nowrap`}\n ref={textRef}\n >\n {text}\n </span>\n </div>\n );\n};\n\nexport default FitText;\n","import React from 'react';\n\ntype InfoBoxProps = {\n text: string;\n handleClose: () => void;\n backgroundColor?: string;\n};\n\nconst InfoBox: React.FC<InfoBoxProps> = ({ text, handleClose, backgroundColor = '#6366F1' }) => {\n const bgColorWithOpacity = `${backgroundColor}1F`; // 12% opacity\n return (\n <div\n className=\"info-box p-[10px] rounded-[10px] w-full font-poppins text-[12px] leading[18px]\"\n style={{ backgroundColor: bgColorWithOpacity }}\n >\n {text}{' '}\n <button onClick={handleClose} className=\"text-indigo-500 font-[700] select-none\">\n Close\n </button>\n </div>\n );\n};\n\nexport default InfoBox;\n","import React, { useState } from 'react';\nimport DefaultFace from '../../assets/images/default-face.jpeg';\n\nimport { IssueHistory } from '../../types';\n\ntype SkillsBoxProps = {\n issueHistory: IssueHistory[];\n customIssueHistoryComponent?: React.ReactNode;\n};\n\nconst IssueHistoryBox: React.FC<SkillsBoxProps> = ({\n issueHistory,\n customIssueHistoryComponent,\n}) => {\n let renderIssueHistory = issueHistory?.map(issueItem => {\n return (\n <div\n className=\"flex items-center issue-log-item border-b-[1px] py-[5px] border-grayscale-200 border-solid w-full\"\n key={issueItem?.id}\n >\n <div className=\"profile-thumb-img vc-issuee-image h-[35px] w-[35px] rounded-full overflow-hidden\">\n <img\n className=\"h-full w-full object-cover select-none\"\n src={issueItem?.thumb || DefaultFace}\n alt=\"profile\"\n />\n </div>\n <div className=\"ml-[9px] flex flex-col justify-center\">\n <p className=\"issue-item-name font-montserrat font-semibold text-grayscale-900 text-[14px] \">\n {issueItem?.name}\n </p>\n <p className=\"issue-item-date font-montserrat text-[12px] text-grayscale-600 \">\n {issueItem?.date}\n </p>\n </div>\n </div>\n );\n });\n\n return (\n <div className=\"bg-white flex flex-col items-start gap-[10px] rounded-[20px] shadow-bottom px-[15px] py-[20px] w-full relative\">\n <h3 className=\"text-[20px] leading-[20px] text-grayscale-900\">Issue Log</h3>\n {!customIssueHistoryComponent ? renderIssueHistory : customIssueHistoryComponent}\n </div>\n );\n};\n\nexport default IssueHistoryBox;\n","import React, { useEffect, useState } from 'react';\nimport prettyBytes from 'pretty-bytes';\n\nimport Camera from '../svgs/Camera';\nimport LinkIcon from '../svgs/LinkIcon';\nimport VideoIcon from '../svgs/VideoIcon';\nimport GenericDocumentIcon from '../svgs/GenericDocumentIcon';\n\nimport { Attachment, MediaMetadata, VideoMetadata } from '../../types';\nimport { getBaseUrl } from '../../helpers/url.helpers';\nimport { Lightbox, LightboxItem } from '../Lightbox';\n\ntype MediaAttachmentsBoxProps = {\n attachments: Attachment[];\n getFileMetadata?: (url: string) => MediaMetadata;\n getVideoMetadata?: (url: string) => VideoMetadata;\n onMediaAttachmentClick?: (url: string, type: 'photo' | 'document' | 'video' | 'link') => void;\n enableLightbox?: boolean;\n};\n\nconst defaultGetFileMetadata = async (url: string) => {\n const isFilestack = url.includes('filestack');\n if (!isFilestack) return;\n\n const urlParams = url.split('.com/')[1]?.split('/');\n if (!urlParams) return;\n const handle = urlParams[urlParams.length - 1];\n\n let fetchFailed = false;\n const data = await fetch(`https://cdn.filestackcontent.com/${handle}/metadata`)\n .then(res => res.json())\n .catch(() => (fetchFailed = true));\n\n if (fetchFailed) return;\n\n const fileExtension = data.filename.split('.')[1];\n\n return {\n fileExtension,\n sizeInBytes: data.size,\n numberOfPages: undefined,\n };\n};\n\nconst defaultGetVideoMetadata = async (url: string) => {\n const isYoutube = url.includes('youtube');\n if (!isYoutube) return;\n\n const metadataUrl = `http://youtube.com/oembed?url=${url}&format=json`;\n\n let fetchFailed = false;\n const metadata = await fetch(metadataUrl)\n .then(res => res.json())\n .catch(() => (fetchFailed = true));\n\n if (fetchFailed) return;\n\n return {\n title: metadata.title,\n imageUrl: metadata.thumbnail_url,\n videoLength: '', // TODO figure out how to get this\n };\n};\n\nconst MediaAttachmentsBox: React.FC<MediaAttachmentsBoxProps> = ({\n attachments,\n getFileMetadata = defaultGetFileMetadata,\n getVideoMetadata = defaultGetVideoMetadata,\n onMediaAttachmentClick,\n enableLightbox = false,\n}) => {\n const [documentMetadata, setDocumentMetadata] = useState<{\n [documentUrl: string]: MediaMetadata | undefined;\n }>({});\n const [videoMetadata, setVideoMetadata] = useState<{\n [videoUrl: string]: VideoMetadata | undefined;\n }>({});\n\n const mediaAttachments: Attachment[] = [];\n const documentsAndLinks: Attachment[] = [];\n attachments.forEach(a => {\n switch (a.type) {\n case 'document':\n case 'link':\n documentsAndLinks.push(a);\n break;\n case 'photo':\n case 'video':\n mediaAttachments.push(a);\n break;\n default:\n break;\n }\n });\n\n useEffect(() => {\n const getMetadata = async (attachments: Attachment[]): Promise<any> => {\n const docMetadata: { [docUrl: string]: MediaMetadata | undefined } = {};\n const videoMetadata: { [videoUrl: string]: VideoMetadata | undefined } = {};\n await Promise.all(\n attachments.map(async attachment => {\n if (attachment.type === 'document') {\n docMetadata[attachment.url] = await getFileMetadata(attachment.url);\n } else if (attachment.type === 'video') {\n videoMetadata[attachment.url] = await getVideoMetadata(attachment.url);\n }\n })\n );\n\n setVideoMetadata(videoMetadata);\n setDocumentMetadata(docMetadata);\n };\n\n const videos = attachments.filter(a => a.type === 'video');\n getMetadata([...documentsAndLinks, ...videos]);\n }, []);\n\n const [currentLightboxUrl, setCurrentLightboxUrl] = useState<string | undefined>(undefined);\n const lightboxItems = mediaAttachments.filter(\n a => a.type === 'photo' || a.type === 'video'\n ) as LightboxItem[];\n const handleMediaAttachmentClick = (\n url: string,\n type: 'photo' | 'document' | 'video' | 'link'\n ) => {\n if (type === 'photo' || type === 'video') {\n setCurrentLightboxUrl(url);\n }\n\n onMediaAttachmentClick?.(url, type);\n };\n\n return (\n <div className=\"media-attachments-box bg-white flex flex-col items-start gap-[10px] rounded-[20px] shadow-bottom px-[15px] py-[20px] w-full\">\n <h3 className=\"text-[20px] leading-[20px] text-grayscale-900\">Media Attachments</h3>\n {mediaAttachments.length > 0 && (\n <div className=\"flex gap-[5px] justify-between flex-wrap w-full\">\n {enableLightbox && (\n <Lightbox\n items={lightboxItems}\n currentUrl={currentLightboxUrl}\n setCurrentUrl={setCurrentLightboxUrl}\n />\n )}\n {mediaAttachments.map((media, index) => {\n let innerContent: React.ReactNode;\n let title = media.title;\n\n if (media.type === 'video') {\n const metadata = videoMetadata[media.url];\n title = (title || metadata?.title) ?? '';\n const baseUrl = getBaseUrl(media.url);\n const iconTop = title || baseUrl;\n\n innerContent = (\n <div\n className=\"absolute top-0 left-0 right-0 bottom-0 bg-cover bg-no-repeat font-poppins text-white text-[12px] font-[400] leading-[17px] flex flex-col justify-end items-start p-[10px] text-left bg-rose-600 rounded-[15px]\"\n style={{\n backgroundImage: metadata?.imageUrl\n ? `linear-gradient(180deg, rgba(0, 0, 0, 0) 44.20%, rgba(0, 0, 0, 0.6) 69%), url(${\n metadata?.imageUrl ?? ''\n })`\n : undefined,\n }}\n >\n {!metadata?.imageUrl && (\n <VideoIcon size=\"60\" className=\"m-auto\" />\n )}\n <div\n className={`absolute ${\n iconTop ? 'top-[10px]' : 'bottom-[10px]'\n } left-[10px] z-10 flex items-center gap-[5px]`}\n >\n {metadata?.imageUrl && <VideoIcon />}\n {metadata?.videoLength && (\n <span className=\"leading-[23px]\">\n {metadata.videoLength}\n </span>\n )}\n </div>\n {baseUrl && <span className=\"font-[600]\">{baseUrl}</span>}\n {title && <span className=\"line-clamp-2\">{title}</span>}\n </div>\n );\n } else {\n innerContent = (\n <div className=\"absolute top-0 left-0 right-0 bottom-0 h-min\">\n <img className=\"rounded-[15px]\" src={media.url} />\n <Camera className=\"relative bottom-[30px] left-[10px] z-10\" />\n </div>\n );\n }\n\n const className = `media-attachment ${media.type} w-[49%] pt-[49%] overflow-hidden relative`;\n\n if (onMediaAttachmentClick || enableLightbox) {\n return (\n <button\n key={index}\n className={className}\n onClick={() =>\n handleMediaAttachmentClick(media.url, media.type)\n }\n >\n {innerContent}\n </button>\n );\n }\n\n return (\n <div key={index} className={className}>\n {innerContent}\n </div>\n );\n })}\n </div>\n )}\n {documentsAndLinks.length > 0 && (\n <div className=\"w-full flex flex-col gap-[5px]\">\n {documentsAndLinks.map((docOrLink, index) => {\n const metadata =\n docOrLink.type === 'document'\n ? documentMetadata[docOrLink.url]\n : undefined;\n const { fileExtension, sizeInBytes, numberOfPages } = metadata ?? {};\n\n let baseUrl = '';\n if (docOrLink.type === 'link') {\n baseUrl = getBaseUrl(docOrLink.url);\n }\n\n const innerContent = (\n <div className=\"flex flex-col gap-[5px]\">\n <div className=\"flex gap-[5px] items-center\">\n {docOrLink.type === 'document' && (\n <GenericDocumentIcon className=\"shrink-0\" />\n )}\n {docOrLink.type === 'link' && <LinkIcon className=\"shrink-0\" />}\n <span className=\"text-grayscale-900 font-[400]\">\n {docOrLink.title ?? 'No title'}\n </span>\n </div>\n {docOrLink.type === 'document' && metadata && (\n <a\n href={docOrLink.url}\n target=\"_blank\"\n rel=\"noreferrer\"\n className=\"text-grayscale-600 font-[600] px-[5px] hover:underline\"\n >\n {fileExtension && (\n <span className=\"uppercase\">{fileExtension}</span>\n )}\n {fileExtension && (numberOfPages || sizeInBytes) && ' • '}\n {numberOfPages && (\n <span>\n {numberOfPages} page{numberOfPages === 1 ? '' : 's'}\n </span>\n )}\n {numberOfPages && sizeInBytes && ' • '}\n {sizeInBytes && <span>{prettyBytes(sizeInBytes)}</span>}\n </a>\n )}\n {docOrLink.type === 'link' && (\n <a\n href={docOrLink.url}\n target=\"_blank\"\n rel=\"noreferrer\"\n className=\"text-indigo-500 font-[600] px-[5px] hover:underline\"\n >\n {baseUrl}\n </a>\n )}\n </div>\n );\n\n const className = `row-attachment ${docOrLink.type} bg-grayscale-100 rounded-[15px] p-[10px] w-full font-poppins text-[12px] leading-[18px] tracking-[-0.33px] text-left`;\n\n if (onMediaAttachmentClick) {\n return (\n <button\n key={index}\n className={className}\n onClick={() =>\n handleMediaAttachmentClick(docOrLink.url, docOrLink.type)\n }\n >\n {innerContent}\n </button>\n );\n }\n\n return (\n <div key={index} className={className}>\n {innerContent}\n </div>\n );\n })}\n </div>\n )}\n </div>\n );\n};\n\nexport default MediaAttachmentsBox;\n","import React from 'react';\n\nconst RibbonEnd: React.FC<{ side: 'left' | 'right'; className?: string; height?: string }> = ({\n side,\n className = '',\n height = '64',\n}) => {\n const halfHeight = parseInt(height) / 2;\n return (\n <svg\n className={className}\n width=\"30\"\n height={height}\n viewBox={`0 0 30 ${height}`}\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n style={{ transform: `scaleX(${side === 'left' ? '1' : '-1'})` }}\n >\n <g filter=\"url(#filter0_d_4620_22659)\">\n <path d={`M0 0H30V${height}H0L6.36364 ${halfHeight}L0 0Z`} fill=\"white\" />\n <path\n d={`M3.08593 2.5H27.5V${height}H3.08593L8.80922 ${halfHeight}L8.91926 30L8.80922 29.4812L3.08593 2.5Z`}\n stroke=\"#EEF2FF\"\n strokeWidth=\"5\"\n />\n </g>\n <defs>\n <filter\n id=\"filter0_d_4620_22659\"\n x=\"0\"\n y=\"0\"\n width=\"30\"\n height={height}\n filterUnits=\"userSpaceOnUse\"\n colorInterpolationFilters=\"sRGB\"\n >\n <feFlood floodOpacity=\"0\" result=\"BackgroundImageFix\" />\n <feColorMatrix\n in=\"SourceAlpha\"\n type=\"matrix\"\n values=\"0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0\"\n result=\"hardAlpha\"\n />\n <feOffset dy=\"4\" />\n <feComposite in2=\"hardAlpha\" operator=\"out\" />\n <feColorMatrix\n type=\"matrix\"\n values=\"0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.25 0\"\n />\n <feBlend\n mode=\"normal\"\n in2=\"BackgroundImageFix\"\n result=\"effect1_dropShadow_4620_22659\"\n />\n <feBlend\n mode=\"normal\"\n in=\"SourceGraphic\"\n in2=\"effect1_dropShadow_4620_22659\"\n result=\"shape\"\n />\n </filter>\n </defs>\n </svg>\n );\n};\n\nexport default RibbonEnd;\n","import React, { useState } from 'react';\n\ntype TruncateTextBoxProps = {\n headerText?: string;\n headerClassName?: string;\n\n // the text to be truncated if it's too long\n text: string;\n\n truncateThreshold?: number;\n\n // extra things to put at the bottom of the box\n children?: React.ReactNode;\n className?: string;\n\n // container styles\n containerClassName?: string;\n // text styles\n textClassName?: string;\n};\n\nconst TruncateTextBox: React.FC<TruncateTextBoxProps> = ({\n headerText = '',\n headerClassName = '',\n text,\n truncateThreshold = 132,\n children,\n className = 'truncate-text-box',\n containerClassName = '',\n textClassName = '',\n}) => {\n const needsTruncate = text?.length > truncateThreshold;\n const [showFullText, setShowFullText] = useState(false);\n const truncated = needsTruncate && !showFullText;\n\n const displayText = truncated ? text.substring(0, truncateThreshold) : text;\n\n const defaultStyles = 'shadow-bottom px-[15px] py-[20px]';\n\n return (\n <div\n className={`${className} ${defaultStyles} bg-white flex flex-col items-start gap-[10px] rounded-[20px] w-full ${containerClassName}`}\n >\n {headerText && (\n <h3 className={`${headerClassName} text-[20px] leading-[20px] text-grayscale-900`}>\n {headerText}\n </h3>\n )}\n\n <p\n className={`text-[12px] text-grayscale-700 leading-[18px] font-poppins font-[400] mb-0 ${textClassName}`}\n >\n {displayText}\n {truncated && (\n <>\n ...{' '}\n <button\n className=\"text-indigo-500 font-[700]\"\n onClick={() => setShowFullText(true)}\n >\n More\n </button>\n </>\n )}\n {needsTruncate && showFullText && (\n <>\n {' '}\n <button\n className=\"text-indigo-500 font-[700]\"\n onClick={() => setShowFullText(false)}\n >\n Close\n </button>\n </>\n )}\n </p>\n\n {children}\n </div>\n );\n};\n\nexport default TruncateTextBox;\n","import React, { useState } from 'react';\nimport { VerificationItem, VerificationStatusEnum } from '@learncard/types';\nimport { getColorForVerificationStatus } from '../../helpers/credential.helpers';\n\nimport InfoBox from './InfoBox';\nimport InfoIcon from '../svgs/InfoIcon';\nimport AcuteCheckmark from '../svgs/AcuteCheckmark';\nimport ExclamationPoint from '../svgs/ExclamationPoint';\nimport X from '../svgs/X';\nimport { capitalize } from '../../helpers/string.helpers';\n\ntype VerificationRowProps = {\n verification: VerificationItem;\n};\n\nconst VerificationRow: React.FC<VerificationRowProps> = ({ verification }) => {\n const [showInfo, setShowInfo] = useState(false);\n const statusColor = getColorForVerificationStatus(verification.status);\n\n const getIcon = () => {\n switch (verification.status) {\n case VerificationStatusEnum.Success:\n return <AcuteCheckmark />;\n case VerificationStatusEnum.Error:\n return <ExclamationPoint />;\n case VerificationStatusEnum.Failed:\n return <X />;\n }\n };\n\n let primaryText = verification.check\n ? `${verification.check}: ${verification.message}`\n : verification.message;\n if (verification.status === VerificationStatusEnum.Failed) {\n primaryText = verification.message ?? verification.details ?? '';\n }\n primaryText = capitalize(primaryText);\n\n const infoText = ''; // if we want certain verifications to have extra explanation, we can set this variable\n\n return (\n <div className=\"verification-row flex flex-col gap-[5px] font-poppins border-b-[1px] border-grayscale-200 border-solid w-full py-[10px] last:border-0 last:pb-0\">\n <span\n className=\"font-[700] text-[11px] leading-[16px] uppercase flex items-center gap-[3px] select-none\"\n style={{ color: statusColor }}\n >\n {getIcon()}\n {verification.status}\n {infoText && (\n <button className=\"ml-auto\" onClick={() => setShowInfo(!showInfo)}>\n <InfoIcon color={statusColor} />\n </button>\n )}\n </span>\n {showInfo && infoText && (\n <InfoBox\n text={infoText}\n handleClose={() => setShowInfo(false)}\n backgroundColor={statusColor}\n />\n )}\n <span className=\"font-[400] text-[14px] leading-[21px] text-grayscale-900\">\n {primaryText}\n </span>\n </div>\n );\n};\n\nexport default VerificationRow;\n","import React, { useState } from 'react';\n\nimport VerificationRow from './VerificationRow';\nimport InfoIcon from '../svgs/InfoIcon';\nimport InfoBox from './InfoBox';\n\nimport { VerificationItem } from '@learncard/types';\n\ntype VerificationsBoxProps = {\n verificationItems: VerificationItem[];\n};\n\nconst VerificationsBox: React.FC<VerificationsBoxProps> = ({ verificationItems }) => {\n const [showInfo, setShowInfo] = useState(false);\n\n return (\n <div className=\"verifications-box bg-white flex flex-col items-start gap-[10px] rounded-[20px] shadow-bottom px-[15px] py-[20px] w-full relative\">\n <h3 className=\"text-[20px] leading-[20px] text-grayscale-900\">\n Credential Verifications\n </h3>\n <button\n className=\"absolute top-[17px] right-[17px]\"\n onClick={() => setShowInfo(!showInfo)}\n >\n <InfoIcon color={showInfo ? '#6366F1' : undefined} />\n </button>\n {showInfo && (\n <InfoBox\n text=\"Credential verifications check the cryptographic proof of digital credentials to ensure their authenticity and accuracy.\"\n handleClose={() => setShowInfo(false)}\n />\n )}\n\n {verificationItems.map((verification, index) => (\n <VerificationRow key={index} verification={verification} />\n ))}\n </div>\n );\n};\n\nexport default VerificationsBox;\n","import React from 'react';\nimport { format } from 'date-fns';\n\nimport MediaAttachmentsBox from './MediaAttachmentsBox';\nimport TruncateTextBox from './TruncateTextBox';\nimport SkillsBox from './SkillsBox';\nimport IssueHistoryBox from './IssueHistoryBox';\nimport { VC, VerificationItem } from '@learncard/types';\nimport VerificationsBox from './VerificationsBox';\nimport AlignmentsBox from '../CertificateDisplayCard/AlignmentsBox';\nimport {\n BoostAchievementCredential,\n IssueHistory,\n MediaMetadata,\n VideoMetadata,\n} from '../../types';\nimport LeftArrow from '../svgs/LeftArrow';\n\n/*\nconst defaultTagsToSkills = (tags: string[]) => {\n const skillsObj: { [skill: string]: string[] } = {};\n tags.forEach(tag => {\n skillsObj[tag] = [];\n });\n};\n*/\n\ntype VC2BackFaceProps = {\n credential: VC | BoostAchievementCredential;\n verificationItems: VerificationItem[];\n // convertTagsToSkills?: (tags: string[]) => { [skill: string]: string[] };\n getFileMetadata?: (url: string) => MediaMetadata;\n getVideoMetadata?: (url: string) => VideoMetadata;\n onMediaAttachmentClick?: (url: string, type: 'photo' | 'document' | 'video' | 'link') => void;\n issueHistory?: IssueHistory[];\n showBackButton?: boolean;\n showFrontFace: () => void;\n customDescription?: React.ReactNode;\n customCriteria?: React.ReactNode;\n customSkillsComponent?: React.ReactNode;\n customIssueHistoryComponent?: React.ReactNode;\n enableLightbox?: boolean;\n};\n\nconst VC2BackFace: React.FC<VC2BackFaceProps> = ({\n credential,\n verificationItems,\n // convertTagsToSkills = defaultTagsToSkills,\n getFileMetadata,\n getVideoMetadata,\n onMediaAttachmentClick,\n issueHistory,\n showBackButton,\n showFrontFace,\n customDescription,\n customCriteria,\n customSkillsComponent,\n customIssueHistoryComponent,\n enableLightbox,\n}) => {\n const expiration = credential.expirationDate\n ? format(new Date(credential.expirationDate), 'MMM dd, yyyy')\n : undefined;\n\n const isExpired =\n credential.expirationDate &&\n Number(new Date(credential.expirationDate)) < Number(new Date());\n\n const achievement =\n 'achievement' in credential.credentialSubject\n ? credential.credentialSubject.achievement\n : undefined;\n const criteria = achievement?.criteria?.narrative;\n const description = achievement?.description;\n const alignment = achievement?.alignment;\n\n /* \n const tags = credential.credentialSubject.achievement?.tag;\n const skillsObject = tags && tags.length > 0 ? convertTagsToSkills(tags) : undefined;\n */\n\n return (\n <section className=\"vc-back-face flex flex-col gap-[20px] w-full px-[15px] pb-[25px]\">\n {showBackButton && (\n <div className=\"w-full\">\n <button\n className=\"vc-card-back-button rounded-full h-[50px] px-[15px] flex items-center justify-center gap-[5px] z-50 text-[30px] text-white select-none\"\n onClick={showFrontFace}\n >\n <LeftArrow className=\"text-white\" size=\"25\" />\n Details\n </button>\n </div>\n )}\n\n {customDescription && (\n <TruncateTextBox headerText=\"About\" text={description} className=\"description-box\">\n {customDescription}\n </TruncateTextBox>\n )}\n {!customDescription && (description || expiration) && (\n <TruncateTextBox headerText=\"About\" text={description} className=\"description-box\">\n {expiration && (\n <p className=\"text-grayscale-800 font-poppins font-[600] text-[12px] leading-[18px] mb-0\">\n Expire{isExpired ? 'd' : 's'} on {expiration}\n </p>\n )}\n </TruncateTextBox>\n )}\n\n {customCriteria && (\n <TruncateTextBox\n headerText=\"Criteria\"\n text={description}\n className=\"description-box\"\n >\n {customCriteria}\n </TruncateTextBox>\n )}\n {!customCriteria && criteria && (\n <TruncateTextBox headerText=\"Criteria\" text={criteria} className=\"criteria-box\" />\n )}\n {(credential.skills?.length ?? 0) > 0 &&\n (customSkillsComponent ? (\n customSkillsComponent\n ) : (\n <SkillsBox skills={credential.skills ?? []} />\n ))}\n\n {issueHistory && issueHistory?.length > 0 && (\n <IssueHistoryBox\n issueHistory={issueHistory}\n customIssueHistoryComponent={customIssueHistoryComponent}\n />\n )}\n\n {credential.attachments && credential.attachments.length > 0 && (\n <MediaAttachmentsBox\n attachments={credential.attachments}\n getFileMetadata={getFileMetadata}\n getVideoMetadata={getVideoMetadata}\n onMediaAttachmentClick={onMediaAttachmentClick}\n enableLightbox={enableLightbox}\n />\n )}\n {/* {credential.notes && <TruncateTextBox headerText=\"Notes\" text={credential.notes} />} */}\n\n {alignment && <AlignmentsBox alignment={alignment} style=\"boost\" />}\n\n {verificationItems && verificationItems.length > 0 && (\n <VerificationsBox verificationItems={verificationItems} />\n )}\n </section>\n );\n};\n\nexport default VC2BackFace;\n","import React from 'react';\n\nimport DefaultFace from '../../assets/images/default-face.jpeg';\n\nimport { getImageFromProfile, getNameFromProfile } from '../../helpers/credential.helpers';\nimport { truncateWithEllipsis } from '../../helpers/string.helpers';\nimport { Profile } from '@learncard/types';\n\ntype VC2FrontFaceInfoProps = {\n issuee: Profile | string;\n issuer: Profile | string;\n title: string;\n subjectDID?: string | undefined;\n subjectImageComponent?: React.ReactNode;\n issuerImageComponent?: React.ReactNode;\n createdAt: string;\n imageUrl?: string;\n customBodyCardComponent?: React.ReactNode;\n customThumbComponent?: React.ReactNode;\n};\n\nconst VC2FrontFaceInfo: React.FC<VC2FrontFaceInfoProps> = ({\n issuee,\n issuer,\n subjectDID,\n subjectImageComponent,\n issuerImageComponent,\n customBodyCardComponent,\n createdAt,\n imageUrl,\n customThumbComponent,\n}) => {\n const issuerName = truncateWithEllipsis(getNameFromProfile(issuer ?? ''), 25);\n const issueeName = truncateWithEllipsis(getNameFromProfile(issuee ?? ''), 25);\n const issuerImage = getImageFromProfile(issuer ?? '');\n const issueeImage = getImageFromProfile(issuee ?? '');\n\n const getImageElement = (\n imageUrl: string,\n alt: string,\n overrideComponent: React.ReactNode | undefined\n ) => {\n if (overrideComponent) return overrideComponent;\n\n return (\n <img\n className=\"h-full w-full object-cover select-none\"\n src={imageUrl || DefaultFace}\n alt={alt}\n />\n );\n };\n\n const issueeImageEl: React.ReactNode = getImageElement(\n issueeImage,\n 'Issuee image',\n subjectImageComponent\n );\n const issuerImageEl: React.ReactNode = getImageElement(\n issuerImage,\n 'Issuer image',\n issuerImageComponent\n );\n\n return (\n <section className=\"vc-front-face w-full px-[15px] flex flex-col items-center gap-[15px]\">\n {imageUrl && !customThumbComponent && (\n <img className=\"vc-front-image h-[130px] w-[130px] rounded-[10px]\" src={imageUrl} />\n )}\n\n {customThumbComponent && customThumbComponent}\n <div className=\"vc-issue-info-box bg-white flex flex-col items-center gap-[5px] rounded-[20px] shadow-bottom px-[15px] py-[20px] w-full\">\n {customBodyCardComponent && customBodyCardComponent}\n\n {!customBodyCardComponent && (\n <>\n <h3 className=\"text-[27px] flex flex-col text-center leading-[130%] text-grayscale-900 capitalize\">\n {issueeName}\n {subjectDID && (\n <span className=\"text-[12px] text-grayscale-700 leading-[18px] font-poppins font-[400] m-0 p-0 normal-case\">\n {subjectDID}\n </span>\n )}\n </h3>\n <div className=\"relative\">\n <div className=\"vc-issuee-image h-[60px] w-[60px] rounded-full overflow-hidden\">\n {issueeImageEl}\n </div>\n <div className=\"vc-issuer-image h-[30px] w-[30px] rounded-full overflow-hidden absolute bottom-[-12px] right-[-12px]\">\n {issuerImageEl}\n </div>\n </div>\n <div className=\"vc-issue-details mt-[10px] flex flex-col items-center font-montserrat text-[14px] leading-[20px]\">\n <span className=\"created-at text-grayscale-700\">{createdAt}</span>\n <span className=\"issued-by text-grayscale-900 font-[500]\">\n by <strong className=\"font-[700]\">{issuerName}</strong>\n </span>\n </div>\n </>\n )}\n </div>\n </section>\n );\n};\n\nexport default VC2FrontFaceInfo;\n","import React from 'react';\nimport { getCategoryColor } from '../../helpers/credential.helpers';\nimport { LCCategoryEnum } from '../../types';\n\nconst VCDisplayCardCategoryType: React.FC<{ categoryType?: LCCategoryEnum }> = ({\n categoryType = LCCategoryEnum.achievement,\n}) => {\n const categoryColor = getCategoryColor(categoryType);\n\n return (\n <span\n className={`uppercase font-poppins text-[12px] font-[600] leading-[12px] select-none text-${categoryColor}`}\n >\n {categoryType}\n </span>\n );\n};\n\nexport default VCDisplayCardCategoryType;\n","import React from 'react';\n\nimport IDIcon from '../svgs/IDIcon';\nimport IDSleeve from '../../assets/images/id-sleeve.png';\nimport QRCodeIcon from '../svgs/QRCodeIcon';\nimport UnknownVerifierBadge from '../svgs/UnknownVerifierBadge';\nimport VerifiedBadge from '../svgs/VerifiedBadge';\nimport PersonBadge from '../svgs/PersonBadge';\nimport RedFlag from '../svgs/RedFlag';\n\nimport { getInfoFromCredential } from '../../helpers/credential.helpers';\n\nimport { VC } from '@learncard/types';\nimport { BoostAchievementCredential } from '../../types';\nimport TruncateTextBox from './TruncateTextBox';\n\ntype VCIDDisplayFrontFaceProps = {\n isFront: boolean;\n setIsFront: (value: boolean) => void;\n showDetailsBtn?: boolean;\n credential: VC | BoostAchievementCredential;\n trustedAppRegistry?: any[];\n customThumbComponent?: React.ReactNode;\n hideQRCode?: boolean;\n qrCodeOnClick?: () => void;\n customIDDescription?: React.ReactNode;\n};\n\nconst VERIFIER_STATES = {\n selfVerified: 'Self Verified',\n trustedVerifier: 'Trusted Verifier',\n unknownVerifier: 'Unknown Verifier',\n untrustedVerifier: 'Untrusted Verifier',\n} as const;\ntype VerifierState = (typeof VERIFIER_STATES)[keyof typeof VERIFIER_STATES];\n\nconst VCIDDisplayFrontFace: React.FC<VCIDDisplayFrontFaceProps> = ({\n isFront,\n setIsFront,\n showDetailsBtn,\n credential,\n trustedAppRegistry,\n customThumbComponent,\n hideQRCode = false,\n qrCodeOnClick,\n customIDDescription,\n}) => {\n const { credentialSubject } = getInfoFromCredential(credential, 'MMM dd, yyyy', {\n uppercaseDate: false,\n });\n\n const issuerDid =\n typeof credential.issuer === 'string' ? credential.issuer : credential.issuer.id;\n\n let verifierState: VerifierState;\n if (credentialSubject?.id === issuerDid && issuerDid && issuerDid !== 'did:example:123') {\n // the extra \"&& issuerDid\" is so that the credential preview doesn't say \"Self Verified\"\n // the did:example:123 condition is so that we don't show this status from the Manage Boosts tab\n verifierState = VERIFIER_STATES.selfVerified;\n } else {\n const appRegistryEntry = trustedAppRegistry?.find(\n registryEntry => registryEntry.did === issuerDid\n );\n\n if (appRegistryEntry) {\n verifierState = appRegistryEntry.isTrusted\n ? VERIFIER_STATES.trustedVerifier\n : VERIFIER_STATES.untrustedVerifier;\n } else {\n verifierState = VERIFIER_STATES.unknownVerifier;\n }\n }\n const isSelfVerified = verifierState === VERIFIER_STATES.selfVerified;\n\n const achievement =\n 'achievement' in credential?.credentialSubject\n ? credential?.credentialSubject?.achievement\n : undefined;\n const description = achievement?.description;\n\n return (\n <section className=\"vc-front-face w-full flex flex-col items-center gap-[15px]\">\n {/* <div className=\"w-[380px] h-[211px] bg-red-300\" /> */}\n\n {customThumbComponent && customThumbComponent}\n\n <div className=\"text-white w-full flex items-center justify-center font-poppins\">\n <IDIcon className=\"text-white mr-1\" /> ID\n </div>\n\n <div className=\"w-full relative\">\n {!hideQRCode && (\n <button\n onClick={() => qrCodeOnClick?.()}\n className=\"text-grayscale-900 bg-white rounded-full p-[10px] absolute top-[-10px] right-[45%]\"\n >\n <QRCodeIcon className=\"text-grayscale-900 \" />\n </button>\n )}\n <img src={IDSleeve} alt=\"id-sleeve\" className=\"w-full object-cover\" />\n </div>\n\n <div className=\"w-full bg-white relative mt-[-70px] px-6 pb-4 pt-4\">\n {description && !customIDDescription && (\n <>\n <TruncateTextBox\n text={description}\n className=\"description-box\"\n containerClassName=\"!p-0 !shadow-none !text-center !w-full\"\n textClassName=\"!font-poppins !text-base !text-grayscale-700 !text-center !w-full\"\n truncateThreshold={204}\n />\n </>\n )}\n\n {customIDDescription && customIDDescription}\n\n {isFront && showDetailsBtn && (\n <button\n type=\"button\"\n className=\"vc-toggle-side-button text-white shadow-bottom bg-[#00000099] px-[30px] py-[8px] rounded-[40px] text-[28px] tracking-[0.75px] uppercase leading-[28px] mt-[25px] w-fit select-none\"\n onClick={() => setIsFront(!isFront)}\n >\n Details\n </button>\n )}\n\n <div className=\"w-full flex items-center justify-center mt-4\">\n <div className=\"h-[2px] w-full bg-gray-200\" />\n </div>\n\n <div className=\"w-full flex items-center justify-center mt-2\">\n {isSelfVerified && (\n <span className=\"uppercase font-poppins text-base font-[500] text-green-dark flex gap-[3px] items-center\">\n <PersonBadge className=\"w-[20px] h-[20px]\" />\n Self Verified\n </span>\n )}\n {verifierState === VERIFIER_STATES.trustedVerifier && (\n <span className=\"uppercase font-poppins text-base font-[500] text-blue-light flex gap-[3px] items-center\">\n <VerifiedBadge className=\"w-[20px] h-[20px]\" />\n Trusted Verifier\n </span>\n )}\n {verifierState === VERIFIER_STATES.unknownVerifier && (\n <span className=\"uppercase font-poppins text-base font-[500] text-orange-500 flex gap-[3px] items-center\">\n <UnknownVerifierBadge className=\"w-[20px] h-[20px]\" />\n Unknown Verifier\n </span>\n )}\n {verifierState === VERIFIER_STATES.untrustedVerifier && (\n <span className=\"uppercase font-poppins text-base font-[500] text-red-mastercard flex gap-[3px] items-center\">\n <RedFlag className=\"w-[20px] h-[20px]\" />\n Untrusted Verifier\n </span>\n )}\n </div>\n </div>\n </section>\n );\n};\n\nexport default VCIDDisplayFrontFace;\n","import React, { useState } from 'react';\nimport { Flipper, Flipped } from 'react-flip-toolkit';\n\nimport VC2BackFace from './VC2BackFace';\nimport VCIDDisplayFrontFace from './VCIDDisplayFrontFace';\n\nimport {\n BoostAchievementCredential,\n IssueHistory,\n MediaMetadata,\n VideoMetadata,\n} from '../../types';\nimport { VC, VerificationItem } from '@learncard/types';\n\nexport type VCIDDisplayCardProps = {\n credential: VC | BoostAchievementCredential;\n verificationItems: VerificationItem[];\n getFileMetadata?: (url: string) => MediaMetadata;\n getVideoMetadata?: (url: string) => VideoMetadata;\n onMediaAttachmentClick?: (url: string, type: 'photo' | 'document' | 'video' | 'link') => void;\n customThumbComponent?: React.ReactNode;\n customDescription?: React.ReactNode;\n customCriteria?: React.ReactNode;\n customIssueHistoryComponent?: React.ReactNode;\n issueHistory?: IssueHistory[];\n showBackButton?: boolean;\n enableLightbox?: boolean;\n trustedAppRegistry?: any[];\n customSkillsComponent?: React.ReactNode;\n isFrontOverride?: boolean;\n setIsFrontOverride?: (value: boolean) => void;\n hideNavButtons?: boolean;\n hideQRCode?: boolean;\n qrCodeOnClick?: () => void;\n showDetailsBtn?: boolean;\n customIDDescription?: React.ReactNode;\n hideGradientBackground?: boolean;\n};\n\nexport const VCIDDisplayCard: React.FC<VCIDDisplayCardProps> = ({\n credential,\n verificationItems,\n getFileMetadata,\n getVideoMetadata,\n onMediaAttachmentClick,\n customThumbComponent,\n customCriteria,\n customDescription,\n customIssueHistoryComponent,\n issueHistory,\n showBackButton = true,\n enableLightbox,\n trustedAppRegistry,\n customSkillsComponent,\n isFrontOverride,\n setIsFrontOverride,\n hideNavButtons,\n hideQRCode = false,\n qrCodeOnClick,\n showDetailsBtn = false,\n customIDDescription,\n hideGradientBackground = false,\n}) => {\n const [_isFront, _setIsFront] = useState<boolean>(isFrontOverride ?? true);\n const isFront = isFrontOverride ?? _isFront;\n const setIsFront = setIsFrontOverride ?? _setIsFront;\n\n let backgroundStyle = {\n backgroundColor: `linear-gradient(180deg, rgba(24,34,78,1) ${\n !isFront && hideGradientBackground ? '100%' : '25%'\n }, rgba(139,145,167,1) 100%)`,\n backgroundImage: `linear-gradient(180deg, rgba(24,34,78,1) ${\n !isFront && hideGradientBackground ? '100%' : '25%'\n }, rgba(139,145,167,1) 100%)`,\n backgroundSize: 'cover',\n backgroundPosition: 'center',\n backgroundAttachment: 'fixed',\n };\n\n return (\n <Flipper className=\"w-full\" flipKey={isFront}>\n <Flipped flipId=\"card\">\n <section\n className={`vc-display-card font-mouse flex flex-col items-center border-solid border-white rounded-[30px] z-10 max-w-[400px] relative bg-white shadow-3xl ${\n isFront ? '' : 'min-h-[800px]'\n }`}\n >\n <div\n className=\"relative vc-card-content-container flex flex-col items-center grow min-h-0 w-full rounded-t-[30px] rounded-b-[30px] overflow-hidden\"\n style={backgroundStyle}\n >\n <Flipped flipId=\"scroll-container\">\n <div className=\"vc-card-content-scroll-container w-full min-h-full flex flex-col justify-start items-center rounded-t-[30px] rounded-b-[30px] scrollbar-hide pt-[20px]\">\n {isFront && (\n <Flipped flipId=\"face\">\n <VCIDDisplayFrontFace\n isFront={_isFront}\n setIsFront={setIsFront}\n showDetailsBtn={showDetailsBtn}\n customThumbComponent={customThumbComponent}\n credential={credential}\n trustedAppRegistry={trustedAppRegistry}\n qrCodeOnClick={qrCodeOnClick}\n hideQRCode={hideQRCode}\n customIDDescription={customIDDescription}\n />\n </Flipped>\n )}\n {!isFront && (\n <Flipped flipId=\"face\">\n <VC2BackFace\n credential={credential}\n verificationItems={verificationItems}\n issueHistory={issueHistory}\n getFileMetadata={getFileMetadata}\n getVideoMetadata={getVideoMetadata}\n onMediaAttachmentClick={onMediaAttachmentClick}\n showBackButton={\n (showBackButton && !hideNavButtons) ||\n showDetailsBtn\n }\n showFrontFace={() => setIsFront(true)}\n customDescription={customDescription}\n customCriteria={customCriteria}\n customIssueHistoryComponent={\n customIssueHistoryComponent\n }\n enableLightbox={enableLightbox}\n customSkillsComponent={customSkillsComponent}\n />\n </Flipped>\n )}\n </div>\n </Flipped>\n </div>\n </section>\n </Flipped>\n </Flipper>\n );\n};\n\nexport default VCIDDisplayCard;\n","import React, { useLayoutEffect, useRef, useState } from 'react';\nimport { Flipper, Flipped } from 'react-flip-toolkit';\n\nimport { VCVerificationCheckWithSpinner } from '../VCVerificationCheck/VCVerificationCheck';\nimport VC2FrontFaceInfo from './VC2FrontFaceInfo';\nimport VC2BackFace from './VC2BackFace';\nimport RibbonEnd from './RibbonEnd';\nimport FitText from './FitText';\nimport AwardRibbon from '../svgs/AwardRibbon';\nimport LeftArrow from '../svgs/LeftArrow';\nimport RoundedX from '../svgs/RoundedX';\nimport VCDisplayCardCategoryType from './VCDisplayCardCategoryType';\nimport VCDisplayCardSkillsCount from './VCDisplayCardSkillsCount';\nimport VCIDDisplayCard from './VCIDDIsplayCard';\n\nimport { Profile, VC, VerificationItem, VerificationStatusEnum } from '@learncard/types';\nimport {\n getColorForVerificationStatus,\n getInfoFromCredential,\n} from '../../helpers/credential.helpers';\nimport {\n BoostAchievementCredential,\n IssueHistory,\n LCCategoryEnum,\n MediaMetadata,\n VideoMetadata,\n} from '../../types';\nimport { CertificateDisplayCard } from '../CertificateDisplayCard';\n\nexport type CredentialIconType = {\n image?: React.ReactNode;\n color?: string;\n};\n\nexport type VCDisplayCard2Props = {\n categoryType?: LCCategoryEnum;\n credential: VC | BoostAchievementCredential;\n verificationItems: VerificationItem[];\n issueeOverride?: Profile;\n issuerOverride?: Profile;\n subjectDID?: string;\n subjectImageComponent?: React.ReactNode;\n issuerImageComponent?: React.ReactNode;\n verificationInProgress?: boolean;\n // convertTagsToSkills?: (tags: string[]) => { [skill: string]: string[] };\n handleXClick?: () => void;\n getFileMetadata?: (url: string) => MediaMetadata;\n getVideoMetadata?: (url: string) => VideoMetadata;\n onMediaAttachmentClick?: (url: string, type: 'photo' | 'document' | 'video' | 'link') => void;\n bottomRightIcon?: CredentialIconType;\n customFooterComponent?: React.ReactNode;\n customBodyCardComponent?: React.ReactNode;\n customThumbComponent?: React.ReactNode;\n customDescription?: React.ReactNode;\n customCriteria?: React.ReactNode;\n customIssueHistoryComponent?: React.ReactNode;\n issueHistory?: IssueHistory[];\n titleOverride?: string;\n showBackButton?: boolean;\n enableLightbox?: boolean;\n customRibbonCategoryComponent?: React.ReactNode;\n customFrontButton?: React.ReactNode;\n trustedAppRegistry?: any[];\n hideIssueDate?: boolean;\n onDotsClick?: () => void;\n customSkillsComponent?: React.ReactNode;\n isFrontOverride?: boolean;\n setIsFrontOverride?: (value: boolean) => void;\n hideNavButtons?: boolean;\n hideQRCode?: boolean;\n qrCodeOnClick?: () => void; // exclusive to the ID display type\n showDetailsBtn?: boolean;\n customIDDescription?: React.ReactNode;\n hideGradientBackground?: boolean;\n};\n\nexport const VCDisplayCard2: React.FC<VCDisplayCard2Props> = ({\n categoryType,\n credential,\n verificationItems,\n issueeOverride,\n issuerOverride,\n subjectDID,\n subjectImageComponent,\n issuerImageComponent,\n verificationInProgress = false,\n // convertTagsToSkills,\n handleXClick,\n getFileMetadata,\n getVideoMetadata,\n onMediaAttachmentClick,\n bottomRightIcon,\n customFooterComponent,\n customBodyCardComponent,\n customThumbComponent,\n customCriteria,\n customDescription,\n customIssueHistoryComponent,\n issueHistory,\n titleOverride,\n showBackButton = true,\n enableLightbox,\n customRibbonCategoryComponent,\n customFrontButton,\n trustedAppRegistry,\n hideIssueDate,\n onDotsClick,\n customSkillsComponent,\n isFrontOverride,\n setIsFrontOverride,\n hideNavButtons,\n hideQRCode = false,\n qrCodeOnClick,\n showDetailsBtn = false,\n customIDDescription,\n hideGradientBackground = false,\n}) => {\n const {\n title = '',\n createdAt,\n issuer: _issuer = '',\n issuee: _issuee = '',\n imageUrl,\n } = getInfoFromCredential(credential, 'MMM dd, yyyy');\n const issuee = issueeOverride || _issuee;\n const issuer = issuerOverride || _issuer;\n\n const [_isFront, _setIsFront] = useState(isFrontOverride ?? true);\n const isFront = isFrontOverride ?? _isFront;\n const setIsFront = setIsFrontOverride ?? _setIsFront;\n\n const [headerHeight, setHeaderHeight] = useState(100); // 79 is the height if the header is one line\n const [headerWidth, setHeaderWidth] = useState(0);\n\n const headerRef = useRef<HTMLHeadingElement>(null);\n\n useLayoutEffect(() => {\n // Needs a small setTimeout otherwise it'll be wrong sometimes with multiline header.\n // Probably because of the interaction with FitText\n setTimeout(() => {\n setHeaderHeight(headerRef.current?.clientHeight ?? 100);\n setHeaderWidth(headerRef.current?.clientWidth ?? 0);\n }, 10);\n });\n\n let worstVerificationStatus = verificationItems.reduce(\n (\n currentWorst: (typeof VerificationStatusEnum)[keyof typeof VerificationStatusEnum],\n verification\n ) => {\n switch (currentWorst) {\n case VerificationStatusEnum.Success:\n return verification.status;\n case VerificationStatusEnum.Error:\n return verification.status === VerificationStatusEnum.Failed\n ? verification.status\n : currentWorst;\n case VerificationStatusEnum.Failed:\n return currentWorst;\n }\n },\n VerificationStatusEnum.Success\n );\n\n const statusColor = getColorForVerificationStatus(worstVerificationStatus);\n\n const backgroundStyle = {\n backgroundColor: credential?.display?.backgroundColor,\n backgroundImage: credential?.display?.backgroundImage\n ? `linear-gradient(to bottom, rgba(0, 0, 0, 0.15), rgba(0, 0, 0, 0.25)), url(${credential.display?.backgroundImage})`\n : undefined,\n backgroundSize: 'cover',\n backgroundPosition: 'center',\n backgroundAttachment: 'fixed',\n };\n\n const _title = titleOverride || title;\n\n if (credential?.display?.displayType === 'certificate') {\n return (\n <CertificateDisplayCard\n credential={credential}\n categoryType={categoryType}\n issueeOverride={issuee}\n issuerOverride={issuer}\n verificationItems={verificationItems}\n getFileMetadata={getFileMetadata}\n getVideoMetadata={getVideoMetadata}\n onMediaAttachmentClick={onMediaAttachmentClick}\n enableLightbox={enableLightbox}\n trustedAppRegistry={trustedAppRegistry}\n handleXClick={handleXClick}\n subjectImageComponent={subjectImageComponent}\n issuerImageComponent={issuerImageComponent}\n customBodyCardComponent={customBodyCardComponent}\n hideIssueDate={hideIssueDate}\n onDotsClick={onDotsClick}\n isFrontOverride={isFrontOverride}\n setIsFrontOverride={setIsFrontOverride}\n hideNavButtons={hideNavButtons}\n showBackButton={showBackButton}\n showDetailsBtn={showDetailsBtn}\n />\n );\n } else if (credential?.display?.displayType === 'id' || categoryType === 'ID') {\n return (\n <div>\n <VCIDDisplayCard\n credential={credential}\n verificationItems={verificationItems}\n getFileMetadata={getFileMetadata}\n getVideoMetadata={getVideoMetadata}\n onMediaAttachmentClick={onMediaAttachmentClick}\n customThumbComponent={customThumbComponent}\n customCriteria={customCriteria}\n customDescription={customDescription}\n customIssueHistoryComponent={customIssueHistoryComponent}\n issueHistory={issueHistory}\n enableLightbox={enableLightbox}\n trustedAppRegistry={trustedAppRegistry}\n customSkillsComponent={customSkillsComponent}\n isFrontOverride={isFrontOverride}\n setIsFrontOverride={setIsFrontOverride}\n hideNavButtons={hideNavButtons}\n hideQRCode={hideQRCode}\n qrCodeOnClick={qrCodeOnClick}\n showBackButton={showBackButton}\n showDetailsBtn={showDetailsBtn}\n customIDDescription={customIDDescription}\n hideGradientBackground={hideGradientBackground}\n />\n </div>\n );\n }\n\n return (\n <Flipper className=\"w-full\" flipKey={isFront}>\n <Flipped flipId=\"card\">\n <section className=\"vc-display-card font-mouse flex flex-col items-center border-solid border-[5px] border-white rounded-[30px] z-10 min-h-[800px] max-w-[400px] relative bg-white shadow-3xl\">\n <RibbonEnd\n side=\"left\"\n className=\"absolute left-[-30px] top-[50px] z-0\"\n height={'100'}\n />\n <RibbonEnd\n side=\"right\"\n className=\"absolute right-[-30px] top-[50px] z-0\"\n height={'100'}\n />\n\n <h1\n ref={headerRef}\n className=\"vc-card-header px-[20px] pb-[10px] pt-[3px] overflow-visible mt-[40px] absolute text-center bg-white border-y-[5px] border-[#EEF2FF] shadow-bottom w-[calc(100%_+_16px)] rounded-t-[8px] z-50\"\n style={{ wordBreak: 'break-word' }}\n >\n {customRibbonCategoryComponent && customRibbonCategoryComponent}\n {!customRibbonCategoryComponent && (\n <VCDisplayCardCategoryType categoryType={categoryType} />\n )}\n\n <FitText\n text={_title ?? ''}\n maxFontSize={32}\n minFontSize={20}\n width={((headerWidth ?? 290) - 40).toString()}\n className=\"vc-card-header-main-title text-[#18224E] leading-[100%] text-shadow text-[32px]\"\n />\n </h1>\n\n {isFront && handleXClick && (\n <button\n className=\"vc-card-x-button absolute top-[-25px] bg-white rounded-full h-[50px] w-[50px] flex items-center justify-center z-50\"\n onClick={handleXClick}\n >\n <RoundedX />\n </button>\n )}\n\n <div\n className=\"relative pt-[114px] vc-card-content-container flex flex-col items-center grow min-h-0 w-full rounded-t-[30px] bg-[#353E64] rounded-b-[200px]\"\n style={backgroundStyle}\n >\n {/* \n div in a div here so that we can have an outer scroll container with an inner container\n that has a rounded bottom at the bottom of the scrollable content \n */}\n <Flipped flipId=\"scroll-container\">\n <div className=\"vc-card-content-scroll-container w-full pt-[20px] min-h-full flex flex-col justify-start items-center rounded-t-[30px] rounded-b-[200px] scrollbar-hide pb-[50px]\">\n {isFront && (\n <Flipped flipId=\"face\">\n <VC2FrontFaceInfo\n issuee={issuee}\n subjectDID={subjectDID}\n issuer={issuer}\n title={title}\n subjectImageComponent={subjectImageComponent}\n issuerImageComponent={issuerImageComponent}\n customBodyCardComponent={customBodyCardComponent}\n customThumbComponent={customThumbComponent}\n createdAt={createdAt ?? ''}\n imageUrl={imageUrl}\n />\n </Flipped>\n )}\n {!isFront && (\n <Flipped flipId=\"face\">\n <VC2BackFace\n credential={credential}\n verificationItems={verificationItems}\n // convertTagsToSkills={convertTagsToSkills}\n issueHistory={issueHistory}\n getFileMetadata={getFileMetadata}\n getVideoMetadata={getVideoMetadata}\n onMediaAttachmentClick={onMediaAttachmentClick}\n showBackButton={\n (showBackButton && !hideNavButtons) ||\n showDetailsBtn\n }\n showFrontFace={() => setIsFront(true)}\n customDescription={customDescription}\n customCriteria={customCriteria}\n customIssueHistoryComponent={\n customIssueHistoryComponent\n }\n enableLightbox={enableLightbox}\n customSkillsComponent={customSkillsComponent}\n />\n </Flipped>\n )}\n\n {isFront && (\n <VCDisplayCardSkillsCount\n skills={credential?.skills}\n onClick={() => setIsFront(!isFront)}\n />\n )}\n\n {(!hideNavButtons || showDetailsBtn) && (\n <>\n {isFront && customFrontButton}\n {((isFront && !customFrontButton) ||\n (isFront && showDetailsBtn)) && (\n <Flipped flipId=\"details-back-button\">\n <button\n type=\"button\"\n className=\"vc-toggle-side-button text-white shadow-bottom bg-[#00000099] px-[30px] py-[8px] rounded-[40px] text-[28px] tracking-[0.75px] uppercase leading-[28px] mt-[40px] w-fit select-none\"\n onClick={() => setIsFront(!isFront)}\n >\n Details\n </button>\n </Flipped>\n )}\n {!isFront && (\n <Flipped flipId=\"details-back-button\">\n <button\n type=\"button\"\n className=\"vc-toggle-side-button text-white shadow-bottom bg-[#00000099] px-[30px] py-[8px] rounded-[40px] text-[28px] tracking-[0.75px] uppercase leading-[28px] mt-[40px] w-fit select-none\"\n onClick={() => setIsFront(!isFront)}\n >\n <span className=\"flex gap-[10px] items-center\">\n <LeftArrow />\n Back\n </span>\n </button>\n </Flipped>\n )}\n </>\n )}\n </div>\n </Flipped>\n </div>\n <footer className=\"vc-card-footer w-full flex justify-between p-[5px] mt-[5px]\">\n {customFooterComponent && customFooterComponent}\n {!customFooterComponent && (\n <>\n {worstVerificationStatus === VerificationStatusEnum.Failed ? (\n <div className=\"w-[40px]\" role=\"presentation\" />\n ) : (\n <VCVerificationCheckWithSpinner\n spinnerSize=\"40px\"\n size={'32px'}\n loading={verificationInProgress}\n />\n )}\n <div className=\"vc-footer-text font-montserrat flex flex-col items-center justify-center text-[12px] font-[700] leading-[15px] select-none\">\n <span className=\"text-[#4F4F4F]\">Verified Credential</span>\n <span\n className=\"vc-footer-status uppercase\"\n style={{ color: statusColor }}\n >\n {worstVerificationStatus}\n </span>\n </div>\n <div\n className=\"vc-footer-icon rounded-[20px] h-[40px] w-[40px] flex items-center justify-center overflow-hidden\"\n style={{ backgroundColor: bottomRightIcon?.color ?? '#6366F1' }}\n >\n {bottomRightIcon?.image ?? <AwardRibbon />}\n </div>\n </>\n )}\n </footer>\n </section>\n </Flipped>\n </Flipper>\n );\n};\n\nexport default VCDisplayCard2;\n"],"names":["this","Flipper","Flipped"],"mappings":"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"}