@linktr.ee/messaging-react 1.32.1 → 1.33.0-rc-1777504230
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/{Card-ClE_iExA.js → Card-BsqYzZt1.js} +55 -55
- package/dist/Card-BsqYzZt1.js.map +1 -0
- package/dist/{Card-1CQEn-OT.js → Card-Cnn9V-W7.js} +44 -44
- package/dist/Card-Cnn9V-W7.js.map +1 -0
- package/dist/assets/index.css +1 -1
- package/dist/index-BMfupE8K.js +3130 -0
- package/dist/index-BMfupE8K.js.map +1 -0
- package/dist/index.d.ts +19 -1
- package/dist/index.js +20 -2477
- package/dist/index.js.map +1 -1
- package/package.json +1 -1
- package/src/components/ChannelInfoDialog/index.tsx +3 -1
- package/src/components/ChannelView.stories.tsx +38 -0
- package/src/components/ChannelView.test.tsx +25 -6
- package/src/components/ChannelView.tsx +26 -6
- package/src/components/CustomMessageInput/CustomMessageInput.stories.tsx +180 -0
- package/src/components/CustomMessageInput/CustomMessageInput.test.tsx +63 -1
- package/src/components/CustomMessageInput/index.tsx +24 -5
- package/src/components/LockedAttachment/components/Creator/Card.tsx +11 -11
- package/src/components/LockedAttachment/components/MediaPlayer.tsx +10 -1
- package/src/components/LockedAttachment/components/Visitor/Card.tsx +9 -9
- package/src/components/LockedAttachment/components/Visitor/CardActions.tsx +2 -2
- package/src/components/MediaMessage/MediaMessage.stories.tsx +233 -0
- package/src/components/MediaMessage/MediaMessage.test.tsx +520 -0
- package/src/components/MediaMessage/index.tsx +476 -0
- package/src/components/MessagingShell/index.tsx +2 -0
- package/src/index.ts +2 -0
- package/src/styles.css +49 -0
- package/src/types.ts +13 -0
- package/dist/Card-1CQEn-OT.js.map +0 -1
- package/dist/Card-ClE_iExA.js.map +0 -1
- package/dist/MediaPlayer-B9Ws2NeE.js +0 -292
- package/dist/MediaPlayer-B9Ws2NeE.js.map +0 -1
|
@@ -1,54 +1,54 @@
|
|
|
1
|
-
import { jsx as e, jsxs as
|
|
1
|
+
import { jsx as e, jsxs as i } from "react/jsx-runtime";
|
|
2
2
|
import { LockSimpleIcon as k, DownloadSimpleIcon as R, LockOpenIcon as U, CheckCircleIcon as D } from "@phosphor-icons/react";
|
|
3
|
-
import
|
|
4
|
-
import { g as O, M as P, r as z } from "./
|
|
3
|
+
import w, { useState as y, useRef as x, useCallback as N, useEffect as M } from "react";
|
|
4
|
+
import { g as O, M as P, r as z } from "./index-BMfupE8K.js";
|
|
5
5
|
const A = (d) => {
|
|
6
6
|
const {
|
|
7
|
-
isUnlocking:
|
|
7
|
+
isUnlocking: l = !1,
|
|
8
8
|
sourceUrl: n,
|
|
9
|
-
redeemUrl:
|
|
9
|
+
redeemUrl: r,
|
|
10
10
|
onUnlockClicked: c,
|
|
11
|
-
onDownloadClicked:
|
|
11
|
+
onDownloadClicked: a
|
|
12
12
|
} = d, o = n === void 0;
|
|
13
13
|
return o && c != null ? /* @__PURE__ */ e(
|
|
14
14
|
"button",
|
|
15
15
|
{
|
|
16
16
|
type: "button",
|
|
17
17
|
onClick: c,
|
|
18
|
-
disabled:
|
|
19
|
-
className: "mt-3 inline-flex h-10 w-full items-center justify-center gap-2 rounded-full bg-
|
|
20
|
-
children:
|
|
18
|
+
disabled: l,
|
|
19
|
+
className: "mt-3 inline-flex h-10 w-full items-center justify-center gap-2 rounded-full bg-white px-4 text-sm font-medium leading-none text-[#121110] hover:bg-white/90 disabled:opacity-70",
|
|
20
|
+
children: l ? /* @__PURE__ */ e(E, {}) : /* @__PURE__ */ i(w.Fragment, { children: [
|
|
21
21
|
/* @__PURE__ */ e(k, { className: "size-4", weight: "fill" }),
|
|
22
22
|
"Unlock"
|
|
23
23
|
] })
|
|
24
24
|
}
|
|
25
|
-
) : !o &&
|
|
25
|
+
) : !o && a != null && n != null ? /* @__PURE__ */ i(
|
|
26
26
|
"a",
|
|
27
27
|
{
|
|
28
|
-
href:
|
|
28
|
+
href: r ?? n,
|
|
29
29
|
target: "_blank",
|
|
30
30
|
rel: "noopener noreferrer",
|
|
31
|
-
onClick:
|
|
32
|
-
className: "mt-3 inline-flex h-10 w-full items-center justify-center gap-2 rounded-full bg-
|
|
31
|
+
onClick: a,
|
|
32
|
+
className: "mt-3 inline-flex h-10 w-full items-center justify-center gap-2 rounded-full bg-white px-4 text-sm font-medium leading-none !text-[#121110] hover:bg-white/90",
|
|
33
33
|
children: [
|
|
34
34
|
/* @__PURE__ */ e(R, { className: "size-4", weight: "bold" }),
|
|
35
35
|
"Download"
|
|
36
36
|
]
|
|
37
37
|
}
|
|
38
38
|
) : null;
|
|
39
|
-
}, E = () => /* @__PURE__ */
|
|
39
|
+
}, E = () => /* @__PURE__ */ i("span", { className: "flex items-center gap-1", children: [
|
|
40
40
|
/* @__PURE__ */ e("span", { className: "size-1 rounded-full bg-white animate-bounce [animation-delay:-0.3s]" }),
|
|
41
41
|
/* @__PURE__ */ e("span", { className: "size-1 rounded-full bg-white animate-bounce [animation-delay:-0.15s]" }),
|
|
42
42
|
/* @__PURE__ */ e("span", { className: "size-1 rounded-full bg-white animate-bounce" })
|
|
43
43
|
] }), F = ({
|
|
44
44
|
title: d,
|
|
45
|
-
sourceUrl:
|
|
45
|
+
sourceUrl: l,
|
|
46
46
|
thumbnailUrl: n,
|
|
47
|
-
mimeType:
|
|
47
|
+
mimeType: r,
|
|
48
48
|
paymentStatus: c
|
|
49
49
|
}) => {
|
|
50
|
-
const [
|
|
51
|
-
return f ? /* @__PURE__ */
|
|
50
|
+
const [a, o] = y(!1), f = l === void 0, s = O(r);
|
|
51
|
+
return f ? /* @__PURE__ */ i("div", { className: "relative aspect-video overflow-hidden bg-black/5", children: [
|
|
52
52
|
n != null ? /* @__PURE__ */ e(
|
|
53
53
|
"img",
|
|
54
54
|
{
|
|
@@ -57,66 +57,66 @@ const A = (d) => {
|
|
|
57
57
|
className: "absolute inset-0 h-full w-full object-cover",
|
|
58
58
|
draggable: !1
|
|
59
59
|
}
|
|
60
|
-
) : /* @__PURE__ */ e("div", { className: "absolute inset-0 flex items-center justify-center", children: z(
|
|
60
|
+
) : /* @__PURE__ */ e("div", { className: "absolute inset-0 flex items-center justify-center", children: z(r, {
|
|
61
61
|
className: "size-12 text-black/20",
|
|
62
62
|
weight: "regular"
|
|
63
63
|
}) }),
|
|
64
64
|
f && /* @__PURE__ */ e("div", { className: "absolute inset-0 bg-black/30", children: /* @__PURE__ */ e("div", { className: "absolute left-3 top-3 flex size-8 items-center justify-center rounded-full bg-black/60 text-white", children: c === "paid" ? /* @__PURE__ */ e(U, {}) : /* @__PURE__ */ e(k, {}) }) })
|
|
65
|
-
] }) :
|
|
65
|
+
] }) : s === "audio" || s === "video" ? /* @__PURE__ */ e(
|
|
66
66
|
P,
|
|
67
67
|
{
|
|
68
|
-
source:
|
|
68
|
+
source: l,
|
|
69
69
|
poster: n,
|
|
70
|
-
mimeType:
|
|
70
|
+
mimeType: r
|
|
71
71
|
}
|
|
72
72
|
) : /* @__PURE__ */ e("div", { className: "relative overflow-hidden bg-black/5", children: /* @__PURE__ */ e(
|
|
73
73
|
"img",
|
|
74
74
|
{
|
|
75
|
-
src:
|
|
75
|
+
src: s === "document" ? n : l,
|
|
76
76
|
alt: d,
|
|
77
|
-
className: `block w-full transition-opacity duration-300 ${
|
|
77
|
+
className: `block w-full transition-opacity duration-300 ${a ? "opacity-100" : "opacity-0"}`,
|
|
78
78
|
draggable: !1,
|
|
79
79
|
onLoad: () => o(!0)
|
|
80
80
|
}
|
|
81
81
|
) });
|
|
82
82
|
}, q = ({
|
|
83
83
|
title: d,
|
|
84
|
-
amountText:
|
|
84
|
+
amountText: l,
|
|
85
85
|
thumbnailUrl: n,
|
|
86
|
-
mimeType:
|
|
86
|
+
mimeType: r = "application/octet-stream",
|
|
87
87
|
detail: c,
|
|
88
|
-
onUnlockClick:
|
|
88
|
+
onUnlockClick: a,
|
|
89
89
|
onFetchSource: o,
|
|
90
90
|
onDownloadClick: f,
|
|
91
|
-
paymentStatus:
|
|
91
|
+
paymentStatus: s,
|
|
92
92
|
isUnlocking: C = !1
|
|
93
93
|
}) => {
|
|
94
94
|
const [t, _] = y(), g = x(null), p = x(!1), m = x(o);
|
|
95
95
|
m.current = o;
|
|
96
|
-
const
|
|
96
|
+
const v = t == null ? void 0 : t.sourceUrl, j = (t == null ? void 0 : t.thumbnailUrl) ?? n, I = t == null ? void 0 : t.redeemUrl, h = N(async () => {
|
|
97
97
|
var u;
|
|
98
98
|
if (!p.current) {
|
|
99
99
|
p.current = !0;
|
|
100
100
|
try {
|
|
101
|
-
const
|
|
102
|
-
|
|
101
|
+
const b = await ((u = m.current) == null ? void 0 : u.call(m));
|
|
102
|
+
b && _(b);
|
|
103
103
|
} finally {
|
|
104
104
|
p.current = !1;
|
|
105
105
|
}
|
|
106
106
|
}
|
|
107
107
|
}, []), L = N(() => {
|
|
108
|
-
|
|
109
|
-
}, [
|
|
108
|
+
s === "paid" ? h() : a == null || a();
|
|
109
|
+
}, [s, h, a]);
|
|
110
110
|
return M(() => {
|
|
111
|
-
if (!g.current ||
|
|
111
|
+
if (!g.current || s !== "paid" || t !== void 0) return;
|
|
112
112
|
const u = new IntersectionObserver(
|
|
113
|
-
([
|
|
114
|
-
|
|
113
|
+
([b]) => {
|
|
114
|
+
b.isIntersecting && (h(), u.disconnect());
|
|
115
115
|
},
|
|
116
116
|
{ threshold: 1 }
|
|
117
117
|
);
|
|
118
118
|
return u.observe(g.current), () => u.disconnect();
|
|
119
|
-
}, [
|
|
119
|
+
}, [s, t, h]), /* @__PURE__ */ i(
|
|
120
120
|
"div",
|
|
121
121
|
{
|
|
122
122
|
ref: g,
|
|
@@ -127,40 +127,40 @@ const A = (d) => {
|
|
|
127
127
|
F,
|
|
128
128
|
{
|
|
129
129
|
title: d,
|
|
130
|
-
sourceUrl:
|
|
130
|
+
sourceUrl: v,
|
|
131
131
|
thumbnailUrl: j,
|
|
132
|
-
mimeType:
|
|
133
|
-
paymentStatus:
|
|
132
|
+
mimeType: r,
|
|
133
|
+
paymentStatus: s
|
|
134
134
|
}
|
|
135
135
|
),
|
|
136
|
-
/* @__PURE__ */
|
|
137
|
-
/* @__PURE__ */ e("p", { className: "mb-1.5 truncate text-base font-medium text-
|
|
138
|
-
/* @__PURE__ */
|
|
139
|
-
z(
|
|
140
|
-
className: "size-5 shrink-0 text-
|
|
136
|
+
/* @__PURE__ */ i("div", { className: "px-4 pb-3 pt-3 bg-black", children: [
|
|
137
|
+
/* @__PURE__ */ e("p", { className: "mb-1.5 truncate text-base font-medium text-white", children: d }),
|
|
138
|
+
/* @__PURE__ */ i("div", { className: "flex items-center gap-1", children: [
|
|
139
|
+
z(r, {
|
|
140
|
+
className: "size-5 shrink-0 text-white/55",
|
|
141
141
|
weight: "regular"
|
|
142
142
|
}),
|
|
143
|
-
c && /* @__PURE__ */ e("span", { className: "text-xs font-medium text-
|
|
144
|
-
|
|
145
|
-
/* @__PURE__ */ e("span", { className: "text-xs font-medium text-
|
|
146
|
-
/* @__PURE__ */ e("span", { className: "text-xs font-medium text-[#
|
|
143
|
+
c && /* @__PURE__ */ e("span", { className: "text-xs font-medium text-white/55", children: c }),
|
|
144
|
+
s === "paid" ? /* @__PURE__ */ i(w.Fragment, { children: [
|
|
145
|
+
/* @__PURE__ */ e("span", { className: "text-xs font-medium text-white/55", children: "•" }),
|
|
146
|
+
/* @__PURE__ */ e("span", { className: "text-xs font-medium text-[#4ade80]", children: "Purchased" }),
|
|
147
147
|
/* @__PURE__ */ e(
|
|
148
148
|
D,
|
|
149
149
|
{
|
|
150
|
-
className: "size-4 text-[#
|
|
150
|
+
className: "size-4 text-[#4ade80]",
|
|
151
151
|
weight: "bold"
|
|
152
152
|
}
|
|
153
153
|
)
|
|
154
|
-
] }) :
|
|
155
|
-
/* @__PURE__ */ e("span", { className: "text-xs font-medium text-
|
|
156
|
-
/* @__PURE__ */ e("span", { className: "text-xs font-medium text-
|
|
154
|
+
] }) : l != null ? /* @__PURE__ */ i(w.Fragment, { children: [
|
|
155
|
+
/* @__PURE__ */ e("span", { className: "text-xs font-medium text-white/55", children: "•" }),
|
|
156
|
+
/* @__PURE__ */ e("span", { className: "text-xs font-medium text-white/55", children: l })
|
|
157
157
|
] }) : null
|
|
158
158
|
] }),
|
|
159
159
|
/* @__PURE__ */ e(
|
|
160
160
|
A,
|
|
161
161
|
{
|
|
162
162
|
isUnlocking: C,
|
|
163
|
-
sourceUrl:
|
|
163
|
+
sourceUrl: v,
|
|
164
164
|
redeemUrl: I,
|
|
165
165
|
onUnlockClicked: L,
|
|
166
166
|
onDownloadClicked: f
|
|
@@ -174,4 +174,4 @@ const A = (d) => {
|
|
|
174
174
|
export {
|
|
175
175
|
q as default
|
|
176
176
|
};
|
|
177
|
-
//# sourceMappingURL=Card-
|
|
177
|
+
//# sourceMappingURL=Card-BsqYzZt1.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Card-BsqYzZt1.js","sources":["../src/components/LockedAttachment/components/Visitor/CardActions.tsx","../src/components/LockedAttachment/components/Visitor/CardThumbnail.tsx","../src/components/LockedAttachment/components/Visitor/Card.tsx"],"sourcesContent":["import { DownloadSimpleIcon, LockSimpleIcon } from '@phosphor-icons/react'\nimport React from 'react'\n\ninterface CardActionsProps {\n sourceUrl?: string\n redeemUrl?: string\n onUnlockClicked?: () => void\n onDownloadClicked?: () => void\n isUnlocking?: boolean\n}\n\nconst CardActions: React.FC<CardActionsProps> = (props) => {\n const {\n isUnlocking = false,\n sourceUrl,\n redeemUrl,\n onUnlockClicked,\n onDownloadClicked,\n } = props\n\n const isLocked = sourceUrl === undefined\n\n if (isLocked && onUnlockClicked != null) {\n return (\n <button\n type=\"button\"\n onClick={onUnlockClicked}\n disabled={isUnlocking}\n className=\"mt-3 inline-flex h-10 w-full items-center justify-center gap-2 rounded-full bg-white px-4 text-sm font-medium leading-none text-[#121110] hover:bg-white/90 disabled:opacity-70\"\n >\n {isUnlocking ? (\n <LoadingDots />\n ) : (\n <React.Fragment>\n <LockSimpleIcon className=\"size-4\" weight=\"fill\" />\n Unlock\n </React.Fragment>\n )}\n </button>\n )\n }\n\n if (!isLocked && onDownloadClicked != null && sourceUrl != null) {\n return (\n <a\n href={redeemUrl ?? sourceUrl}\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n onClick={onDownloadClicked}\n className=\"mt-3 inline-flex h-10 w-full items-center justify-center gap-2 rounded-full bg-white px-4 text-sm font-medium leading-none !text-[#121110] hover:bg-white/90\"\n >\n <DownloadSimpleIcon className=\"size-4\" weight=\"bold\" />\n Download\n </a>\n )\n }\n\n return null\n}\n\nconst LoadingDots: React.FC = () => {\n return (\n <span className=\"flex items-center gap-1\">\n <span className=\"size-1 rounded-full bg-white animate-bounce [animation-delay:-0.3s]\" />\n <span className=\"size-1 rounded-full bg-white animate-bounce [animation-delay:-0.15s]\" />\n <span className=\"size-1 rounded-full bg-white animate-bounce\" />\n </span>\n )\n}\n\nexport default CardActions\n","import { LockOpenIcon, LockSimpleIcon } from '@phosphor-icons/react'\nimport React, { useState } from 'react'\n\nimport { PaymentStatus } from '../../types'\nimport { renderTypeIcon } from '../../utils/icons'\nimport { getSourceType } from '../../utils/mimeType'\nimport MediaPlayer from '../MediaPlayer'\n\ninterface CardThumbnailProps {\n title?: string\n sourceUrl?: string\n thumbnailUrl?: string\n mimeType: string\n paymentStatus?: PaymentStatus\n}\n\nconst CardThumbnail: React.FC<CardThumbnailProps> = ({\n title,\n sourceUrl,\n thumbnailUrl,\n mimeType,\n paymentStatus,\n}) => {\n const [sourceReady, setSourceReady] = useState(false)\n\n const isLocked = sourceUrl === undefined\n const sourceType = getSourceType(mimeType)\n\n if (!isLocked) {\n if (sourceType === 'audio' || sourceType === 'video') {\n return (\n <MediaPlayer\n source={sourceUrl}\n poster={thumbnailUrl}\n mimeType={mimeType}\n />\n )\n }\n\n return (\n <div className=\"relative overflow-hidden bg-black/5\">\n <img\n src={sourceType === 'document' ? thumbnailUrl : sourceUrl}\n alt={title}\n className={`block w-full transition-opacity duration-300 ${sourceReady ? 'opacity-100' : 'opacity-0'}`}\n draggable={false}\n onLoad={() => setSourceReady(true)}\n />\n </div>\n )\n }\n\n return (\n <div className=\"relative aspect-video overflow-hidden bg-black/5\">\n {thumbnailUrl != null ? (\n <img\n src={thumbnailUrl}\n alt=\"\"\n className=\"absolute inset-0 h-full w-full object-cover\"\n draggable={false}\n />\n ) : (\n <div className=\"absolute inset-0 flex items-center justify-center\">\n {renderTypeIcon(mimeType, {\n className: 'size-12 text-black/20',\n weight: 'regular',\n })}\n </div>\n )}\n {isLocked && (\n <div className=\"absolute inset-0 bg-black/30\">\n <div className=\"absolute left-3 top-3 flex size-8 items-center justify-center rounded-full bg-black/60 text-white\">\n {paymentStatus === 'paid' ? <LockOpenIcon /> : <LockSimpleIcon />}\n </div>\n </div>\n )}\n </div>\n )\n}\n\nexport default CardThumbnail\n","import { CheckCircleIcon } from '@phosphor-icons/react'\nimport React, { useCallback, useEffect, useRef, useState } from 'react'\n\nimport type {\n LockedAttachmentBaseProps,\n LockedAttachmentSource,\n} from '../../types'\nimport { renderTypeIcon } from '../../utils/icons'\n\nimport CardActions from './CardActions'\nimport CardThumbnail from './CardThumbnail'\n\nexport interface VisitorCardProps extends LockedAttachmentBaseProps {\n /**\n * Called when the visitor clicks Unlock on an unpaid attachment.\n * Use this to open a checkout flow. Omit to hide the Unlock button.\n */\n onUnlockClick?: () => void\n /**\n * Called to fetch the attachment source — fired automatically when\n * paymentStatus transitions to 'paid', or immediately on click when\n * paymentStatus is already 'paid'. Return a LockedAttachmentSource to\n * unlock the card.\n */\n onFetchSource?: () => Promise<LockedAttachmentSource | void>\n /**\n * Called when the visitor clicks Download on an unlocked card.\n * Omit to hide the Download button.\n */\n onDownloadClick?: () => void\n /**\n * When true, shows loading dots on the Unlock button.\n * Driven by the LockedAttachmentContext (e.g. checkout in progress, payment processing).\n */\n isUnlocking?: boolean\n}\n\nconst VisitorCard: React.FC<VisitorCardProps> = ({\n title,\n amountText,\n thumbnailUrl,\n mimeType = 'application/octet-stream',\n detail,\n onUnlockClick,\n onFetchSource,\n onDownloadClick,\n paymentStatus,\n isUnlocking = false,\n}) => {\n const [source, setSource] = useState<LockedAttachmentSource | undefined>()\n\n const cardRef = useRef<HTMLDivElement>(null)\n const fetchingRef = useRef(false)\n\n const onFetchSourceRef = useRef(onFetchSource)\n onFetchSourceRef.current = onFetchSource\n\n const effectiveSourceUrl = source?.sourceUrl\n const effectiveThumbnail = source?.thumbnailUrl ?? thumbnailUrl\n const effectiveRedeemUrl = source?.redeemUrl\n\n const fetchSource = useCallback(async (): Promise<void> => {\n if (fetchingRef.current) return\n fetchingRef.current = true\n try {\n const result = await onFetchSourceRef.current?.()\n if (result) setSource(result)\n } finally {\n fetchingRef.current = false\n }\n }, [])\n\n const handleUnlockClick = useCallback(() => {\n if (paymentStatus === 'paid') {\n void fetchSource()\n } else {\n onUnlockClick?.()\n }\n }, [paymentStatus, fetchSource, onUnlockClick])\n\n // Fetch source when card is in viewport\n useEffect(() => {\n if (!cardRef.current) return\n if (paymentStatus !== 'paid' || source !== undefined) return\n\n const observer = new IntersectionObserver(\n ([entry]) => {\n if (entry.isIntersecting) {\n void fetchSource()\n observer.disconnect()\n }\n },\n { threshold: 1.0 }\n )\n\n observer.observe(cardRef.current)\n return () => observer.disconnect()\n }, [paymentStatus, source, fetchSource])\n\n return (\n <div\n ref={cardRef}\n data-testid=\"locked-attachment\"\n className=\"w-[280px] select-none overflow-hidden rounded-[24px] bg-white shadow-[0_0_0_1px_rgba(0,0,0,0.04),0_4px_8px_rgba(0,0,0,0.06)]\"\n >\n <CardThumbnail\n title={title}\n sourceUrl={effectiveSourceUrl}\n thumbnailUrl={effectiveThumbnail}\n mimeType={mimeType}\n paymentStatus={paymentStatus}\n />\n\n <div className=\"px-4 pb-3 pt-3 bg-black\">\n <p className=\"mb-1.5 truncate text-base font-medium text-white\">\n {title}\n </p>\n <div className=\"flex items-center gap-1\">\n {renderTypeIcon(mimeType, {\n className: 'size-5 shrink-0 text-white/55',\n weight: 'regular',\n })}\n\n {detail && (\n <span className=\"text-xs font-medium text-white/55\">{detail}</span>\n )}\n\n {paymentStatus === 'paid' ? (\n <React.Fragment>\n <span className=\"text-xs font-medium text-white/55\">•</span>\n <span className=\"text-xs font-medium text-[#4ade80]\">\n Purchased\n </span>\n <CheckCircleIcon\n className=\"size-4 text-[#4ade80]\"\n weight=\"bold\"\n />\n </React.Fragment>\n ) : amountText != null ? (\n <React.Fragment>\n <span className=\"text-xs font-medium text-white/55\">•</span>\n <span className=\"text-xs font-medium text-white/55\">\n {amountText}\n </span>\n </React.Fragment>\n ) : null}\n </div>\n\n <CardActions\n isUnlocking={isUnlocking}\n sourceUrl={effectiveSourceUrl}\n redeemUrl={effectiveRedeemUrl}\n onUnlockClicked={handleUnlockClick}\n onDownloadClicked={onDownloadClick}\n />\n </div>\n </div>\n )\n}\n\nexport default VisitorCard\n"],"names":["CardActions","props","isUnlocking","sourceUrl","redeemUrl","onUnlockClicked","onDownloadClicked","isLocked","jsx","LoadingDots","jsxs","React","LockSimpleIcon","DownloadSimpleIcon","CardThumbnail","title","thumbnailUrl","mimeType","paymentStatus","sourceReady","setSourceReady","useState","sourceType","getSourceType","LockOpenIcon","MediaPlayer","VisitorCard","amountText","detail","onUnlockClick","onFetchSource","onDownloadClick","source","setSource","cardRef","useRef","fetchingRef","onFetchSourceRef","effectiveSourceUrl","effectiveThumbnail","effectiveRedeemUrl","fetchSource","useCallback","result","_a","handleUnlockClick","useEffect","observer","entry","renderTypeIcon","CheckCircleIcon"],"mappings":"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"}
|
|
@@ -1,17 +1,17 @@
|
|
|
1
|
-
import { jsxs as
|
|
2
|
-
import { CheckCircleIcon as
|
|
1
|
+
import { jsxs as i, jsx as e } from "react/jsx-runtime";
|
|
2
|
+
import { CheckCircleIcon as w, XIcon as v, EyeIcon as k, EyeSlashIcon as z, LockOpenIcon as I, LockIcon as y } from "@phosphor-icons/react";
|
|
3
3
|
import d from "classnames";
|
|
4
4
|
import f, { useState as _, useCallback as j } from "react";
|
|
5
|
-
import { r as
|
|
5
|
+
import { r as h, g as C, M as S } from "./index-BMfupE8K.js";
|
|
6
6
|
const E = ({
|
|
7
7
|
title: t,
|
|
8
|
-
sourceUrl:
|
|
8
|
+
sourceUrl: c,
|
|
9
9
|
thumbnailUrl: s,
|
|
10
10
|
mimeType: a,
|
|
11
11
|
onToggle: l
|
|
12
12
|
}) => {
|
|
13
|
-
const o = l &&
|
|
14
|
-
return /* @__PURE__ */
|
|
13
|
+
const o = l && c && s;
|
|
14
|
+
return /* @__PURE__ */ i(
|
|
15
15
|
"button",
|
|
16
16
|
{
|
|
17
17
|
type: "button",
|
|
@@ -26,7 +26,7 @@ const E = ({
|
|
|
26
26
|
o ? /* @__PURE__ */ e(
|
|
27
27
|
M,
|
|
28
28
|
{
|
|
29
|
-
sourceUrl:
|
|
29
|
+
sourceUrl: c,
|
|
30
30
|
thumbnailUrl: s,
|
|
31
31
|
mimeType: a
|
|
32
32
|
}
|
|
@@ -38,7 +38,7 @@ const E = ({
|
|
|
38
38
|
draggable: !1,
|
|
39
39
|
className: "absolute inset-0 h-full w-full object-cover"
|
|
40
40
|
}
|
|
41
|
-
) }) : /* @__PURE__ */ e("div", { className: "aspect-video flex items-center justify-center", children:
|
|
41
|
+
) }) : /* @__PURE__ */ e("div", { className: "aspect-video flex items-center justify-center", children: h(a, {
|
|
42
42
|
className: "size-12 text-black/20",
|
|
43
43
|
weight: "regular"
|
|
44
44
|
}) }),
|
|
@@ -48,7 +48,7 @@ const E = ({
|
|
|
48
48
|
);
|
|
49
49
|
}, M = ({
|
|
50
50
|
sourceUrl: t,
|
|
51
|
-
thumbnailUrl:
|
|
51
|
+
thumbnailUrl: c,
|
|
52
52
|
mimeType: s
|
|
53
53
|
}) => {
|
|
54
54
|
const a = C(s);
|
|
@@ -57,7 +57,7 @@ const E = ({
|
|
|
57
57
|
{
|
|
58
58
|
mimeType: s,
|
|
59
59
|
source: t,
|
|
60
|
-
poster:
|
|
60
|
+
poster: c,
|
|
61
61
|
autoPlay: !0,
|
|
62
62
|
loop: !0,
|
|
63
63
|
controls: !0,
|
|
@@ -66,7 +66,7 @@ const E = ({
|
|
|
66
66
|
) : a === "image" ? /* @__PURE__ */ e("img", { src: t, alt: "", className: "block w-full", draggable: !1 }) : a === "document" ? /* @__PURE__ */ e(
|
|
67
67
|
"img",
|
|
68
68
|
{
|
|
69
|
-
src:
|
|
69
|
+
src: c,
|
|
70
70
|
alt: "",
|
|
71
71
|
className: "block w-full",
|
|
72
72
|
draggable: !1
|
|
@@ -74,26 +74,26 @@ const E = ({
|
|
|
74
74
|
) : null;
|
|
75
75
|
}, R = ({
|
|
76
76
|
title: t,
|
|
77
|
-
mimeType:
|
|
77
|
+
mimeType: c = "application/octet-stream",
|
|
78
78
|
thumbnailUrl: s,
|
|
79
79
|
detail: a,
|
|
80
80
|
amountText: l,
|
|
81
81
|
placeholderTitle: o = "Attachment title",
|
|
82
|
-
placeholderAmountText:
|
|
82
|
+
placeholderAmountText: b,
|
|
83
83
|
paymentStatus: m,
|
|
84
|
-
onDismiss:
|
|
85
|
-
onPreviewClick:
|
|
84
|
+
onDismiss: p,
|
|
85
|
+
onPreviewClick: n
|
|
86
86
|
}) => {
|
|
87
|
-
const [
|
|
88
|
-
|
|
89
|
-
}, [
|
|
90
|
-
return /* @__PURE__ */
|
|
87
|
+
const [r, u] = _(), x = r == null ? void 0 : r.sourceUrl, g = (r == null ? void 0 : r.thumbnailUrl) ?? s, N = j(() => {
|
|
88
|
+
r ? u(void 0) : n && u(n());
|
|
89
|
+
}, [r, n]);
|
|
90
|
+
return /* @__PURE__ */ i("div", { className: "relative w-[280px] select-none overflow-hidden rounded-[24px] bg-white shadow-[0_0_0_1px_rgba(0,0,0,0.04),0_4px_8px_rgba(0,0,0,0.06)]", children: [
|
|
91
91
|
/* @__PURE__ */ e(
|
|
92
92
|
F,
|
|
93
93
|
{
|
|
94
|
-
onDismiss:
|
|
95
|
-
onPreviewClick:
|
|
96
|
-
sourceUrl:
|
|
94
|
+
onDismiss: p,
|
|
95
|
+
onPreviewClick: n,
|
|
96
|
+
sourceUrl: r == null ? void 0 : r.sourceUrl,
|
|
97
97
|
paymentStatus: m
|
|
98
98
|
}
|
|
99
99
|
),
|
|
@@ -103,47 +103,47 @@ const E = ({
|
|
|
103
103
|
title: t,
|
|
104
104
|
sourceUrl: x,
|
|
105
105
|
thumbnailUrl: g,
|
|
106
|
-
mimeType:
|
|
107
|
-
onToggle:
|
|
106
|
+
mimeType: c,
|
|
107
|
+
onToggle: n ? N : void 0
|
|
108
108
|
}
|
|
109
109
|
),
|
|
110
|
-
/* @__PURE__ */
|
|
110
|
+
/* @__PURE__ */ i("div", { className: "px-4 pb-3 pt-3 bg-black", children: [
|
|
111
111
|
/* @__PURE__ */ e(
|
|
112
112
|
"p",
|
|
113
113
|
{
|
|
114
114
|
className: d("mb-1.5 truncate text-base font-medium", {
|
|
115
|
-
"text-
|
|
116
|
-
"text-
|
|
115
|
+
"text-white/30": !t,
|
|
116
|
+
"text-white": !!t
|
|
117
117
|
}),
|
|
118
118
|
children: t || o
|
|
119
119
|
}
|
|
120
120
|
),
|
|
121
|
-
/* @__PURE__ */
|
|
122
|
-
|
|
123
|
-
className: "size-5 shrink-0 text-
|
|
121
|
+
/* @__PURE__ */ i("div", { className: "flex items-center gap-1", children: [
|
|
122
|
+
h(c, {
|
|
123
|
+
className: "size-5 shrink-0 text-white/55",
|
|
124
124
|
weight: "regular"
|
|
125
125
|
}),
|
|
126
|
-
a && /* @__PURE__ */ e("span", { className: "text-xs font-medium text-
|
|
127
|
-
m === "paid" ? /* @__PURE__ */
|
|
128
|
-
/* @__PURE__ */ e("span", { className: "text-xs font-medium text-
|
|
129
|
-
/* @__PURE__ */ e("span", { className: "text-xs font-medium text-[#
|
|
126
|
+
a && /* @__PURE__ */ e("span", { className: "text-xs font-medium text-white/55", children: a }),
|
|
127
|
+
m === "paid" ? /* @__PURE__ */ i(f.Fragment, { children: [
|
|
128
|
+
/* @__PURE__ */ e("span", { className: "text-xs font-medium text-white/55", children: "•" }),
|
|
129
|
+
/* @__PURE__ */ e("span", { className: "text-xs font-medium text-[#4ade80]", children: "Sold" }),
|
|
130
130
|
/* @__PURE__ */ e(
|
|
131
|
-
|
|
131
|
+
w,
|
|
132
132
|
{
|
|
133
|
-
className: "size-4 text-[#
|
|
133
|
+
className: "size-4 text-[#4ade80]",
|
|
134
134
|
weight: "bold"
|
|
135
135
|
}
|
|
136
136
|
)
|
|
137
|
-
] }) : /* @__PURE__ */
|
|
138
|
-
/* @__PURE__ */ e("span", { className: "text-xs font-medium text-
|
|
137
|
+
] }) : /* @__PURE__ */ i(f.Fragment, { children: [
|
|
138
|
+
/* @__PURE__ */ e("span", { className: "text-xs font-medium text-white/55", children: "•" }),
|
|
139
139
|
/* @__PURE__ */ e(
|
|
140
140
|
"span",
|
|
141
141
|
{
|
|
142
142
|
className: d("text-xs font-medium", {
|
|
143
|
-
"text-
|
|
144
|
-
"text-
|
|
143
|
+
"text-white/30": !l,
|
|
144
|
+
"text-white/55": !!l
|
|
145
145
|
}),
|
|
146
|
-
children: l ||
|
|
146
|
+
children: l || b
|
|
147
147
|
}
|
|
148
148
|
)
|
|
149
149
|
] })
|
|
@@ -152,7 +152,7 @@ const E = ({
|
|
|
152
152
|
] });
|
|
153
153
|
}, F = ({
|
|
154
154
|
onDismiss: t,
|
|
155
|
-
onPreviewClick:
|
|
155
|
+
onPreviewClick: c,
|
|
156
156
|
sourceUrl: s,
|
|
157
157
|
paymentStatus: a
|
|
158
158
|
}) => t ? /* @__PURE__ */ e(
|
|
@@ -164,8 +164,8 @@ const E = ({
|
|
|
164
164
|
"aria-label": "Dismiss attachment",
|
|
165
165
|
children: /* @__PURE__ */ e(v, { className: "size-4", weight: "bold" })
|
|
166
166
|
}
|
|
167
|
-
) : /* @__PURE__ */ e("div", { className: "absolute top-3 z-50 flex size-8 items-center justify-center rounded-full bg-black/60 text-white left-3", children: /* @__PURE__ */ e(
|
|
167
|
+
) : /* @__PURE__ */ e("div", { className: "absolute top-3 z-50 flex size-8 items-center justify-center rounded-full bg-black/60 text-white left-3", children: /* @__PURE__ */ e(c ? s ? k : z : a === "paid" ? I : y, { className: "size-4", weight: "fill" }) });
|
|
168
168
|
export {
|
|
169
169
|
R as default
|
|
170
170
|
};
|
|
171
|
-
//# sourceMappingURL=Card-
|
|
171
|
+
//# sourceMappingURL=Card-Cnn9V-W7.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Card-Cnn9V-W7.js","sources":["../src/components/LockedAttachment/components/Creator/CardThumbnail.tsx","../src/components/LockedAttachment/components/Creator/Card.tsx"],"sourcesContent":["import classNames from 'classnames'\nimport React from 'react'\n\nimport { renderTypeIcon } from '../../utils/icons'\nimport { getSourceType } from '../../utils/mimeType'\nimport MediaPlayer from '../MediaPlayer'\n\ninterface CardThumbnailProps {\n title?: string\n sourceUrl?: string\n thumbnailUrl?: string\n mimeType: string\n onToggle?: () => void\n}\n\nconst CardThumbnail: React.FC<CardThumbnailProps> = ({\n title,\n sourceUrl,\n thumbnailUrl,\n mimeType,\n onToggle,\n}) => {\n const isExpanded = onToggle && sourceUrl && thumbnailUrl\n\n return (\n <button\n type=\"button\"\n disabled={!onToggle}\n className={classNames(\n 'relative block w-full overflow-hidden border-0 bg-black/5 p-0 text-left appearance-none',\n { 'cursor-pointer': !!onToggle, 'cursor-default': !onToggle }\n )}\n onClick={onToggle}\n aria-label={onToggle ? 'Toggle preview' : undefined}\n >\n {isExpanded ? (\n <ThumbnailMedia\n sourceUrl={sourceUrl}\n thumbnailUrl={thumbnailUrl}\n mimeType={mimeType}\n />\n ) : thumbnailUrl ? (\n <div className=\"aspect-video overflow-hidden\">\n <img\n src={thumbnailUrl}\n alt={title}\n draggable={false}\n className=\"absolute inset-0 h-full w-full object-cover\"\n />\n </div>\n ) : (\n <div className=\"aspect-video flex items-center justify-center\">\n {renderTypeIcon(mimeType, {\n className: 'size-12 text-black/20',\n weight: 'regular',\n })}\n </div>\n )}\n\n {!isExpanded && (\n <div className=\"pointer-events-none absolute inset-0 bg-black/30\" />\n )}\n </button>\n )\n}\n\ninterface ThumbnailMediaProps {\n sourceUrl: string\n thumbnailUrl: string\n mimeType: string\n}\n\nconst ThumbnailMedia: React.FC<ThumbnailMediaProps> = ({\n sourceUrl,\n thumbnailUrl,\n mimeType,\n}) => {\n const sourceType = getSourceType(mimeType)\n\n if (sourceType === 'video' || sourceType === 'audio') {\n return (\n <MediaPlayer\n mimeType={mimeType}\n source={sourceUrl}\n poster={thumbnailUrl}\n autoPlay={true}\n loop={true}\n controls={true}\n muted={false}\n />\n )\n }\n\n if (sourceType === 'image') {\n return (\n <img src={sourceUrl} alt=\"\" className=\"block w-full\" draggable={false} />\n )\n }\n\n if (sourceType === 'document') {\n return (\n <img\n src={thumbnailUrl}\n alt=\"\"\n className=\"block w-full\"\n draggable={false}\n />\n )\n }\n\n return null\n}\n\nexport default CardThumbnail\n","import {\n CheckCircleIcon,\n EyeIcon,\n EyeSlashIcon,\n LockIcon,\n LockOpenIcon,\n XIcon,\n} from '@phosphor-icons/react'\nimport classNames from 'classnames'\nimport React, { useCallback, useState } from 'react'\n\nimport type {\n LockedAttachmentBaseProps,\n LockedAttachmentSource,\n PaymentStatus,\n} from '../../types'\nimport { renderTypeIcon } from '../../utils/icons'\n\nimport CardThumbnail from './CardThumbnail'\n\nexport interface CreatorCardProps extends LockedAttachmentBaseProps {\n placeholderTitle?: string\n placeholderAmountText?: string\n onDismiss?: () => void\n onPreviewClick?: () => LockedAttachmentSource\n}\n\nconst CreatorCard: React.FC<CreatorCardProps> = ({\n title,\n mimeType = 'application/octet-stream',\n thumbnailUrl,\n detail,\n amountText,\n placeholderTitle = 'Attachment title',\n placeholderAmountText,\n paymentStatus,\n onDismiss,\n onPreviewClick,\n}) => {\n const [source, setSource] = useState<LockedAttachmentSource | undefined>()\n\n const effectiveSourceUrl = source?.sourceUrl\n const effectiveThumbnailUrl = source?.thumbnailUrl ?? thumbnailUrl\n\n const handleToggle = useCallback(() => {\n if (source) {\n setSource(undefined)\n } else if (onPreviewClick) {\n setSource(onPreviewClick())\n }\n }, [source, onPreviewClick])\n\n return (\n <div className=\"relative w-[280px] select-none overflow-hidden rounded-[24px] bg-white shadow-[0_0_0_1px_rgba(0,0,0,0.04),0_4px_8px_rgba(0,0,0,0.06)]\">\n <CardHeader\n onDismiss={onDismiss}\n onPreviewClick={onPreviewClick}\n sourceUrl={source?.sourceUrl}\n paymentStatus={paymentStatus}\n />\n\n <CardThumbnail\n title={title}\n sourceUrl={effectiveSourceUrl}\n thumbnailUrl={effectiveThumbnailUrl}\n mimeType={mimeType}\n onToggle={onPreviewClick ? handleToggle : undefined}\n />\n\n <div className=\"px-4 pb-3 pt-3 bg-black\">\n <p\n className={classNames('mb-1.5 truncate text-base font-medium', {\n 'text-white/30': !title,\n 'text-white': !!title,\n })}\n >\n {title || placeholderTitle}\n </p>\n\n <div className=\"flex items-center gap-1\">\n {renderTypeIcon(mimeType, {\n className: 'size-5 shrink-0 text-white/55',\n weight: 'regular',\n })}\n\n {detail && (\n <span className=\"text-xs font-medium text-white/55\">{detail}</span>\n )}\n\n {paymentStatus === 'paid' ? (\n <React.Fragment>\n <span className=\"text-xs font-medium text-white/55\">•</span>\n <span className=\"text-xs font-medium text-[#4ade80]\">Sold</span>\n <CheckCircleIcon\n className=\"size-4 text-[#4ade80]\"\n weight=\"bold\"\n />\n </React.Fragment>\n ) : (\n <React.Fragment>\n <span className=\"text-xs font-medium text-white/55\">•</span>\n <span\n className={classNames('text-xs font-medium', {\n 'text-white/30': !amountText,\n 'text-white/55': !!amountText,\n })}\n >\n {amountText || placeholderAmountText}\n </span>\n </React.Fragment>\n )}\n </div>\n </div>\n </div>\n )\n}\n\ninterface CardHeaderProps {\n onDismiss?: () => void\n onPreviewClick?: () => void\n sourceUrl?: string\n paymentStatus?: PaymentStatus\n}\n\nconst CardHeader: React.FC<CardHeaderProps> = ({\n onDismiss,\n onPreviewClick,\n sourceUrl,\n paymentStatus,\n}) => {\n if (onDismiss) {\n return (\n <button\n type=\"button\"\n onClick={onDismiss}\n className=\"absolute top-3 z-50 flex size-8 items-center justify-center rounded-full bg-black/60 text-white right-3\"\n aria-label=\"Dismiss attachment\"\n >\n <XIcon className=\"size-4\" weight=\"bold\" />\n </button>\n )\n }\n\n const Icon = onPreviewClick\n ? sourceUrl\n ? EyeIcon\n : EyeSlashIcon\n : paymentStatus === 'paid'\n ? LockOpenIcon\n : LockIcon\n\n return (\n <div className=\"absolute top-3 z-50 flex size-8 items-center justify-center rounded-full bg-black/60 text-white left-3\">\n <Icon className=\"size-4\" weight=\"fill\" />\n </div>\n )\n}\n\nexport default CreatorCard\n"],"names":["CardThumbnail","title","sourceUrl","thumbnailUrl","mimeType","onToggle","isExpanded","jsxs","classNames","jsx","ThumbnailMedia","sourceType","getSourceType","MediaPlayer","CreatorCard","detail","amountText","placeholderTitle","placeholderAmountText","paymentStatus","onDismiss","onPreviewClick","source","setSource","useState","effectiveSourceUrl","effectiveThumbnailUrl","handleToggle","useCallback","CardHeader","renderTypeIcon","React","CheckCircleIcon","XIcon","EyeIcon","EyeSlashIcon","LockOpenIcon","LockIcon"],"mappings":"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"}
|