@linktr.ee/messaging-react 1.28.0-rc-1776231821 → 1.28.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/{Creator-BFpHsh2u.js → Creator-VyMyIk2b.js} +126 -114
- package/dist/Creator-VyMyIk2b.js.map +1 -0
- package/dist/{MediaPlayer-DXz4IBLx.js → MediaPlayer-Bf-xPB8Z.js} +99 -94
- package/dist/MediaPlayer-Bf-xPB8Z.js.map +1 -0
- package/dist/Visitor-C4WqnN8H.js +218 -0
- package/dist/Visitor-C4WqnN8H.js.map +1 -0
- package/dist/index.d.ts +2 -1
- package/dist/index.js +640 -636
- package/dist/index.js.map +1 -1
- package/package.json +1 -1
- package/src/components/LockedAttachment/LockedAttachment.stories.tsx +24 -7
- package/src/components/LockedAttachment/components/Creator.tsx +25 -5
- package/src/components/LockedAttachment/components/MediaPlayer.tsx +10 -2
- package/src/components/LockedAttachment/components/Visitor.tsx +75 -33
- package/src/components/MessagingShell/index.tsx +4 -0
- package/dist/Creator-BFpHsh2u.js.map +0 -1
- package/dist/MediaPlayer-DXz4IBLx.js.map +0 -1
- package/dist/Visitor-C1Fcrgd6.js +0 -199
- package/dist/Visitor-C1Fcrgd6.js.map +0 -1
package/dist/Visitor-C1Fcrgd6.js
DELETED
|
@@ -1,199 +0,0 @@
|
|
|
1
|
-
import { jsxs as c, jsx as e, Fragment as b } from "react/jsx-runtime";
|
|
2
|
-
import { CheckCircleIcon as T, LockOpenIcon as v, DownloadSimpleIcon as P, LockSimpleIcon as C } from "@phosphor-icons/react";
|
|
3
|
-
import { useState as x, useEffect as L } from "react";
|
|
4
|
-
import { g as D, r as g, M as U } from "./MediaPlayer-DXz4IBLx.js";
|
|
5
|
-
const h = (s) => s === "paid" ? v : C, z = (s) => {
|
|
6
|
-
const { icon: t } = s;
|
|
7
|
-
return /* @__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", children: /* @__PURE__ */ e(t, { className: "size-4 text-white", weight: "fill" }) }) });
|
|
8
|
-
}, I = (s) => {
|
|
9
|
-
const { thumbnail: t, mimeType: n, LockIcon: a } = s;
|
|
10
|
-
return /* @__PURE__ */ c("div", { className: "relative aspect-video overflow-hidden bg-black/5", children: [
|
|
11
|
-
t ? /* @__PURE__ */ e(
|
|
12
|
-
"img",
|
|
13
|
-
{
|
|
14
|
-
src: t,
|
|
15
|
-
alt: "",
|
|
16
|
-
className: "absolute inset-0 h-full w-full object-cover"
|
|
17
|
-
}
|
|
18
|
-
) : /* @__PURE__ */ e("div", { className: "absolute inset-0 flex items-center justify-center", children: g(n, {
|
|
19
|
-
className: "size-12 text-black/20",
|
|
20
|
-
weight: "regular"
|
|
21
|
-
}) }),
|
|
22
|
-
/* @__PURE__ */ e(z, { icon: a })
|
|
23
|
-
] });
|
|
24
|
-
}, M = (s) => {
|
|
25
|
-
const { source: t, thumbnail: n, mimeType: a, title: i, paymentStatus: l, isLocked: o } = s, [r, m] = x(!1);
|
|
26
|
-
return L(() => {
|
|
27
|
-
m(!1);
|
|
28
|
-
}, [t]), o ? /* @__PURE__ */ e(
|
|
29
|
-
I,
|
|
30
|
-
{
|
|
31
|
-
thumbnail: n,
|
|
32
|
-
mimeType: a,
|
|
33
|
-
LockIcon: h(l)
|
|
34
|
-
}
|
|
35
|
-
) : /* @__PURE__ */ e("div", { className: "relative overflow-hidden bg-black/5", children: /* @__PURE__ */ e(
|
|
36
|
-
"img",
|
|
37
|
-
{
|
|
38
|
-
src: t,
|
|
39
|
-
alt: i,
|
|
40
|
-
className: `block w-full transition-opacity duration-300 ${r ? "opacity-100" : "opacity-0"}`,
|
|
41
|
-
onLoad: () => m(!0)
|
|
42
|
-
}
|
|
43
|
-
) });
|
|
44
|
-
}, O = (s) => {
|
|
45
|
-
const { thumbnail: t, mimeType: n, paymentStatus: a, isLocked: i } = s;
|
|
46
|
-
return /* @__PURE__ */ c("div", { className: "relative aspect-video overflow-hidden bg-black/5", children: [
|
|
47
|
-
t ? /* @__PURE__ */ e(
|
|
48
|
-
"img",
|
|
49
|
-
{
|
|
50
|
-
src: t,
|
|
51
|
-
alt: "",
|
|
52
|
-
className: "absolute inset-0 h-full w-full object-cover"
|
|
53
|
-
}
|
|
54
|
-
) : /* @__PURE__ */ e("div", { className: "absolute inset-0 flex items-center justify-center", children: g(n, {
|
|
55
|
-
className: "size-12 text-black/20",
|
|
56
|
-
weight: "regular"
|
|
57
|
-
}) }),
|
|
58
|
-
i && /* @__PURE__ */ e(z, { icon: h(a) })
|
|
59
|
-
] });
|
|
60
|
-
}, R = (s) => {
|
|
61
|
-
const { source: t, thumbnail: n, mimeType: a, paymentStatus: i, isLocked: l } = s;
|
|
62
|
-
return l ? /* @__PURE__ */ e(
|
|
63
|
-
I,
|
|
64
|
-
{
|
|
65
|
-
thumbnail: n,
|
|
66
|
-
mimeType: a,
|
|
67
|
-
LockIcon: h(i)
|
|
68
|
-
}
|
|
69
|
-
) : /* @__PURE__ */ e(U, { source: t, mimeType: a, poster: n });
|
|
70
|
-
}, A = (s) => {
|
|
71
|
-
const { isLocked: t, loading: n, paymentStatus: a, source: i, onUnlock: l, onDownload: o } = s, r = h(a);
|
|
72
|
-
return t && l ? /* @__PURE__ */ e(
|
|
73
|
-
"button",
|
|
74
|
-
{
|
|
75
|
-
type: "button",
|
|
76
|
-
onClick: l,
|
|
77
|
-
disabled: n,
|
|
78
|
-
className: "mt-3 inline-flex h-10 w-full items-center justify-center gap-2 rounded-full bg-[#121110] px-4 text-sm font-medium leading-none text-white disabled:opacity-70",
|
|
79
|
-
children: n ? /* @__PURE__ */ c("span", { className: "flex items-center gap-1", children: [
|
|
80
|
-
/* @__PURE__ */ e("span", { className: "size-1 rounded-full bg-white animate-bounce [animation-delay:-0.3s]" }),
|
|
81
|
-
/* @__PURE__ */ e("span", { className: "size-1 rounded-full bg-white animate-bounce [animation-delay:-0.15s]" }),
|
|
82
|
-
/* @__PURE__ */ e("span", { className: "size-1 rounded-full bg-white animate-bounce" })
|
|
83
|
-
] }) : /* @__PURE__ */ c(b, { children: [
|
|
84
|
-
a === "paid" ? /* @__PURE__ */ e(v, { className: "size-4", weight: "fill" }) : /* @__PURE__ */ e(r, { className: "size-4", weight: "fill" }),
|
|
85
|
-
a === "paid" ? "Open" : "Unlock"
|
|
86
|
-
] })
|
|
87
|
-
}
|
|
88
|
-
) : !t && o && i ? /* @__PURE__ */ c(
|
|
89
|
-
"a",
|
|
90
|
-
{
|
|
91
|
-
href: i,
|
|
92
|
-
target: "_blank",
|
|
93
|
-
rel: "noopener noreferrer",
|
|
94
|
-
onClick: o,
|
|
95
|
-
className: "mt-3 inline-flex h-10 w-full items-center justify-center gap-2 rounded-full bg-[#121110] px-4 text-sm font-medium leading-none !text-white",
|
|
96
|
-
children: [
|
|
97
|
-
/* @__PURE__ */ e(P, { className: "size-4", weight: "bold" }),
|
|
98
|
-
"Download"
|
|
99
|
-
]
|
|
100
|
-
}
|
|
101
|
-
) : null;
|
|
102
|
-
}, $ = (s) => {
|
|
103
|
-
const {
|
|
104
|
-
title: t,
|
|
105
|
-
amountText: n,
|
|
106
|
-
thumbnail: a,
|
|
107
|
-
source: i,
|
|
108
|
-
mimeType: l = "application/octet-stream",
|
|
109
|
-
detail: o,
|
|
110
|
-
onUnlock: r,
|
|
111
|
-
onDownload: m,
|
|
112
|
-
paymentStatus: d
|
|
113
|
-
} = s, [u, k] = x(i), [S, w] = x(!1);
|
|
114
|
-
L(() => {
|
|
115
|
-
i !== void 0 && k(i);
|
|
116
|
-
}, [i]);
|
|
117
|
-
const f = u === void 0, N = D(l), j = async () => {
|
|
118
|
-
if (r) {
|
|
119
|
-
w(!0);
|
|
120
|
-
try {
|
|
121
|
-
const y = await r();
|
|
122
|
-
k(y.source);
|
|
123
|
-
} catch {
|
|
124
|
-
} finally {
|
|
125
|
-
w(!1);
|
|
126
|
-
}
|
|
127
|
-
}
|
|
128
|
-
};
|
|
129
|
-
let p;
|
|
130
|
-
return N === "image" ? p = /* @__PURE__ */ e(
|
|
131
|
-
M,
|
|
132
|
-
{
|
|
133
|
-
source: u,
|
|
134
|
-
thumbnail: a,
|
|
135
|
-
mimeType: l,
|
|
136
|
-
title: t,
|
|
137
|
-
paymentStatus: d,
|
|
138
|
-
isLocked: f
|
|
139
|
-
}
|
|
140
|
-
) : N === "document" ? p = /* @__PURE__ */ e(
|
|
141
|
-
O,
|
|
142
|
-
{
|
|
143
|
-
thumbnail: a,
|
|
144
|
-
mimeType: l,
|
|
145
|
-
paymentStatus: d,
|
|
146
|
-
isLocked: f
|
|
147
|
-
}
|
|
148
|
-
) : p = /* @__PURE__ */ e(
|
|
149
|
-
R,
|
|
150
|
-
{
|
|
151
|
-
source: u,
|
|
152
|
-
thumbnail: a,
|
|
153
|
-
mimeType: l,
|
|
154
|
-
paymentStatus: d,
|
|
155
|
-
isLocked: f
|
|
156
|
-
}
|
|
157
|
-
), /* @__PURE__ */ c("div", { className: "w-[280px] select-none overflow-hidden rounded-3xl bg-white shadow-card", children: [
|
|
158
|
-
p,
|
|
159
|
-
/* @__PURE__ */ c("div", { className: "px-4 pb-3 pt-3", children: [
|
|
160
|
-
/* @__PURE__ */ e("p", { className: "mb-1.5 truncate text-base font-medium text-black", children: t }),
|
|
161
|
-
/* @__PURE__ */ c("div", { className: "flex items-center gap-1", children: [
|
|
162
|
-
g(l, {
|
|
163
|
-
className: "size-5 shrink-0 text-black/55",
|
|
164
|
-
weight: "regular"
|
|
165
|
-
}),
|
|
166
|
-
o && /* @__PURE__ */ e("span", { className: "text-xs font-medium text-black/55", children: o }),
|
|
167
|
-
d === "paid" ? /* @__PURE__ */ c(b, { children: [
|
|
168
|
-
/* @__PURE__ */ e("span", { className: "text-xs font-medium text-black/55", children: "•" }),
|
|
169
|
-
/* @__PURE__ */ e("span", { className: "text-xs font-medium text-[#008236]", children: "Purchased" }),
|
|
170
|
-
/* @__PURE__ */ e(
|
|
171
|
-
T,
|
|
172
|
-
{
|
|
173
|
-
className: "size-4 text-[#008236]",
|
|
174
|
-
weight: "bold"
|
|
175
|
-
}
|
|
176
|
-
)
|
|
177
|
-
] }) : n && /* @__PURE__ */ c(b, { children: [
|
|
178
|
-
/* @__PURE__ */ e("span", { className: "text-xs font-medium text-black/55", children: "•" }),
|
|
179
|
-
/* @__PURE__ */ e("span", { className: "text-xs font-medium text-black/55", children: n })
|
|
180
|
-
] })
|
|
181
|
-
] }),
|
|
182
|
-
/* @__PURE__ */ e(
|
|
183
|
-
A,
|
|
184
|
-
{
|
|
185
|
-
isLocked: f,
|
|
186
|
-
loading: S,
|
|
187
|
-
paymentStatus: d,
|
|
188
|
-
source: u,
|
|
189
|
-
onUnlock: r ? j : void 0,
|
|
190
|
-
onDownload: m
|
|
191
|
-
}
|
|
192
|
-
)
|
|
193
|
-
] })
|
|
194
|
-
] });
|
|
195
|
-
};
|
|
196
|
-
export {
|
|
197
|
-
$ as default
|
|
198
|
-
};
|
|
199
|
-
//# sourceMappingURL=Visitor-C1Fcrgd6.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"Visitor-C1Fcrgd6.js","sources":["../src/components/LockedAttachment/components/Visitor.tsx"],"sourcesContent":["import {\n CheckCircleIcon,\n DownloadSimpleIcon,\n LockOpenIcon,\n LockSimpleIcon,\n} from '@phosphor-icons/react'\nimport React, { useEffect, useState } from 'react'\n\nimport { isDevBuild } from '../../../utils/isDevBuild'\nimport type {\n LockedAttachmentBaseProps,\n LockedAttachmentSource,\n PaymentStatus,\n} from '../types'\nimport { renderTypeIcon } from '../utils/icons'\nimport { getSourceType } from '../utils/mimeType'\n\nimport MediaPlayer from './MediaPlayer'\n\nexport interface VisitorCardProps extends LockedAttachmentBaseProps {\n /**\n * Called when the visitor clicks Unlock. Return the resolved source URL.\n * The component manages loading state and sets source internally on resolution.\n * Omit to hide the Unlock button.\n */\n onUnlock?: () => Promise<LockedAttachmentSource>\n /** \n * Called when the visitor clicks Download on an unlocked card.\n */\n onDownload?: () => void\n}\n\nconst getLockIcon = (paymentStatus?: PaymentStatus): React.ElementType =>\n paymentStatus === 'paid' ? LockOpenIcon : LockSimpleIcon\n\n\ninterface LockOverlayProps {\n icon: React.ElementType\n}\n\nconst LockOverlay: React.FC<LockOverlayProps> = (props) => {\n const { icon: Icon } = props\n return (\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\">\n <Icon className=\"size-4 text-white\" weight=\"fill\" />\n </div>\n </div>\n )\n}\n\ninterface LockedPreviewProps {\n thumbnail?: string\n mimeType: string\n LockIcon: React.ElementType\n}\n\nconst LockedPreview: React.FC<LockedPreviewProps> = (props) => {\n const { thumbnail, mimeType, LockIcon } = props\n return (\n <div className=\"relative aspect-video overflow-hidden bg-black/5\">\n {thumbnail ? (\n <img\n src={thumbnail}\n alt=\"\"\n className=\"absolute inset-0 h-full w-full object-cover\"\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 <LockOverlay icon={LockIcon} />\n </div>\n )\n}\n\n\ninterface ImagePreviewProps {\n source?: string\n thumbnail?: string\n mimeType: string\n title?: string\n paymentStatus?: PaymentStatus\n isLocked: boolean\n}\n\nconst ImagePreview: React.FC<ImagePreviewProps> = (props) => {\n const { source, thumbnail, mimeType, title, paymentStatus, isLocked } = props\n const [sourceReady, setSourceReady] = useState(false)\n\n useEffect(() => {\n setSourceReady(false)\n }, [source])\n\n if (isLocked) {\n return (\n <LockedPreview\n thumbnail={thumbnail}\n mimeType={mimeType}\n LockIcon={getLockIcon(paymentStatus)}\n />\n )\n }\n\n return (\n <div className=\"relative overflow-hidden bg-black/5\">\n <img\n src={source}\n alt={title}\n className={`block w-full transition-opacity duration-300 ${sourceReady ? 'opacity-100' : 'opacity-0'}`}\n onLoad={() => setSourceReady(true)}\n />\n </div>\n )\n}\n\ninterface DocumentPreviewProps {\n thumbnail?: string\n mimeType: string\n paymentStatus?: PaymentStatus\n isLocked: boolean\n}\n\nconst DocumentPreview: React.FC<DocumentPreviewProps> = (props) => {\n const { thumbnail, mimeType, paymentStatus, isLocked } = props\n return (\n <div className=\"relative aspect-video overflow-hidden bg-black/5\">\n {thumbnail ? (\n <img\n src={thumbnail}\n alt=\"\"\n className=\"absolute inset-0 h-full w-full object-cover\"\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 && <LockOverlay icon={getLockIcon(paymentStatus)} />}\n </div>\n )\n}\n\ninterface MediaPreviewProps {\n source?: string\n thumbnail?: string\n mimeType: string\n paymentStatus?: PaymentStatus\n isLocked: boolean\n}\n\nconst MediaPreview: React.FC<MediaPreviewProps> = (props) => {\n const { source, thumbnail, mimeType, paymentStatus, isLocked } = props\n if (isLocked) {\n return (\n <LockedPreview\n thumbnail={thumbnail}\n mimeType={mimeType}\n LockIcon={getLockIcon(paymentStatus)}\n />\n )\n }\n return <MediaPlayer source={source!} mimeType={mimeType} poster={thumbnail} />\n}\n\n\ninterface CardActionsProps {\n isLocked: boolean\n loading: boolean\n paymentStatus?: PaymentStatus\n source?: string\n onUnlock?: () => void\n onDownload?: () => void\n}\n\nconst CardActions: React.FC<CardActionsProps> = (props) => {\n const { isLocked, loading, paymentStatus, source, onUnlock, onDownload } =\n props\n const LockIcon = getLockIcon(paymentStatus)\n\n if (isLocked && onUnlock) {\n return (\n <button\n type=\"button\"\n onClick={onUnlock}\n disabled={loading}\n className=\"mt-3 inline-flex h-10 w-full items-center justify-center gap-2 rounded-full bg-[#121110] px-4 text-sm font-medium leading-none text-white disabled:opacity-70\"\n >\n {loading ? (\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 {paymentStatus === 'paid' ? (\n <LockOpenIcon className=\"size-4\" weight=\"fill\" />\n ) : (\n <LockIcon className=\"size-4\" weight=\"fill\" />\n )}\n {paymentStatus === 'paid' ? 'Open' : 'Unlock'}\n </>\n )}\n </button>\n )\n }\n\n if (!isLocked && onDownload && source) {\n return (\n <a\n href={source}\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n onClick={onDownload}\n className=\"mt-3 inline-flex h-10 w-full items-center justify-center gap-2 rounded-full bg-[#121110] px-4 text-sm font-medium leading-none !text-white\"\n >\n <DownloadSimpleIcon className=\"size-4\" weight=\"bold\" />\n Download\n </a>\n )\n }\n\n return null\n}\n\n\nconst VisitorCard: React.FC<VisitorCardProps> = (props) => {\n const {\n title,\n amountText,\n thumbnail,\n source: sourceProp,\n mimeType = 'application/octet-stream',\n detail,\n onUnlock,\n onDownload,\n paymentStatus,\n } = props\n const [source, setSource] = useState(sourceProp)\n const [loading, setLoading] = useState(false)\n\n useEffect(() => {\n if (sourceProp !== undefined) setSource(sourceProp)\n }, [sourceProp])\n\n const isLocked = source === undefined\n const sourceType = getSourceType(mimeType)\n\n const handleUnlock = async () => {\n if (!onUnlock) return\n setLoading(true)\n try {\n const result = await onUnlock()\n setSource(result.source)\n } catch (err) {\n if (isDevBuild()) console.debug('[LockedAttachment] onUnlock failed', err)\n } finally {\n setLoading(false)\n }\n }\n\n let mediaPreview: React.ReactNode\n if (sourceType === 'image') {\n mediaPreview = (\n <ImagePreview\n source={source}\n thumbnail={thumbnail}\n mimeType={mimeType}\n title={title}\n paymentStatus={paymentStatus}\n isLocked={isLocked}\n />\n )\n } else if (sourceType === 'document') {\n mediaPreview = (\n <DocumentPreview\n thumbnail={thumbnail}\n mimeType={mimeType}\n paymentStatus={paymentStatus}\n isLocked={isLocked}\n />\n )\n } else {\n mediaPreview = (\n <MediaPreview\n source={source}\n thumbnail={thumbnail}\n mimeType={mimeType}\n paymentStatus={paymentStatus}\n isLocked={isLocked}\n />\n )\n }\n\n return (\n <div className=\"w-[280px] select-none overflow-hidden rounded-3xl bg-white shadow-card\">\n {mediaPreview}\n <div className=\"px-4 pb-3 pt-3\">\n <p className=\"mb-1.5 truncate text-base font-medium text-black\">\n {title}\n </p>\n <div className=\"flex items-center gap-1\">\n {renderTypeIcon(mimeType, {\n className: 'size-5 shrink-0 text-black/55',\n weight: 'regular',\n })}\n {detail && (\n <span className=\"text-xs font-medium text-black/55\">{detail}</span>\n )}\n {paymentStatus === 'paid' ? (\n <>\n <span className=\"text-xs font-medium text-black/55\">•</span>\n <span className=\"text-xs font-medium text-[#008236]\">\n Purchased\n </span>\n <CheckCircleIcon\n className=\"size-4 text-[#008236]\"\n weight=\"bold\"\n />\n </>\n ) : (\n amountText && (\n <>\n <span className=\"text-xs font-medium text-black/55\">•</span>\n <span className=\"text-xs font-medium text-black/55\">\n {amountText}\n </span>\n </>\n )\n )}\n </div>\n <CardActions\n isLocked={isLocked}\n loading={loading}\n paymentStatus={paymentStatus}\n source={source}\n onUnlock={onUnlock ? handleUnlock : undefined}\n onDownload={onDownload}\n />\n </div>\n </div>\n )\n}\n\nexport default VisitorCard\n"],"names":["getLockIcon","paymentStatus","LockOpenIcon","LockSimpleIcon","LockOverlay","props","Icon","jsx","LockedPreview","thumbnail","mimeType","LockIcon","jsxs","ImagePreview","source","title","isLocked","sourceReady","setSourceReady","useState","useEffect","DocumentPreview","MediaPreview","MediaPlayer","CardActions","loading","onUnlock","onDownload","Fragment","DownloadSimpleIcon","VisitorCard","amountText","sourceProp","detail","setSource","setLoading","sourceType","getSourceType","handleUnlock","result","mediaPreview","renderTypeIcon","CheckCircleIcon"],"mappings":"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"}
|