@learncard/react 2.5.10 → 2.5.12
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/ArrowArcLeft.svg +4 -0
- package/dist/cjs/Checkmark-f611aa4d.js +58 -0
- package/dist/cjs/Checkmark-f611aa4d.js.map +1 -0
- package/dist/cjs/{LearnCardCreditCardFrontFace-4452fd7a.js → LearnCardCreditCardFrontFace-4ce0d049.js} +2 -2
- package/dist/cjs/{LearnCardCreditCardFrontFace-4452fd7a.js.map → LearnCardCreditCardFrontFace-4ce0d049.js.map} +1 -1
- package/dist/cjs/Notification-9d230f1b.js +94 -0
- package/dist/cjs/Notification-9d230f1b.js.map +1 -0
- package/dist/cjs/NotificationBoostCard-3b3bd47d.js +121 -0
- package/dist/cjs/NotificationBoostCard-3b3bd47d.js.map +1 -0
- package/dist/cjs/NotificationUserAcceptedBoostCard-423b9320.js +74 -0
- package/dist/cjs/NotificationUserAcceptedBoostCard-423b9320.js.map +1 -0
- package/dist/cjs/NotificationUserCard-d4dab06c.js +94 -0
- package/dist/cjs/NotificationUserCard-d4dab06c.js.map +1 -0
- package/dist/cjs/{QRCodeCard-efaa58e1.js → QRCodeCard-b60c0500.js} +2 -2
- package/dist/cjs/{QRCodeCard-efaa58e1.js.map → QRCodeCard-b60c0500.js.map} +1 -1
- package/dist/cjs/SchoolIDCard-1baf77e8.js.map +1 -1
- package/dist/cjs/{User-7408bdf0.js → User-92f9cf40.js} +1 -50
- package/dist/cjs/User-92f9cf40.js.map +1 -0
- package/dist/cjs/{VCCard-4a5e06a1.js → VCCard-9e1cd423.js} +3 -3
- package/dist/cjs/{VCCard-4a5e06a1.js.map → VCCard-9e1cd423.js.map} +1 -1
- package/dist/cjs/{VCDisplayBackFace-ecbdb75a.js → VCDisplayBackFace-89b40163.js} +3 -3
- package/dist/cjs/{VCDisplayBackFace-ecbdb75a.js.map → VCDisplayBackFace-89b40163.js.map} +1 -1
- package/dist/cjs/{VCDisplayCard-8de5bb09.js → VCDisplayCard-129d6f10.js} +3 -3
- package/dist/cjs/{VCDisplayCard-8de5bb09.js.map → VCDisplayCard-129d6f10.js.map} +1 -1
- package/dist/cjs/{VCDisplayCard2-7b58036f.js → VCDisplayCard2-59f99f6d.js} +3 -3
- package/dist/cjs/{VCDisplayCard2-7b58036f.js.map → VCDisplayCard2-59f99f6d.js.map} +1 -1
- package/dist/cjs/{VCVerificationPill-b1d50716.js → VCVerificationPill-a6f26ac9.js} +2 -2
- package/dist/cjs/{VCVerificationPill-b1d50716.js.map → VCVerificationPill-a6f26ac9.js.map} +1 -1
- package/dist/cjs/X.svg +4 -0
- package/dist/cjs/{credential.helpers-ede99a07.js → credential.helpers-2ceeae3c.js} +2 -2
- package/dist/cjs/{credential.helpers-ede99a07.js.map → credential.helpers-2ceeae3c.js.map} +1 -1
- package/dist/cjs/{index-82de573c.js → index-c340a7f0.js} +1 -1
- package/dist/{esm/index-aa1098e1.js.map → cjs/index-c340a7f0.js.map} +1 -1
- package/dist/cjs/index.js +27 -14
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/index12.js +27 -14
- package/dist/cjs/index12.js.map +1 -1
- package/dist/cjs/index16.js +2 -2
- package/dist/cjs/index20.js +6 -4
- package/dist/cjs/index20.js.map +1 -1
- package/dist/cjs/index21.js +10 -3
- package/dist/cjs/index21.js.map +1 -1
- package/dist/cjs/index22.js +6 -15
- package/dist/cjs/index22.js.map +1 -1
- package/dist/cjs/index23.js +8 -31
- package/dist/cjs/index23.js.map +1 -1
- package/dist/cjs/index24.js +3 -2
- package/dist/cjs/index24.js.map +1 -1
- package/dist/cjs/index25.js +15 -3
- package/dist/cjs/index25.js.map +1 -1
- package/dist/cjs/index26.js +31 -3
- package/dist/cjs/index26.js.map +1 -1
- package/dist/cjs/index27.js +2 -16
- package/dist/cjs/index27.js.map +1 -1
- package/dist/cjs/index28.js +3 -3
- package/dist/cjs/index29.js +3 -3
- package/dist/cjs/index30.js +16 -14
- package/dist/cjs/index30.js.map +1 -1
- package/dist/cjs/index31.js +3 -22
- package/dist/cjs/index31.js.map +1 -1
- package/dist/cjs/index32.js +3 -13
- package/dist/cjs/index32.js.map +1 -1
- package/dist/cjs/index33.js +15 -17
- package/dist/cjs/index33.js.map +1 -1
- package/dist/cjs/index34.js +16 -5
- package/dist/cjs/index34.js.map +1 -1
- package/dist/cjs/index35.js +15 -3
- package/dist/cjs/index35.js.map +1 -1
- package/dist/cjs/index36.js +16 -3
- package/dist/cjs/index36.js.map +1 -1
- package/dist/cjs/index37.js +9 -4
- package/dist/cjs/index37.js.map +1 -1
- package/dist/cjs/index38.js +5 -10
- package/dist/cjs/index38.js.map +1 -1
- package/dist/cjs/index39.js +13 -0
- package/dist/cjs/index39.js.map +1 -0
- package/dist/cjs/index40.js +15 -0
- package/dist/cjs/index40.js.map +1 -0
- package/dist/cjs/index41.js +15 -0
- package/dist/cjs/index41.js.map +1 -0
- package/dist/cjs/notifications-56c6fc94.js +21 -0
- package/dist/cjs/notifications-56c6fc94.js.map +1 -0
- package/dist/cjs/{Notification-cd651569.js → types-c83b33ec.js} +39 -111
- package/dist/cjs/types-c83b33ec.js.map +1 -0
- package/dist/cjs/types-e4d9a257.js +25 -0
- package/dist/cjs/types-e4d9a257.js.map +1 -0
- package/dist/cjs/{types.esm-a0c2e427.js → types.esm-16460488.js} +56 -3
- package/dist/{esm/types.esm-03174a81.js.map → cjs/types.esm-16460488.js.map} +1 -1
- package/dist/esm/ArrowArcLeft.svg +4 -0
- package/dist/esm/Checkmark-d8b8f43d.js +52 -0
- package/dist/esm/Checkmark-d8b8f43d.js.map +1 -0
- package/dist/esm/{LearnCardCreditCardFrontFace-cf793917.js → LearnCardCreditCardFrontFace-c221facc.js} +2 -2
- package/dist/esm/{LearnCardCreditCardFrontFace-cf793917.js.map → LearnCardCreditCardFrontFace-c221facc.js.map} +1 -1
- package/dist/esm/Notification-0f58ef6a.js +88 -0
- package/dist/esm/Notification-0f58ef6a.js.map +1 -0
- package/dist/esm/NotificationBoostCard-134edf94.js +112 -0
- package/dist/esm/NotificationBoostCard-134edf94.js.map +1 -0
- package/dist/esm/NotificationUserAcceptedBoostCard-8c13bd3f.js +66 -0
- package/dist/esm/NotificationUserAcceptedBoostCard-8c13bd3f.js.map +1 -0
- package/dist/esm/NotificationUserCard-dbcc80f9.js +86 -0
- package/dist/esm/NotificationUserCard-dbcc80f9.js.map +1 -0
- package/dist/esm/{QRCodeCard-c57e2067.js → QRCodeCard-d147d009.js} +2 -2
- package/dist/esm/{QRCodeCard-c57e2067.js.map → QRCodeCard-d147d009.js.map} +1 -1
- package/dist/esm/SchoolIDCard-3b746226.js.map +1 -1
- package/dist/esm/{User-a54607e7.js → User-fd276ad5.js} +2 -50
- package/dist/esm/User-fd276ad5.js.map +1 -0
- package/dist/esm/{VCCard-f4aa0834.js → VCCard-261f5864.js} +3 -3
- package/dist/esm/{VCCard-f4aa0834.js.map → VCCard-261f5864.js.map} +1 -1
- package/dist/esm/{VCDisplayBackFace-ddb5d979.js → VCDisplayBackFace-a1801ec8.js} +3 -3
- package/dist/esm/{VCDisplayBackFace-ddb5d979.js.map → VCDisplayBackFace-a1801ec8.js.map} +1 -1
- package/dist/esm/{VCDisplayCard-079517c1.js → VCDisplayCard-2e5a9776.js} +3 -3
- package/dist/esm/{VCDisplayCard-079517c1.js.map → VCDisplayCard-2e5a9776.js.map} +1 -1
- package/dist/esm/{VCDisplayCard2-273a24c6.js → VCDisplayCard2-44f7f2cb.js} +3 -3
- package/dist/esm/{VCDisplayCard2-273a24c6.js.map → VCDisplayCard2-44f7f2cb.js.map} +1 -1
- package/dist/esm/{VCVerificationPill-0a2552f1.js → VCVerificationPill-e6c31a42.js} +2 -2
- package/dist/esm/{VCVerificationPill-0a2552f1.js.map → VCVerificationPill-e6c31a42.js.map} +1 -1
- package/dist/esm/X.svg +4 -0
- package/dist/esm/{credential.helpers-309b86e2.js → credential.helpers-8701c176.js} +2 -2
- package/dist/esm/{credential.helpers-309b86e2.js.map → credential.helpers-8701c176.js.map} +1 -1
- package/dist/esm/{index-aa1098e1.js → index-54ccc558.js} +1 -1
- package/dist/esm/index-54ccc558.js.map +1 -0
- package/dist/esm/index.js +21 -12
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/index12.js +21 -12
- package/dist/esm/index12.js.map +1 -1
- package/dist/esm/index16.js +2 -2
- package/dist/esm/index20.js +5 -3
- package/dist/esm/index20.js.map +1 -1
- package/dist/esm/index21.js +9 -2
- package/dist/esm/index21.js.map +1 -1
- package/dist/esm/index22.js +5 -13
- package/dist/esm/index22.js.map +1 -1
- package/dist/esm/index23.js +6 -26
- package/dist/esm/index23.js.map +1 -1
- package/dist/esm/index24.js +2 -1
- package/dist/esm/index24.js.map +1 -1
- package/dist/esm/index25.js +13 -1
- package/dist/esm/index25.js.map +1 -1
- package/dist/esm/index26.js +26 -2
- package/dist/esm/index26.js.map +1 -1
- package/dist/esm/index27.js +1 -15
- package/dist/esm/index27.js.map +1 -1
- package/dist/esm/index28.js +1 -2
- package/dist/esm/index28.js.map +1 -1
- package/dist/esm/index29.js +2 -2
- package/dist/esm/index30.js +15 -5
- package/dist/esm/index30.js.map +1 -1
- package/dist/esm/index31.js +2 -21
- package/dist/esm/index31.js.map +1 -1
- package/dist/esm/index32.js +2 -12
- package/dist/esm/index32.js.map +1 -1
- package/dist/esm/index33.js +6 -16
- package/dist/esm/index33.js.map +1 -1
- package/dist/esm/index34.js +15 -4
- package/dist/esm/index34.js.map +1 -1
- package/dist/esm/index35.js +10 -3
- package/dist/esm/index35.js.map +1 -1
- package/dist/esm/index36.js +15 -2
- package/dist/esm/index36.js.map +1 -1
- package/dist/esm/index37.js +8 -1
- package/dist/esm/index37.js.map +1 -1
- package/dist/esm/index38.js +5 -5
- package/dist/esm/index39.js +5 -0
- package/dist/esm/index39.js.map +1 -0
- package/dist/esm/index40.js +5 -0
- package/dist/esm/index40.js.map +1 -0
- package/dist/esm/index41.js +7 -0
- package/dist/esm/index41.js.map +1 -0
- package/dist/esm/notifications-009bbd80.js +18 -0
- package/dist/esm/notifications-009bbd80.js.map +1 -0
- package/dist/esm/{Notification-b7c41237.js → types-7081a9e5.js} +33 -104
- package/dist/esm/types-7081a9e5.js.map +1 -0
- package/dist/esm/types-b32d28d5.js +23 -0
- package/dist/esm/types-b32d28d5.js.map +1 -0
- package/dist/esm/{types.esm-03174a81.js → types.esm-e0b82727.js} +56 -3
- package/dist/{cjs/types.esm-a0c2e427.js.map → esm/types.esm-e0b82727.js.map} +1 -1
- package/dist/images/walletTrophy.png +0 -0
- package/dist/images/walletcurrency.png +0 -0
- package/dist/images/walletids.png +0 -0
- package/dist/images/walletjobhistory.png +0 -0
- package/dist/images/walletlearninghistory.png +0 -0
- package/dist/images/walletskills.png +0 -0
- package/dist/index.d.ts +70 -1
- package/dist/main.css +1 -1
- package/dist/main.js +1 -1
- package/package.json +5 -5
- package/dist/cjs/Notification-cd651569.js.map +0 -1
- package/dist/cjs/User-7408bdf0.js.map +0 -1
- package/dist/cjs/index-82de573c.js.map +0 -1
- package/dist/esm/Notification-b7c41237.js.map +0 -1
- package/dist/esm/User-a54607e7.js.map +0 -1
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
<svg width="24" height="24" viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
|
|
2
|
+
<path d="M8.63574 13.8862H2.63574V7.88623" stroke="#18224E" stroke-width="3" stroke-linecap="round" stroke-linejoin="round"/>
|
|
3
|
+
<path d="M20.9997 17.25C20.9997 15.47 20.4719 13.7299 19.4829 12.2499C18.494 10.7698 17.0884 9.61628 15.4439 8.93509C13.7993 8.2539 11.9897 8.07567 10.2439 8.42294C8.49806 8.7702 6.89441 9.62737 5.63574 10.886L2.63574 13.886" stroke="#18224E" stroke-width="3" stroke-linecap="round" stroke-linejoin="round"/>
|
|
4
|
+
</svg>
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
|
|
3
|
+
const Checkmark = ({ className = "" }) => {
|
|
4
|
+
return /* @__PURE__ */ React.createElement("svg", {
|
|
5
|
+
viewBox: "0 0 26 27",
|
|
6
|
+
fill: "transparent",
|
|
7
|
+
className,
|
|
8
|
+
"data-testid": "checkmark-icon"
|
|
9
|
+
}, /* @__PURE__ */ React.createElement("g", null, /* @__PURE__ */ React.createElement("path", {
|
|
10
|
+
d: "M21 7.25049L10.5 17.75L5.25 12.5005",
|
|
11
|
+
stroke: "currentColor",
|
|
12
|
+
strokeWidth: "2",
|
|
13
|
+
strokeLinecap: "round",
|
|
14
|
+
strokeLinejoin: "round"
|
|
15
|
+
})), /* @__PURE__ */ React.createElement("defs", null, /* @__PURE__ */ React.createElement("filter", {
|
|
16
|
+
id: "filter0_d_1165_663",
|
|
17
|
+
x: "0.25",
|
|
18
|
+
y: "6.25049",
|
|
19
|
+
filterUnits: "userSpaceOnUse",
|
|
20
|
+
colorInterpolationFilters: "sRGB"
|
|
21
|
+
}, /* @__PURE__ */ React.createElement("feFlood", {
|
|
22
|
+
floodOpacity: "0",
|
|
23
|
+
result: "BackgroundImageFix"
|
|
24
|
+
}), /* @__PURE__ */ React.createElement("feColorMatrix", {
|
|
25
|
+
in: "SourceAlpha",
|
|
26
|
+
type: "matrix",
|
|
27
|
+
values: "0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0",
|
|
28
|
+
result: "hardAlpha"
|
|
29
|
+
}), /* @__PURE__ */ React.createElement("feOffset", {
|
|
30
|
+
dy: "4"
|
|
31
|
+
}), /* @__PURE__ */ React.createElement("feGaussianBlur", {
|
|
32
|
+
stdDeviation: "2"
|
|
33
|
+
}), /* @__PURE__ */ React.createElement("feComposite", {
|
|
34
|
+
in2: "hardAlpha",
|
|
35
|
+
operator: "out"
|
|
36
|
+
}), /* @__PURE__ */ React.createElement("feColorMatrix", {
|
|
37
|
+
type: "matrix",
|
|
38
|
+
values: "0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.25 0"
|
|
39
|
+
}), /* @__PURE__ */ React.createElement("feBlend", {
|
|
40
|
+
mode: "normal",
|
|
41
|
+
in2: "BackgroundImageFix",
|
|
42
|
+
result: "effect1_dropShadow_1165_663"
|
|
43
|
+
}), /* @__PURE__ */ React.createElement("feBlend", {
|
|
44
|
+
mode: "normal",
|
|
45
|
+
in: "SourceGraphic",
|
|
46
|
+
in2: "effect1_dropShadow_1165_663",
|
|
47
|
+
result: "shape"
|
|
48
|
+
}))));
|
|
49
|
+
};
|
|
50
|
+
|
|
51
|
+
export { Checkmark as C };
|
|
52
|
+
//# sourceMappingURL=Checkmark-d8b8f43d.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Checkmark-d8b8f43d.js","sources":["../../src/components/svgs/Checkmark.tsx"],"sourcesContent":["import React from 'react';\n\nexport const Checkmark: React.FC<{ className?: string }> = ({ className = '' }) => {\n return (\n <svg\n viewBox=\"0 0 26 27\"\n fill=\"transparent\"\n className={className}\n data-testid=\"checkmark-icon\"\n >\n <g>\n <path\n d=\"M21 7.25049L10.5 17.75L5.25 12.5005\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </g>\n <defs>\n <filter\n id=\"filter0_d_1165_663\"\n x=\"0.25\"\n y=\"6.25049\"\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 <feGaussianBlur stdDeviation=\"2\" />\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_1165_663\"\n />\n <feBlend\n mode=\"normal\"\n in=\"SourceGraphic\"\n in2=\"effect1_dropShadow_1165_663\"\n result=\"shape\"\n />\n </filter>\n </defs>\n </svg>\n );\n};\n\nexport default Checkmark;\n"],"names":[],"mappings":";;AAEO,MAAM,SAA8C,GAAA,CAAC,EAAE,SAAA,GAAY,IAAS,KAAA;AAC/E,EAAA,uBACK,KAAA,CAAA,aAAA,CAAA,KAAA,EAAA;AAAA,IACG,OAAQ,EAAA,WAAA;AAAA,IACR,IAAK,EAAA,aAAA;AAAA,IACL,SAAA;AAAA,IACA,aAAY,EAAA,gBAAA;AAAA,GAEZ,kBAAA,KAAA,CAAA,aAAA,CAAC,2BACI,KAAA,CAAA,aAAA,CAAA,MAAA,EAAA;AAAA,IACG,CAAE,EAAA,qCAAA;AAAA,IACF,MAAO,EAAA,cAAA;AAAA,IACP,WAAY,EAAA,GAAA;AAAA,IACZ,aAAc,EAAA,OAAA;AAAA,IACd,cAAe,EAAA,OAAA;AAAA,GACnB,CACJ,CAAA,kBACC,KAAA,CAAA,aAAA,CAAA,MAAA,EAAA,IAAA,kBACI,KAAA,CAAA,aAAA,CAAA,QAAA,EAAA;AAAA,IACG,EAAG,EAAA,oBAAA;AAAA,IACH,CAAE,EAAA,MAAA;AAAA,IACF,CAAE,EAAA,SAAA;AAAA,IACF,WAAY,EAAA,gBAAA;AAAA,IACZ,yBAA0B,EAAA,MAAA;AAAA,GAAA,kBAEzB,KAAA,CAAA,aAAA,CAAA,SAAA,EAAA;AAAA,IAAQ,YAAa,EAAA,GAAA;AAAA,IAAI,MAAO,EAAA,oBAAA;AAAA,GAAqB,mBACrD,KAAA,CAAA,aAAA,CAAA,eAAA,EAAA;AAAA,IACG,EAAG,EAAA,aAAA;AAAA,IACH,IAAK,EAAA,QAAA;AAAA,IACL,MAAO,EAAA,2CAAA;AAAA,IACP,MAAO,EAAA,WAAA;AAAA,GACX,mBACC,KAAA,CAAA,aAAA,CAAA,UAAA,EAAA;AAAA,IAAS,EAAG,EAAA,GAAA;AAAA,GAAI,mBAChB,KAAA,CAAA,aAAA,CAAA,gBAAA,EAAA;AAAA,IAAe,YAAa,EAAA,GAAA;AAAA,GAAI,mBAChC,KAAA,CAAA,aAAA,CAAA,aAAA,EAAA;AAAA,IAAY,GAAI,EAAA,WAAA;AAAA,IAAY,QAAS,EAAA,KAAA;AAAA,GAAM,mBAC3C,KAAA,CAAA,aAAA,CAAA,eAAA,EAAA;AAAA,IACG,IAAK,EAAA,QAAA;AAAA,IACL,MAAO,EAAA,4CAAA;AAAA,GACX,mBACC,KAAA,CAAA,aAAA,CAAA,SAAA,EAAA;AAAA,IACG,IAAK,EAAA,QAAA;AAAA,IACL,GAAI,EAAA,oBAAA;AAAA,IACJ,MAAO,EAAA,6BAAA;AAAA,GACX,mBACC,KAAA,CAAA,aAAA,CAAA,SAAA,EAAA;AAAA,IACG,IAAK,EAAA,QAAA;AAAA,IACL,EAAG,EAAA,eAAA;AAAA,IACH,GAAI,EAAA,6BAAA;AAAA,IACJ,MAAO,EAAA,OAAA;AAAA,GACX,CACJ,CACJ,CACJ,CAAA,CAAA;AAER;;;;"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
|
-
import { Q as QRCodeSVG } from './index-
|
|
2
|
+
import { Q as QRCodeSVG } from './index-54ccc558.js';
|
|
3
3
|
import CardChip from './card-chip.svg';
|
|
4
4
|
import MasterCardLogo from './master-card-logo.svg';
|
|
5
5
|
|
|
@@ -67,4 +67,4 @@ const LearnCardCreditCardFrontFace = ({
|
|
|
67
67
|
};
|
|
68
68
|
|
|
69
69
|
export { LearnCardCreditCardFrontFace as L };
|
|
70
|
-
//# sourceMappingURL=LearnCardCreditCardFrontFace-
|
|
70
|
+
//# sourceMappingURL=LearnCardCreditCardFrontFace-c221facc.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"LearnCardCreditCardFrontFace-
|
|
1
|
+
{"version":3,"file":"LearnCardCreditCardFrontFace-c221facc.js","sources":["../../src/components/LearnCardCreditCardFrontFace/LearnCardCreditCardFrontFace.tsx"],"sourcesContent":["import React from 'react';\nimport { QRCodeSVG } from 'qrcode.react';\n\nimport { LearnCardCreditCardFrontFaceProps } from './types';\n\nimport CardChip from '../../assets/images/card-chip.svg';\nimport MasterCardLogo from '../../assets/images/master-card-logo.svg';\n\nexport const LearnCardCreditCardFrontFace: React.FC<LearnCardCreditCardFrontFaceProps> = ({\n userImage,\n userImageComponent = null,\n qrCodeValue,\n className,\n showActionButton = false,\n actionButtonText = 'Open Card',\n onClick = () => {},\n children,\n}) => {\n let userImageEl: React.ReactNode | null = null;\n\n if (userImage) {\n userImageEl = (\n <div className=\"inline-block relative overflow-hidden rounded-full shadow-3xl h-0 bg-white w-1/2 pb-[50%] mt-2 ml-4\">\n <img\n className=\"w-full h-full absolute rounded-full object-cover border-solid border-2 border-white\"\n src={userImage}\n alt=\"user image\"\n data-testid=\"credit-card-frontface-userImg\"\n />\n </div>\n );\n } else if (!userImage && userImageComponent) {\n userImageEl = userImageComponent;\n }\n\n return (\n <div\n className={`flex justify-center items-center max-w-[375px] rounded-[20px] ${className}`}\n >\n <div\n className={`flex flex-row justify-center items-start pt-9 w-full min-h-[220px] rounded-[20px] shadow-3xl relative overflow-hidden credit-card-front-face`}\n >\n <div className=\"absolute top-[-40px] left-0 w-[55%] h-[140%] rounded-tr-[150px] rounded-br-[150px] bg-grayscale-900 credit-card-bubble\" />\n {showActionButton && (\n <button\n className=\"absolute top-2 right-4 bg-grayscale-500 border-[2px] rounded-3xl border-solid border-color-grayscale-900 min-w-[110px] p-[2px] font-bold text-xs tracking-wide leading-snug text-center text-white\"\n onClick={onClick}\n data-testid=\"credit-card-frontface-button\"\n >\n {actionButtonText}\n </button>\n )}\n <div className=\"flex flex-row justify-between items-start w-full h-full relative\">\n <div className=\"flex flex-1 flex-col\">\n <div className=\"pl-8\">\n <p className=\"w-full text-xs text-white font-bold tracking-[7px] mb-2 credit-card-front-face-title\">\n LEARNCARD\n </p>\n <img\n src={CardChip ?? ''}\n alt=\"card chip\"\n className=\"h-[30px] w-[42px]\"\n />\n </div>\n\n {userImageEl}\n </div>\n\n {qrCodeValue && (\n <div className=\"flex flex-1 justify-center items-center relative pl-10 credit-card-qr-code-container\">\n <div className=\"h-auto relative qr-code-container\">\n {/* <div className=\"qr-code-upper-left-yellow\" />\n <div className=\"qr-code-upper-right-pink-square\" />\n <div className=\"qr-code-bottom-left-purple-square\" />\n <div className=\"qr-code-green-blob\" />\n <div className=\"qr-code-green-blob-2\" />\n <div className=\"qr-code-blue-blob\" />\n <div className=\"qr-code-orange-blob\" /> */}\n <QRCodeSVG\n className=\"h-full w-full\"\n value={qrCodeValue}\n data-testid=\"credit-card-qr-code\"\n bgColor=\"transparent\"\n // fgColor=\"#999999\"\n />\n </div>\n </div>\n )}\n\n <img\n src={MasterCardLogo ?? ''}\n alt=\"mastercard icon\"\n className=\"absolute bottom-[-8px] right-4 learn-card-mastercard-logo\"\n />\n </div>\n </div>\n {children}\n </div>\n );\n};\n\nexport default LearnCardCreditCardFrontFace;\n"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
import React, { useState, useEffect } from 'react';
|
|
2
|
+
import { N as NotificationTypeStyles } from './types-7081a9e5.js';
|
|
3
|
+
import { N as NotificationTypeEnum } from './notifications-009bbd80.js';
|
|
4
|
+
import { C as Checkmark } from './Checkmark-d8b8f43d.js';
|
|
5
|
+
|
|
6
|
+
const Notification = ({
|
|
7
|
+
title,
|
|
8
|
+
issuerImage,
|
|
9
|
+
issueDate,
|
|
10
|
+
className,
|
|
11
|
+
notificationType = NotificationTypeEnum.Achievement,
|
|
12
|
+
handleViewOnClick = () => {
|
|
13
|
+
},
|
|
14
|
+
claimStatus = false,
|
|
15
|
+
handleClaimOnClick = () => {
|
|
16
|
+
},
|
|
17
|
+
loadingState = false
|
|
18
|
+
}) => {
|
|
19
|
+
const [isClaimed, setIsClaimed] = useState(claimStatus || false);
|
|
20
|
+
const [isLoading, setIsLoading] = useState(loadingState || false);
|
|
21
|
+
useEffect(() => {
|
|
22
|
+
setIsClaimed(claimStatus);
|
|
23
|
+
}, [claimStatus]);
|
|
24
|
+
useEffect(() => {
|
|
25
|
+
setIsLoading(loadingState);
|
|
26
|
+
}, [loadingState]);
|
|
27
|
+
const {
|
|
28
|
+
IconComponent,
|
|
29
|
+
iconCircleStyles,
|
|
30
|
+
textStyles,
|
|
31
|
+
viewButtonStyles,
|
|
32
|
+
claimedButtonStyles,
|
|
33
|
+
unclaimedButtonStyles,
|
|
34
|
+
typeText
|
|
35
|
+
} = NotificationTypeStyles[notificationType];
|
|
36
|
+
const claimButtonStyles = isClaimed ? claimedButtonStyles : unclaimedButtonStyles;
|
|
37
|
+
let buttonText = "";
|
|
38
|
+
if (isClaimed) {
|
|
39
|
+
buttonText = "Claimed";
|
|
40
|
+
} else if (!isClaimed) {
|
|
41
|
+
buttonText = "Claim";
|
|
42
|
+
}
|
|
43
|
+
return /* @__PURE__ */ React.createElement("div", {
|
|
44
|
+
className: `flex justify-center items-center relative w-full rounded-3xl shadow-2xl py-3 bg-white ${className}`
|
|
45
|
+
}, /* @__PURE__ */ React.createElement("div", {
|
|
46
|
+
className: `absolute flex items-center justify-center top-2 right-2 h-8 w-8 overflow-hidden rounded-full z-10 ${iconCircleStyles}`
|
|
47
|
+
}, /* @__PURE__ */ React.createElement(IconComponent, {
|
|
48
|
+
className: "h-4/5 text-white"
|
|
49
|
+
})), /* @__PURE__ */ React.createElement("div", {
|
|
50
|
+
className: "flex flex-col justify-center items-center relative w-11/12"
|
|
51
|
+
}, /* @__PURE__ */ React.createElement("div", {
|
|
52
|
+
className: "flex flex-row items-center justify-start w-full"
|
|
53
|
+
}, /* @__PURE__ */ React.createElement("div", {
|
|
54
|
+
className: `h-12 w-12 max-h-12 max-w-[48px] min-h-[48px] min-w-[48px] overflow-hidden rounded-full ${iconCircleStyles}`
|
|
55
|
+
}, /* @__PURE__ */ React.createElement("img", {
|
|
56
|
+
src: issuerImage,
|
|
57
|
+
alt: "issuer image",
|
|
58
|
+
className: "w-full h-full object-cover"
|
|
59
|
+
})), /* @__PURE__ */ React.createElement("div", {
|
|
60
|
+
className: "text-left ml-3"
|
|
61
|
+
}, /* @__PURE__ */ React.createElement("h4", {
|
|
62
|
+
className: "font-bold tracking-wide line-clamp-1 text-black",
|
|
63
|
+
"data-testid": "notification-title"
|
|
64
|
+
}, title), /* @__PURE__ */ React.createElement("p", {
|
|
65
|
+
className: `font-semibold p-0 m-0 leading-none tracking-wide line-clamp-1 ${textStyles}`,
|
|
66
|
+
"data-testid": "notification-type"
|
|
67
|
+
}, typeText, " ", /* @__PURE__ */ React.createElement("span", {
|
|
68
|
+
className: "text-grayscale-600 normal-case font-normal text-sm",
|
|
69
|
+
"data-testid": "notification-cred-issue-date"
|
|
70
|
+
}, "\u2022 ", issueDate)))), /* @__PURE__ */ React.createElement("div", {
|
|
71
|
+
className: "flex items-center justify-between w-full mt-3"
|
|
72
|
+
}, /* @__PURE__ */ React.createElement("button", {
|
|
73
|
+
onClick: handleViewOnClick,
|
|
74
|
+
className: `flex-1 rounded-[24px] border-solid border-2 bg-white font-semibold mr-2 py-2 px-3 tracking-wide ${viewButtonStyles}`,
|
|
75
|
+
role: "button",
|
|
76
|
+
name: "notification-view-button"
|
|
77
|
+
}, "View"), /* @__PURE__ */ React.createElement("button", {
|
|
78
|
+
className: `flex items-center justify-center flex-1 rounded-[24px] border-2 border-solid font-semibold py-2 px-3 tracking-wide ${claimButtonStyles}`,
|
|
79
|
+
onClick: handleClaimOnClick,
|
|
80
|
+
role: "button",
|
|
81
|
+
name: "notification-claim-button"
|
|
82
|
+
}, isClaimed && /* @__PURE__ */ React.createElement(Checkmark, {
|
|
83
|
+
className: "h-[24px] p-0 m-0"
|
|
84
|
+
}), " ", isLoading ? "Loading..." : buttonText))));
|
|
85
|
+
};
|
|
86
|
+
|
|
87
|
+
export { Notification as N };
|
|
88
|
+
//# sourceMappingURL=Notification-0f58ef6a.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Notification-0f58ef6a.js","sources":["../../src/components/Notification/Notification.tsx"],"sourcesContent":["import React, { useState, useEffect } from 'react';\n\nimport { NotificationProps, NotificationTypeStyles } from './types';\nimport { NotificationTypeEnum } from '../../constants/notifications';\n\nimport Checkmark from '../svgs/Checkmark';\n\nexport const Notification: React.FC<NotificationProps> = ({\n title,\n issuerImage,\n issueDate,\n className,\n notificationType = NotificationTypeEnum.Achievement,\n handleViewOnClick = () => {},\n claimStatus = false,\n handleClaimOnClick = () => {},\n loadingState = false,\n}) => {\n const [isClaimed, setIsClaimed] = useState<boolean>(claimStatus || false);\n const [isLoading, setIsLoading] = useState<boolean>(loadingState || false);\n\n useEffect(() => {\n setIsClaimed(claimStatus);\n }, [claimStatus]);\n\n useEffect(() => {\n setIsLoading(loadingState);\n }, [loadingState]);\n\n const {\n IconComponent,\n iconCircleStyles,\n textStyles,\n viewButtonStyles,\n claimedButtonStyles,\n unclaimedButtonStyles,\n typeText,\n } = NotificationTypeStyles[notificationType];\n\n const claimButtonStyles = isClaimed ? claimedButtonStyles : unclaimedButtonStyles;\n\n let buttonText: string = '';\n\n if (isClaimed) {\n buttonText = 'Claimed';\n } else if (!isClaimed) {\n buttonText = 'Claim';\n }\n\n return (\n <div\n className={`flex justify-center items-center relative w-full rounded-3xl shadow-2xl py-3 bg-white ${className}`}\n >\n <div\n className={`absolute flex items-center justify-center top-2 right-2 h-8 w-8 overflow-hidden rounded-full z-10 ${iconCircleStyles}`}\n >\n <IconComponent className=\"h-4/5 text-white\" />\n </div>\n <div className=\"flex flex-col justify-center items-center relative w-11/12\">\n <div className=\"flex flex-row items-center justify-start w-full\">\n <div\n className={`h-12 w-12 max-h-12 max-w-[48px] min-h-[48px] min-w-[48px] overflow-hidden rounded-full ${iconCircleStyles}`}\n >\n <img\n src={issuerImage}\n alt=\"issuer image\"\n className=\"w-full h-full object-cover\"\n />\n </div>\n <div className=\"text-left ml-3\">\n <h4\n className=\"font-bold tracking-wide line-clamp-1 text-black\"\n data-testid=\"notification-title\"\n >\n {title}\n </h4>\n <p\n className={`font-semibold p-0 m-0 leading-none tracking-wide line-clamp-1 ${textStyles}`}\n data-testid=\"notification-type\"\n >\n {typeText}{' '}\n <span\n className=\"text-grayscale-600 normal-case font-normal text-sm\"\n data-testid=\"notification-cred-issue-date\"\n >\n • {issueDate}\n </span>\n </p>\n </div>\n </div>\n <div className=\"flex items-center justify-between w-full mt-3\">\n <button\n onClick={handleViewOnClick}\n className={`flex-1 rounded-[24px] border-solid border-2 bg-white font-semibold mr-2 py-2 px-3 tracking-wide ${viewButtonStyles}`}\n role=\"button\"\n name=\"notification-view-button\"\n >\n View\n </button>\n <button\n className={`flex items-center justify-center flex-1 rounded-[24px] border-2 border-solid font-semibold py-2 px-3 tracking-wide ${claimButtonStyles}`}\n onClick={handleClaimOnClick}\n role=\"button\"\n name=\"notification-claim-button\"\n >\n {isClaimed && <Checkmark className=\"h-[24px] p-0 m-0\" />}{' '}\n {isLoading ? 'Loading...' : buttonText}\n </button>\n </div>\n </div>\n </div>\n );\n};\n\nexport default Notification;\n"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,112 @@
|
|
|
1
|
+
import React, { useState, useEffect } from 'react';
|
|
2
|
+
import X from './X.svg';
|
|
3
|
+
import { N as NotificationTypeStyles } from './types-7081a9e5.js';
|
|
4
|
+
import { N as NotificationTypeEnum } from './notifications-009bbd80.js';
|
|
5
|
+
import DefaultFace from './default-face.jpeg';
|
|
6
|
+
import { C as Checkmark } from './Checkmark-d8b8f43d.js';
|
|
7
|
+
import ArrowArcLeft from './ArrowArcLeft.svg';
|
|
8
|
+
|
|
9
|
+
const NotificationBoostCard = ({
|
|
10
|
+
title,
|
|
11
|
+
customThumbComponent,
|
|
12
|
+
className,
|
|
13
|
+
thumbImage,
|
|
14
|
+
notificationType = NotificationTypeEnum.Achievement,
|
|
15
|
+
issueDate,
|
|
16
|
+
issuerInfo,
|
|
17
|
+
claimStatus = false,
|
|
18
|
+
loadingState = false,
|
|
19
|
+
handleButtonClick,
|
|
20
|
+
handleCancelClick,
|
|
21
|
+
handleCardClick,
|
|
22
|
+
showIssuerInfo = true,
|
|
23
|
+
isArchived
|
|
24
|
+
}) => {
|
|
25
|
+
var _a, _b;
|
|
26
|
+
const [isClaimed, setIsClaimed] = useState(claimStatus || false);
|
|
27
|
+
const [isLoading, setIsLoading] = useState(loadingState || false);
|
|
28
|
+
useEffect(() => {
|
|
29
|
+
setIsClaimed(claimStatus);
|
|
30
|
+
}, [claimStatus]);
|
|
31
|
+
useEffect(() => {
|
|
32
|
+
setIsLoading(loadingState);
|
|
33
|
+
}, [loadingState]);
|
|
34
|
+
const {
|
|
35
|
+
iconCircleStyles,
|
|
36
|
+
textStyles,
|
|
37
|
+
viewButtonStyles,
|
|
38
|
+
claimedButtonStyles,
|
|
39
|
+
unclaimedButtonStyles,
|
|
40
|
+
typeText
|
|
41
|
+
} = NotificationTypeStyles[notificationType];
|
|
42
|
+
const claimButtonStyles = isClaimed ? claimedButtonStyles : unclaimedButtonStyles;
|
|
43
|
+
let buttonText = "";
|
|
44
|
+
if (isClaimed) {
|
|
45
|
+
buttonText = "Claimed";
|
|
46
|
+
} else if (!isClaimed) {
|
|
47
|
+
buttonText = "Claim";
|
|
48
|
+
}
|
|
49
|
+
return /* @__PURE__ */ React.createElement("div", {
|
|
50
|
+
className: `flex justify-start max-w-[600px] items-start relative w-full rounded-3xl shadow-bottom py-[10px] px-[10px] bg-white ${className}`
|
|
51
|
+
}, /* @__PURE__ */ React.createElement("div", {
|
|
52
|
+
className: "notification-card-left-side px-[0px] flex"
|
|
53
|
+
}, !customThumbComponent && /* @__PURE__ */ React.createElement("div", {
|
|
54
|
+
onClick: handleCardClick,
|
|
55
|
+
className: `overflow-hidden cursor-pointer w-[90px] h-[90px] rounded-full flex items-start ${iconCircleStyles} notification-card-thumbnail`
|
|
56
|
+
}, /* @__PURE__ */ React.createElement("img", {
|
|
57
|
+
src: thumbImage,
|
|
58
|
+
alt: "Notification Thumb",
|
|
59
|
+
className: "w-full h-full w-[100px] h-[100px] object-cover"
|
|
60
|
+
})), customThumbComponent && { customThumbComponent }), /* @__PURE__ */ React.createElement("div", {
|
|
61
|
+
className: "flex flex-col justify-center items-start relative w-full"
|
|
62
|
+
}, /* @__PURE__ */ React.createElement("div", {
|
|
63
|
+
className: "text-left ml-3 flex flex-col items-start justify-start w-full"
|
|
64
|
+
}, /* @__PURE__ */ React.createElement("h4", {
|
|
65
|
+
onClick: handleCardClick,
|
|
66
|
+
className: "cursor-pointer font-bold tracking-wide line-clamp-2 text-black text-[14px] pr-[20px] notification-card-title",
|
|
67
|
+
"data-testid": "notification-title"
|
|
68
|
+
}, title), /* @__PURE__ */ React.createElement("p", {
|
|
69
|
+
className: `font-semibold p-0 mt-[10px] leading-none tracking-wide line-clamp-1 text-[12px] notification-card-type-text ${textStyles}`,
|
|
70
|
+
"data-testid": "notification-type"
|
|
71
|
+
}, typeText, " ", issueDate && /* @__PURE__ */ React.createElement("span", {
|
|
72
|
+
className: "text-grayscale-600 normal-case font-normal text-[12px] notification-card-type-issue-date",
|
|
73
|
+
"data-testid": "notification-cred-issue-date"
|
|
74
|
+
}, "\u2022 ", issueDate)), showIssuerInfo && /* @__PURE__ */ React.createElement("div", {
|
|
75
|
+
className: "notification-card-issuer-info flex items-center mt-[10px]"
|
|
76
|
+
}, /* @__PURE__ */ React.createElement("div", {
|
|
77
|
+
className: "profile-thumb-img border-[2px] border-white border-solid vc-issuee-image h-[35px] w-[35px] rounded-full overflow-hidden mx-[-5px]"
|
|
78
|
+
}, /* @__PURE__ */ React.createElement("img", {
|
|
79
|
+
className: "h-full w-full object-cover",
|
|
80
|
+
src: (issuerInfo == null ? void 0 : issuerInfo.image) || DefaultFace,
|
|
81
|
+
alt: "profile"
|
|
82
|
+
})), /* @__PURE__ */ React.createElement("div", {
|
|
83
|
+
className: "notification-issuer-info-text flex items-center px-[10px]"
|
|
84
|
+
}, /* @__PURE__ */ React.createElement("p", {
|
|
85
|
+
className: "text-[13px] text-gray-700 font-medium"
|
|
86
|
+
}, "From ", (issuerInfo == null ? void 0 : issuerInfo.fullName) || (issuerInfo == null ? void 0 : issuerInfo.displayName)))), /* @__PURE__ */ React.createElement("div", {
|
|
87
|
+
className: "flex items-center justify-between mt-3 w-full"
|
|
88
|
+
}, /* @__PURE__ */ React.createElement("button", {
|
|
89
|
+
className: `notification-claim-btn flex items-center mr-[15px] w-[143px] justify-center flex-1 rounded-[24px] border-2 border-solid font-semibold py-2 px-3 tracking-wide ${claimButtonStyles}`,
|
|
90
|
+
onClick: handleButtonClick,
|
|
91
|
+
role: "button",
|
|
92
|
+
name: "notification-claim-button"
|
|
93
|
+
}, isClaimed && /* @__PURE__ */ React.createElement(Checkmark, {
|
|
94
|
+
className: "h-[24px] p-0 m-0"
|
|
95
|
+
}), " ", isLoading ? "Loading..." : buttonText), /* @__PURE__ */ React.createElement("button", {
|
|
96
|
+
onClick: handleCancelClick,
|
|
97
|
+
className: `rounded-[24px] flex items-center justify-center h-[42px] w-[42px] shadow-bottom bg-white font-semibold mr-2 p-[0px] tracking-wide ${viewButtonStyles}`,
|
|
98
|
+
role: "button",
|
|
99
|
+
name: "notification-view-button"
|
|
100
|
+
}, !isArchived && /* @__PURE__ */ React.createElement("img", {
|
|
101
|
+
src: (_a = X) != null ? _a : "",
|
|
102
|
+
alt: "Cancel",
|
|
103
|
+
className: "notification-card-x"
|
|
104
|
+
}), isArchived && /* @__PURE__ */ React.createElement("img", {
|
|
105
|
+
src: (_b = ArrowArcLeft) != null ? _b : "",
|
|
106
|
+
alt: "Cancel",
|
|
107
|
+
className: "notification-card-x"
|
|
108
|
+
}))))));
|
|
109
|
+
};
|
|
110
|
+
|
|
111
|
+
export { NotificationBoostCard as N };
|
|
112
|
+
//# sourceMappingURL=NotificationBoostCard-134edf94.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NotificationBoostCard-134edf94.js","sources":["../../src/components/NotificationBoostCard/NotificationBoostCard.tsx"],"sourcesContent":["import React, { useState, useEffect } from 'react';\nimport X from '../../assets/images/X.svg';\nimport { NotificationBoostCardProps } from './types';\nimport { NotificationTypeStyles } from '../Notification/types';\nimport { NotificationTypeEnum } from '../../constants/notifications';\nimport DefaultFace from '../../assets/images/default-face.jpeg';\nimport Checkmark from '../svgs/Checkmark';\nimport ArrowArcLeft from '../../assets/images/ArrowArcLeft.svg';\n\nexport const NotificationBoostCard: React.FC<NotificationBoostCardProps> = ({\n title,\n customThumbComponent,\n className,\n thumbImage,\n notificationType = NotificationTypeEnum.Achievement,\n issueDate,\n issuerInfo,\n claimStatus = false,\n loadingState = false,\n handleButtonClick,\n handleCancelClick,\n handleCardClick,\n showIssuerInfo = true,\n isArchived,\n}) => {\n const [isClaimed, setIsClaimed] = useState<boolean>(claimStatus || false);\n const [isLoading, setIsLoading] = useState<boolean>(loadingState || false);\n\n useEffect(() => {\n setIsClaimed(claimStatus);\n }, [claimStatus]);\n\n useEffect(() => {\n setIsLoading(loadingState);\n }, [loadingState]);\n\n const {\n iconCircleStyles,\n textStyles,\n viewButtonStyles,\n claimedButtonStyles,\n unclaimedButtonStyles,\n typeText,\n } = NotificationTypeStyles[notificationType];\n\n const claimButtonStyles = isClaimed ? claimedButtonStyles : unclaimedButtonStyles;\n\n let buttonText: string = '';\n\n if (isClaimed) {\n buttonText = 'Claimed';\n } else if (!isClaimed) {\n buttonText = 'Claim';\n }\n\n return (\n <div\n className={`flex justify-start max-w-[600px] items-start relative w-full rounded-3xl shadow-bottom py-[10px] px-[10px] bg-white ${className}`}\n >\n <div className=\"notification-card-left-side px-[0px] flex\">\n {!customThumbComponent && (\n <div\n onClick={handleCardClick}\n className={`overflow-hidden cursor-pointer w-[90px] h-[90px] rounded-full flex items-start ${iconCircleStyles} notification-card-thumbnail`}\n >\n <img\n src={thumbImage}\n alt=\"Notification Thumb\"\n className=\"w-full h-full w-[100px] h-[100px] object-cover\"\n />\n </div>\n )}\n {customThumbComponent && { customThumbComponent }}\n </div>\n <div className=\"flex flex-col justify-center items-start relative w-full\">\n <div className=\"text-left ml-3 flex flex-col items-start justify-start w-full\">\n <h4\n onClick={handleCardClick}\n className=\"cursor-pointer font-bold tracking-wide line-clamp-2 text-black text-[14px] pr-[20px] notification-card-title\"\n data-testid=\"notification-title\"\n >\n {title}\n </h4>\n <p\n className={`font-semibold p-0 mt-[10px] leading-none tracking-wide line-clamp-1 text-[12px] notification-card-type-text ${textStyles}`}\n data-testid=\"notification-type\"\n >\n {typeText}{' '}\n {issueDate && (\n <span\n className=\"text-grayscale-600 normal-case font-normal text-[12px] notification-card-type-issue-date\"\n data-testid=\"notification-cred-issue-date\"\n >\n • {issueDate}\n </span>\n )}\n </p>\n\n {showIssuerInfo && (\n <div className=\"notification-card-issuer-info flex items-center mt-[10px]\">\n <div className=\"profile-thumb-img border-[2px] border-white border-solid vc-issuee-image h-[35px] w-[35px] rounded-full overflow-hidden mx-[-5px]\">\n <img\n className=\"h-full w-full object-cover\"\n src={issuerInfo?.image || DefaultFace}\n alt=\"profile\"\n />\n </div>\n <div className=\"notification-issuer-info-text flex items-center px-[10px]\">\n <p className=\"text-[13px] text-gray-700 font-medium\">\n From {issuerInfo?.fullName || issuerInfo?.displayName}\n </p>\n </div>\n </div>\n )}\n\n <div className=\"flex items-center justify-between mt-3 w-full\">\n <button\n className={`notification-claim-btn flex items-center mr-[15px] w-[143px] justify-center flex-1 rounded-[24px] border-2 border-solid font-semibold py-2 px-3 tracking-wide ${claimButtonStyles}`}\n onClick={handleButtonClick}\n role=\"button\"\n name=\"notification-claim-button\"\n >\n {isClaimed && <Checkmark className=\"h-[24px] p-0 m-0\" />}{' '}\n {isLoading ? 'Loading...' : buttonText}\n </button>\n\n <button\n onClick={handleCancelClick}\n className={`rounded-[24px] flex items-center justify-center h-[42px] w-[42px] shadow-bottom bg-white font-semibold mr-2 p-[0px] tracking-wide ${viewButtonStyles}`}\n role=\"button\"\n name=\"notification-view-button\"\n >\n {!isArchived && (\n <img src={X ?? ''} alt=\"Cancel\" className=\"notification-card-x\" />\n )}\n {isArchived && (\n <img\n src={ArrowArcLeft ?? ''}\n alt=\"Cancel\"\n className=\"notification-card-x\"\n />\n )}\n </button>\n </div>\n </div>\n </div>\n </div>\n );\n};\n\nexport default NotificationBoostCard;\n"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
import React, { useState, useEffect } from 'react';
|
|
2
|
+
import X from './X.svg';
|
|
3
|
+
import { U as UserNotificationTypeStyles } from './types-b32d28d5.js';
|
|
4
|
+
import { U as UserNotificationTypeEnum } from './notifications-009bbd80.js';
|
|
5
|
+
import ArrowArcLeft from './ArrowArcLeft.svg';
|
|
6
|
+
|
|
7
|
+
const NotificationUserAcceptedBoostCard = ({
|
|
8
|
+
title,
|
|
9
|
+
customThumbComponent,
|
|
10
|
+
className,
|
|
11
|
+
thumbImage,
|
|
12
|
+
notificationType = UserNotificationTypeEnum.AcceptedBoost,
|
|
13
|
+
issueDate,
|
|
14
|
+
loadingState = false,
|
|
15
|
+
handleCancelClick,
|
|
16
|
+
isArchived
|
|
17
|
+
}) => {
|
|
18
|
+
var _a, _b;
|
|
19
|
+
const [isLoading, setIsLoading] = useState(loadingState || false);
|
|
20
|
+
useEffect(() => {
|
|
21
|
+
setIsLoading(loadingState);
|
|
22
|
+
}, [loadingState]);
|
|
23
|
+
const { textStyles, viewButtonStyles, typeText } = UserNotificationTypeStyles[notificationType];
|
|
24
|
+
return /* @__PURE__ */ React.createElement("div", {
|
|
25
|
+
className: `flex justify-start max-w-[600px] items-start relative w-full rounded-3xl shadow-bottom py-[10px] px-[10px] bg-white ${className}`
|
|
26
|
+
}, /* @__PURE__ */ React.createElement("div", {
|
|
27
|
+
className: "notification-card-left-side px-[0px] flex"
|
|
28
|
+
}, !customThumbComponent && /* @__PURE__ */ React.createElement("div", {
|
|
29
|
+
className: `overflow-hidden w-[50px] h-[50px] rounded-full flex items-start notification-card-thumbnail`
|
|
30
|
+
}, /* @__PURE__ */ React.createElement("img", {
|
|
31
|
+
src: thumbImage,
|
|
32
|
+
alt: "Notification Thumb",
|
|
33
|
+
className: "w-full h-full w-[50px] h-[50px] object-cover"
|
|
34
|
+
})), customThumbComponent && { customThumbComponent }), /* @__PURE__ */ React.createElement("div", {
|
|
35
|
+
className: "flex flex-col justify-center items-start relative w-full"
|
|
36
|
+
}, /* @__PURE__ */ React.createElement("div", {
|
|
37
|
+
className: "text-left ml-3 flex flex-col items-start justify-start w-full"
|
|
38
|
+
}, /* @__PURE__ */ React.createElement("h4", {
|
|
39
|
+
className: "font-bold tracking-wide line-clamp-2 text-black text-[14px] pr-[20px] notification-card-title",
|
|
40
|
+
"data-testid": "notification-title"
|
|
41
|
+
}, title), /* @__PURE__ */ React.createElement("p", {
|
|
42
|
+
className: `font-semibold p-0 mt-[10px] leading-none tracking-wide line-clamp-1 text-[12px] notification-card-type-text ${textStyles}`,
|
|
43
|
+
"data-testid": "notification-type"
|
|
44
|
+
}, typeText, " ", issueDate && /* @__PURE__ */ React.createElement("span", {
|
|
45
|
+
className: "text-grayscale-600 normal-case font-normal text-[12px] notification-card-type-issue-date",
|
|
46
|
+
"data-testid": "notification-cred-issue-date"
|
|
47
|
+
}, typeText && "\u2022", " ", issueDate)), /* @__PURE__ */ React.createElement("div", {
|
|
48
|
+
className: "flex items-center justify-end w-full mt-3"
|
|
49
|
+
}, /* @__PURE__ */ React.createElement("button", {
|
|
50
|
+
onClick: handleCancelClick,
|
|
51
|
+
className: `rounded-[24px] flex items-center justify-center h-[42px] w-[42px] shadow-bottom bg-white font-semibold mr-2 p-[0px] tracking-wide ${viewButtonStyles}`,
|
|
52
|
+
role: "button",
|
|
53
|
+
name: "notification-view-button"
|
|
54
|
+
}, !isArchived && /* @__PURE__ */ React.createElement("img", {
|
|
55
|
+
src: (_a = X) != null ? _a : "",
|
|
56
|
+
alt: "Cancel",
|
|
57
|
+
className: "notification-card-x"
|
|
58
|
+
}), isArchived && /* @__PURE__ */ React.createElement("img", {
|
|
59
|
+
src: (_b = ArrowArcLeft) != null ? _b : "",
|
|
60
|
+
alt: "Cancel",
|
|
61
|
+
className: "notification-card-x"
|
|
62
|
+
}))))));
|
|
63
|
+
};
|
|
64
|
+
|
|
65
|
+
export { NotificationUserAcceptedBoostCard as N };
|
|
66
|
+
//# sourceMappingURL=NotificationUserAcceptedBoostCard-8c13bd3f.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NotificationUserAcceptedBoostCard-8c13bd3f.js","sources":["../../src/components/NotificationUserAcceptedBoostCard/NotificationUserAcceptedBoostCard.tsx"],"sourcesContent":["import React, { useState, useEffect } from 'react';\nimport X from '../../assets/images/X.svg';\nimport { NotificationUserAcceptedBoostCardProps } from './types';\nimport { UserNotificationTypeStyles } from '../NotificationUserCard/types';\n\nimport { UserNotificationTypeEnum } from '../../constants/notifications';\nimport ArrowArcLeft from '../../assets/images/ArrowArcLeft.svg';\n\nexport const NotificationUserAcceptedBoostCard: React.FC<\n NotificationUserAcceptedBoostCardProps\n> = ({\n title,\n customThumbComponent,\n className,\n thumbImage,\n notificationType = UserNotificationTypeEnum.AcceptedBoost,\n issueDate,\n loadingState = false,\n handleCancelClick,\n isArchived,\n}) => {\n const [isLoading, setIsLoading] = useState<boolean>(loadingState || false);\n\n useEffect(() => {\n setIsLoading(loadingState);\n }, [loadingState]);\n\n const { textStyles, viewButtonStyles, typeText } = UserNotificationTypeStyles[notificationType];\n\n return (\n <div\n className={`flex justify-start max-w-[600px] items-start relative w-full rounded-3xl shadow-bottom py-[10px] px-[10px] bg-white ${className}`}\n >\n <div className=\"notification-card-left-side px-[0px] flex\">\n {!customThumbComponent && (\n <div\n className={`overflow-hidden w-[50px] h-[50px] rounded-full flex items-start notification-card-thumbnail`}\n >\n <img\n src={thumbImage}\n alt=\"Notification Thumb\"\n className=\"w-full h-full w-[50px] h-[50px] object-cover\"\n />\n </div>\n )}\n {customThumbComponent && { customThumbComponent }}\n </div>\n <div className=\"flex flex-col justify-center items-start relative w-full\">\n <div className=\"text-left ml-3 flex flex-col items-start justify-start w-full\">\n <h4\n className=\"font-bold tracking-wide line-clamp-2 text-black text-[14px] pr-[20px] notification-card-title\"\n data-testid=\"notification-title\"\n >\n {title}\n </h4>\n <p\n className={`font-semibold p-0 mt-[10px] leading-none tracking-wide line-clamp-1 text-[12px] notification-card-type-text ${textStyles}`}\n data-testid=\"notification-type\"\n >\n {typeText}{' '}\n {issueDate && (\n <span\n className=\"text-grayscale-600 normal-case font-normal text-[12px] notification-card-type-issue-date\"\n data-testid=\"notification-cred-issue-date\"\n >\n {typeText && '•'} {issueDate}\n </span>\n )}\n </p>\n\n <div className=\"flex items-center justify-end w-full mt-3\">\n <button\n onClick={handleCancelClick}\n className={`rounded-[24px] flex items-center justify-center h-[42px] w-[42px] shadow-bottom bg-white font-semibold mr-2 p-[0px] tracking-wide ${viewButtonStyles}`}\n role=\"button\"\n name=\"notification-view-button\"\n >\n {!isArchived && (\n <img src={X ?? ''} alt=\"Cancel\" className=\"notification-card-x\" />\n )}\n {isArchived && (\n <img\n src={ArrowArcLeft ?? ''}\n alt=\"Cancel\"\n className=\"notification-card-x\"\n />\n )}\n </button>\n </div>\n </div>\n </div>\n </div>\n );\n};\n\nexport default NotificationUserAcceptedBoostCard;\n"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
import React, { useState, useEffect } from 'react';
|
|
2
|
+
import X from './X.svg';
|
|
3
|
+
import { U as UserNotificationTypeStyles } from './types-b32d28d5.js';
|
|
4
|
+
import { U as UserNotificationTypeEnum } from './notifications-009bbd80.js';
|
|
5
|
+
import { C as Checkmark } from './Checkmark-d8b8f43d.js';
|
|
6
|
+
import ArrowArcLeft from './ArrowArcLeft.svg';
|
|
7
|
+
|
|
8
|
+
const NotificationUserCard = ({
|
|
9
|
+
title,
|
|
10
|
+
customThumbComponent,
|
|
11
|
+
className,
|
|
12
|
+
thumbImage,
|
|
13
|
+
issueDate,
|
|
14
|
+
acceptStatus = false,
|
|
15
|
+
loadingState = false,
|
|
16
|
+
handleButtonClick,
|
|
17
|
+
handleCancelClick,
|
|
18
|
+
isArchived
|
|
19
|
+
}) => {
|
|
20
|
+
var _a, _b;
|
|
21
|
+
const [isAccepted, setisAccepted] = useState(acceptStatus || false);
|
|
22
|
+
const [isLoading, setIsLoading] = useState(loadingState || false);
|
|
23
|
+
useEffect(() => {
|
|
24
|
+
setisAccepted(acceptStatus);
|
|
25
|
+
}, [acceptStatus]);
|
|
26
|
+
useEffect(() => {
|
|
27
|
+
setIsLoading(loadingState);
|
|
28
|
+
}, [loadingState]);
|
|
29
|
+
const { textStyles, viewButtonStyles, claimedButtonStyles, unclaimedButtonStyles, typeText } = UserNotificationTypeStyles[UserNotificationTypeEnum.ConnectionRequest];
|
|
30
|
+
const claimButtonStyles = isAccepted ? claimedButtonStyles : unclaimedButtonStyles;
|
|
31
|
+
let buttonText = "";
|
|
32
|
+
if (isAccepted) {
|
|
33
|
+
buttonText = "Accepted";
|
|
34
|
+
} else if (!isAccepted) {
|
|
35
|
+
buttonText = "Accept";
|
|
36
|
+
}
|
|
37
|
+
return /* @__PURE__ */ React.createElement("div", {
|
|
38
|
+
className: `flex justify-start max-w-[600px] items-start relative w-full rounded-3xl shadow-bottom py-[10px] px-[10px] bg-white ${className}`
|
|
39
|
+
}, /* @__PURE__ */ React.createElement("div", {
|
|
40
|
+
className: "notification-card-left-side px-[0px] flex"
|
|
41
|
+
}, !customThumbComponent && /* @__PURE__ */ React.createElement("div", {
|
|
42
|
+
className: `overflow-hidden cursor-pointer w-[68px] h-[68px] rounded-full flex items-start notification-card-thumbnail`
|
|
43
|
+
}, /* @__PURE__ */ React.createElement("img", {
|
|
44
|
+
src: thumbImage,
|
|
45
|
+
alt: "Notification Thumb",
|
|
46
|
+
className: "w-full h-full w-[68px] h-[68px] object-cover"
|
|
47
|
+
})), customThumbComponent && { customThumbComponent }), /* @__PURE__ */ React.createElement("div", {
|
|
48
|
+
className: "flex flex-col justify-center items-start relative w-full"
|
|
49
|
+
}, /* @__PURE__ */ React.createElement("div", {
|
|
50
|
+
className: "text-left ml-3 flex flex-col items-start justify-start w-full"
|
|
51
|
+
}, /* @__PURE__ */ React.createElement("h4", {
|
|
52
|
+
className: "cursor-pointer font-bold tracking-wide line-clamp-2 text-black text-[14px] pr-[20px] notification-card-title",
|
|
53
|
+
"data-testid": "notification-title"
|
|
54
|
+
}, title), /* @__PURE__ */ React.createElement("p", {
|
|
55
|
+
className: `font-semibold p-0 mt-[10px] leading-none tracking-wide line-clamp-1 text-[12px] notification-card-type-text ${textStyles}`,
|
|
56
|
+
"data-testid": "notification-type"
|
|
57
|
+
}, typeText, " ", issueDate && /* @__PURE__ */ React.createElement("span", {
|
|
58
|
+
className: "text-grayscale-600 normal-case font-normal text-[12px] notification-card-type-issue-date",
|
|
59
|
+
"data-testid": "notification-cred-issue-date"
|
|
60
|
+
}, "\u2022 ", issueDate)), /* @__PURE__ */ React.createElement("div", {
|
|
61
|
+
className: "flex items-center justify-between mt-3 w-full"
|
|
62
|
+
}, /* @__PURE__ */ React.createElement("button", {
|
|
63
|
+
className: `notification-claim-btn flex items-center mr-[15px] w-[143px] justify-center flex-1 rounded-[24px] border-2 border-solid font-semibold py-2 px-3 tracking-wide ${claimButtonStyles}`,
|
|
64
|
+
onClick: handleButtonClick,
|
|
65
|
+
role: "button",
|
|
66
|
+
name: "notification-claim-button"
|
|
67
|
+
}, isAccepted && /* @__PURE__ */ React.createElement(Checkmark, {
|
|
68
|
+
className: "h-[24px] p-0 m-0"
|
|
69
|
+
}), " ", isLoading ? "Loading..." : buttonText), /* @__PURE__ */ React.createElement("button", {
|
|
70
|
+
onClick: handleCancelClick,
|
|
71
|
+
className: `rounded-[24px] flex items-center justify-center h-[42px] w-[42px] shadow-bottom bg-white font-semibold mr-2 p-[0px] tracking-wide ${viewButtonStyles}`,
|
|
72
|
+
role: "button",
|
|
73
|
+
name: "notification-view-button"
|
|
74
|
+
}, !isArchived && /* @__PURE__ */ React.createElement("img", {
|
|
75
|
+
src: (_a = X) != null ? _a : "",
|
|
76
|
+
alt: "Cancel",
|
|
77
|
+
className: "notification-card-x"
|
|
78
|
+
}), isArchived && /* @__PURE__ */ React.createElement("img", {
|
|
79
|
+
src: (_b = ArrowArcLeft) != null ? _b : "",
|
|
80
|
+
alt: "Cancel",
|
|
81
|
+
className: "notification-card-x"
|
|
82
|
+
}))))));
|
|
83
|
+
};
|
|
84
|
+
|
|
85
|
+
export { NotificationUserCard as N };
|
|
86
|
+
//# sourceMappingURL=NotificationUserCard-dbcc80f9.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NotificationUserCard-dbcc80f9.js","sources":["../../src/components/NotificationUserCard/NotificationUserCard.tsx"],"sourcesContent":["import React, { useState, useEffect } from 'react';\nimport X from '../../assets/images/X.svg';\nimport { NotificationUserCardProps, UserNotificationTypeStyles } from './types';\n\nimport { UserNotificationTypeEnum } from '../../constants/notifications';\nimport DefaultFace from '../../assets/images/default-face.jpeg';\nimport Checkmark from '../svgs/Checkmark';\nimport ArrowArcLeft from '../../assets/images/ArrowArcLeft.svg';\n\nexport const NotificationUserCard: React.FC<NotificationUserCardProps> = ({\n title,\n customThumbComponent,\n className,\n thumbImage,\n issueDate,\n acceptStatus = false,\n loadingState = false,\n handleButtonClick,\n handleCancelClick,\n isArchived,\n}) => {\n const [isAccepted, setisAccepted] = useState<boolean>(acceptStatus || false);\n const [isLoading, setIsLoading] = useState<boolean>(loadingState || false);\n\n useEffect(() => {\n setisAccepted(acceptStatus);\n }, [acceptStatus]);\n\n useEffect(() => {\n setIsLoading(loadingState);\n }, [loadingState]);\n\n const { textStyles, viewButtonStyles, claimedButtonStyles, unclaimedButtonStyles, typeText } =\n UserNotificationTypeStyles[UserNotificationTypeEnum.ConnectionRequest];\n\n const claimButtonStyles = isAccepted ? claimedButtonStyles : unclaimedButtonStyles;\n\n let buttonText: string = '';\n\n if (isAccepted) {\n buttonText = 'Accepted';\n } else if (!isAccepted) {\n buttonText = 'Accept';\n }\n\n return (\n <div\n className={`flex justify-start max-w-[600px] items-start relative w-full rounded-3xl shadow-bottom py-[10px] px-[10px] bg-white ${className}`}\n >\n <div className=\"notification-card-left-side px-[0px] flex\">\n {!customThumbComponent && (\n <div\n className={`overflow-hidden cursor-pointer w-[68px] h-[68px] rounded-full flex items-start notification-card-thumbnail`}\n >\n <img\n src={thumbImage}\n alt=\"Notification Thumb\"\n className=\"w-full h-full w-[68px] h-[68px] object-cover\"\n />\n </div>\n )}\n {customThumbComponent && { customThumbComponent }}\n </div>\n <div className=\"flex flex-col justify-center items-start relative w-full\">\n <div className=\"text-left ml-3 flex flex-col items-start justify-start w-full\">\n <h4\n className=\"cursor-pointer font-bold tracking-wide line-clamp-2 text-black text-[14px] pr-[20px] notification-card-title\"\n data-testid=\"notification-title\"\n >\n {title}\n </h4>\n <p\n className={`font-semibold p-0 mt-[10px] leading-none tracking-wide line-clamp-1 text-[12px] notification-card-type-text ${textStyles}`}\n data-testid=\"notification-type\"\n >\n {typeText}{' '}\n {issueDate && (\n <span\n className=\"text-grayscale-600 normal-case font-normal text-[12px] notification-card-type-issue-date\"\n data-testid=\"notification-cred-issue-date\"\n >\n • {issueDate}\n </span>\n )}\n </p>\n\n <div className=\"flex items-center justify-between mt-3 w-full\">\n <button\n className={`notification-claim-btn flex items-center mr-[15px] w-[143px] justify-center flex-1 rounded-[24px] border-2 border-solid font-semibold py-2 px-3 tracking-wide ${claimButtonStyles}`}\n onClick={handleButtonClick}\n role=\"button\"\n name=\"notification-claim-button\"\n >\n {isAccepted && <Checkmark className=\"h-[24px] p-0 m-0\" />}{' '}\n {isLoading ? 'Loading...' : buttonText}\n </button>\n\n <button\n onClick={handleCancelClick}\n className={`rounded-[24px] flex items-center justify-center h-[42px] w-[42px] shadow-bottom bg-white font-semibold mr-2 p-[0px] tracking-wide ${viewButtonStyles}`}\n role=\"button\"\n name=\"notification-view-button\"\n >\n {!isArchived && (\n <img src={X ?? ''} alt=\"Cancel\" className=\"notification-card-x\" />\n )}\n {isArchived && (\n <img\n src={ArrowArcLeft ?? ''}\n alt=\"Cancel\"\n className=\"notification-card-x\"\n />\n )}\n </button>\n </div>\n </div>\n </div>\n </div>\n );\n};\n\nexport default NotificationUserCard;\n"],"names":[],"mappings":"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"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
|
-
import { Q as QRCodeSVG } from './index-
|
|
2
|
+
import { Q as QRCodeSVG } from './index-54ccc558.js';
|
|
3
3
|
|
|
4
4
|
const QRCodeCard = ({
|
|
5
5
|
userHandle,
|
|
@@ -33,4 +33,4 @@ const QRCodeCard = ({
|
|
|
33
33
|
};
|
|
34
34
|
|
|
35
35
|
export { QRCodeCard as Q };
|
|
36
|
-
//# sourceMappingURL=QRCodeCard-
|
|
36
|
+
//# sourceMappingURL=QRCodeCard-d147d009.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"QRCodeCard-
|
|
1
|
+
{"version":3,"file":"QRCodeCard-d147d009.js","sources":["../../src/components/QRCodeCard/QRCodeCard.tsx"],"sourcesContent":["import React from 'react';\nimport { QRCodeSVG } from 'qrcode.react';\n\nimport { QRCodeCardProps } from './types';\n\nexport const QRCodeCard: React.FC<QRCodeCardProps> = ({\n userHandle,\n qrCodeValue,\n className,\n text = null,\n}) => {\n let textEl: React.ReactNode | null = null;\n if (typeof text === 'string') {\n textEl = (\n <p className=\"flex items-center justify-center w-full text-xl text-black font-bold tracking-[9px]\">\n {text}\n </p>\n );\n } else {\n textEl = text;\n }\n\n return (\n <div\n className={`flex flex-col justify-center items-start pt-9 rounded-[20px] shadow-3xl max-w-[400px] bg-white relative pb-8 overflow-hidden ${className}`}\n >\n {qrCodeValue && (\n <div className=\"flex justify-center items-center w-full relative px-8 mb-5\">\n <div className=\"max-w-[90%] w-full h-auto relative\">\n <QRCodeSVG\n className=\"h-full w-full\"\n value={qrCodeValue}\n data-testid=\"qrcode-card\"\n bgColor=\"transparent\"\n />\n </div>\n </div>\n )}\n\n {userHandle && (\n <p\n className=\"flex items-center justify-center text-center w-full mb-3 font-semibold text-lg text-gray-500\"\n data-testid=\"qrcode-card-user-handle\"\n >\n {userHandle}\n </p>\n )}\n\n {textEl}\n </div>\n );\n};\n\nexport default QRCodeCard;\n"],"names":[],"mappings":";;;AAKO,MAAM,aAAwC,CAAC;AAAA,EAClD,UAAA;AAAA,EACA,WAAA;AAAA,EACA,SAAA;AAAA,EACA,IAAO,GAAA,IAAA;AACX,CAAM,KAAA;AACF,EAAA,IAAI,MAAiC,GAAA,IAAA,CAAA;AACrC,EAAI,IAAA,OAAO,SAAS,QAAU,EAAA;AAC1B,IAAA,MAAA,mBACK,KAAA,CAAA,aAAA,CAAA,GAAA,EAAA;AAAA,MAAE,SAAU,EAAA,qFAAA;AAAA,KAAA,EACR,IACL,CAAA,CAAA;AAAA,GAED,MAAA;AACH,IAAS,MAAA,GAAA,IAAA,CAAA;AAAA,GACb;AAEA,EAAA,uBACK,KAAA,CAAA,aAAA,CAAA,KAAA,EAAA;AAAA,IACG,WAAW,CAAgI,6HAAA,EAAA,SAAA,CAAA,CAAA;AAAA,GAAA,EAE1I,+BACI,KAAA,CAAA,aAAA,CAAA,KAAA,EAAA;AAAA,IAAI,SAAU,EAAA,4DAAA;AAAA,GAAA,kBACV,KAAA,CAAA,aAAA,CAAA,KAAA,EAAA;AAAA,IAAI,SAAU,EAAA,oCAAA;AAAA,GAAA,kBACV,KAAA,CAAA,aAAA,CAAA,SAAA,EAAA;AAAA,IACG,SAAU,EAAA,eAAA;AAAA,IACV,KAAO,EAAA,WAAA;AAAA,IACP,aAAY,EAAA,aAAA;AAAA,IACZ,OAAQ,EAAA,aAAA;AAAA,GACZ,CACJ,CACJ,CAGH,EAAA,UAAA,oBACI,KAAA,CAAA,aAAA,CAAA,GAAA,EAAA;AAAA,IACG,SAAU,EAAA,8FAAA;AAAA,IACV,aAAY,EAAA,yBAAA;AAAA,GAEX,EAAA,UACL,GAGH,MACL,CAAA,CAAA;AAER;;;;"}
|