@plasmicpkgs/plasmic-link-preview 1.0.147 → 1.0.148
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/plasmic-link-preview.cjs.development.js +106 -302
- package/dist/plasmic-link-preview.cjs.development.js.map +1 -1
- package/dist/plasmic-link-preview.cjs.production.min.js +1 -1
- package/dist/plasmic-link-preview.cjs.production.min.js.map +1 -1
- package/dist/plasmic-link-preview.esm.js +106 -302
- package/dist/plasmic-link-preview.esm.js.map +1 -1
- package/package.json +3 -3
|
@@ -53,329 +53,136 @@ function _extends() {
|
|
|
53
53
|
return n;
|
|
54
54
|
}, _extends.apply(null, arguments);
|
|
55
55
|
}
|
|
56
|
-
function
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
return o(a, "_invoke", {
|
|
91
|
-
value: makeInvokeMethod(t, r, c)
|
|
92
|
-
}), a;
|
|
93
|
-
}
|
|
94
|
-
function tryCatch(t, e, r) {
|
|
95
|
-
try {
|
|
96
|
-
return {
|
|
97
|
-
type: "normal",
|
|
98
|
-
arg: t.call(e, r)
|
|
99
|
-
};
|
|
100
|
-
} catch (t) {
|
|
101
|
-
return {
|
|
102
|
-
type: "throw",
|
|
103
|
-
arg: t
|
|
104
|
-
};
|
|
105
|
-
}
|
|
106
|
-
}
|
|
107
|
-
e.wrap = wrap;
|
|
108
|
-
var h = "suspendedStart",
|
|
109
|
-
l = "suspendedYield",
|
|
110
|
-
f = "executing",
|
|
111
|
-
s = "completed",
|
|
112
|
-
y = {};
|
|
113
|
-
function Generator() {}
|
|
114
|
-
function GeneratorFunction() {}
|
|
115
|
-
function GeneratorFunctionPrototype() {}
|
|
116
|
-
var p = {};
|
|
117
|
-
define(p, a, function () {
|
|
118
|
-
return this;
|
|
119
|
-
});
|
|
120
|
-
var d = Object.getPrototypeOf,
|
|
121
|
-
v = d && d(d(values([])));
|
|
122
|
-
v && v !== r && n.call(v, a) && (p = v);
|
|
123
|
-
var g = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(p);
|
|
124
|
-
function defineIteratorMethods(t) {
|
|
125
|
-
["next", "throw", "return"].forEach(function (e) {
|
|
126
|
-
define(t, e, function (t) {
|
|
127
|
-
return this._invoke(e, t);
|
|
128
|
-
});
|
|
129
|
-
});
|
|
130
|
-
}
|
|
131
|
-
function AsyncIterator(t, e) {
|
|
132
|
-
function invoke(r, o, i, a) {
|
|
133
|
-
var c = tryCatch(t[r], t, o);
|
|
134
|
-
if ("throw" !== c.type) {
|
|
135
|
-
var u = c.arg,
|
|
136
|
-
h = u.value;
|
|
137
|
-
return h && "object" == typeof h && n.call(h, "__await") ? e.resolve(h.__await).then(function (t) {
|
|
138
|
-
invoke("next", t, i, a);
|
|
139
|
-
}, function (t) {
|
|
140
|
-
invoke("throw", t, i, a);
|
|
141
|
-
}) : e.resolve(h).then(function (t) {
|
|
142
|
-
u.value = t, i(u);
|
|
143
|
-
}, function (t) {
|
|
144
|
-
return invoke("throw", t, i, a);
|
|
145
|
-
});
|
|
146
|
-
}
|
|
147
|
-
a(c.arg);
|
|
148
|
-
}
|
|
149
|
-
var r;
|
|
150
|
-
o(this, "_invoke", {
|
|
151
|
-
value: function (t, n) {
|
|
152
|
-
function callInvokeWithMethodAndArg() {
|
|
153
|
-
return new e(function (e, r) {
|
|
154
|
-
invoke(t, n, e, r);
|
|
155
|
-
});
|
|
56
|
+
function _regenerator() {
|
|
57
|
+
/*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/babel/babel/blob/main/packages/babel-helpers/LICENSE */
|
|
58
|
+
var e,
|
|
59
|
+
t,
|
|
60
|
+
r = "function" == typeof Symbol ? Symbol : {},
|
|
61
|
+
n = r.iterator || "@@iterator",
|
|
62
|
+
o = r.toStringTag || "@@toStringTag";
|
|
63
|
+
function i(r, n, o, i) {
|
|
64
|
+
var c = n && n.prototype instanceof Generator ? n : Generator,
|
|
65
|
+
u = Object.create(c.prototype);
|
|
66
|
+
return _regeneratorDefine(u, "_invoke", function (r, n, o) {
|
|
67
|
+
var i,
|
|
68
|
+
c,
|
|
69
|
+
u,
|
|
70
|
+
f = 0,
|
|
71
|
+
p = o || [],
|
|
72
|
+
y = !1,
|
|
73
|
+
G = {
|
|
74
|
+
p: 0,
|
|
75
|
+
n: 0,
|
|
76
|
+
v: e,
|
|
77
|
+
a: d,
|
|
78
|
+
f: d.bind(e, 4),
|
|
79
|
+
d: function (t, r) {
|
|
80
|
+
return i = t, c = 0, u = e, G.n = r, a;
|
|
81
|
+
}
|
|
82
|
+
};
|
|
83
|
+
function d(r, n) {
|
|
84
|
+
for (c = r, u = n, t = 0; !y && f && !o && t < p.length; t++) {
|
|
85
|
+
var o,
|
|
86
|
+
i = p[t],
|
|
87
|
+
d = G.p,
|
|
88
|
+
l = i[2];
|
|
89
|
+
r > 3 ? (o = l === n) && (u = i[(c = i[4]) ? 5 : (c = 3, 3)], i[4] = i[5] = e) : i[0] <= d && ((o = r < 2 && d < i[1]) ? (c = 0, G.v = n, G.n = i[1]) : d < l && (o = r < 3 || i[0] > n || n > l) && (i[4] = r, i[5] = n, G.n = l, c = 0));
|
|
156
90
|
}
|
|
157
|
-
|
|
91
|
+
if (o || r > 1) return a;
|
|
92
|
+
throw y = !0, n;
|
|
158
93
|
}
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
94
|
+
return function (o, p, l) {
|
|
95
|
+
if (f > 1) throw TypeError("Generator is already running");
|
|
96
|
+
for (y && 1 === p && d(p, l), c = p, u = l; (t = c < 2 ? e : u) || !y;) {
|
|
97
|
+
i || (c ? c < 3 ? (c > 1 && (G.n = -1), d(c, u)) : G.n = u : G.v = u);
|
|
98
|
+
try {
|
|
99
|
+
if (f = 2, i) {
|
|
100
|
+
if (c || (o = "next"), t = i[o]) {
|
|
101
|
+
if (!(t = t.call(i, u))) throw TypeError("iterator result is not an object");
|
|
102
|
+
if (!t.done) return t;
|
|
103
|
+
u = t.value, c < 2 && (c = 0);
|
|
104
|
+
} else 1 === c && (t = i.return) && t.call(i), c < 2 && (u = TypeError("The iterator does not provide a '" + o + "' method"), c = 1);
|
|
105
|
+
i = e;
|
|
106
|
+
} else if ((t = (y = G.n < 0) ? u : r.call(n, G)) !== a) break;
|
|
107
|
+
} catch (t) {
|
|
108
|
+
i = e, c = 1, u = t;
|
|
109
|
+
} finally {
|
|
110
|
+
f = 1;
|
|
111
|
+
}
|
|
112
|
+
}
|
|
167
113
|
return {
|
|
168
114
|
value: t,
|
|
169
|
-
done:
|
|
115
|
+
done: y
|
|
170
116
|
};
|
|
171
|
-
}
|
|
172
|
-
|
|
173
|
-
var c = n.delegate;
|
|
174
|
-
if (c) {
|
|
175
|
-
var u = maybeInvokeDelegate(c, n);
|
|
176
|
-
if (u) {
|
|
177
|
-
if (u === y) continue;
|
|
178
|
-
return u;
|
|
179
|
-
}
|
|
180
|
-
}
|
|
181
|
-
if ("next" === n.method) n.sent = n._sent = n.arg;else if ("throw" === n.method) {
|
|
182
|
-
if (o === h) throw o = s, n.arg;
|
|
183
|
-
n.dispatchException(n.arg);
|
|
184
|
-
} else "return" === n.method && n.abrupt("return", n.arg);
|
|
185
|
-
o = f;
|
|
186
|
-
var p = tryCatch(e, r, n);
|
|
187
|
-
if ("normal" === p.type) {
|
|
188
|
-
if (o = n.done ? s : l, p.arg === y) continue;
|
|
189
|
-
return {
|
|
190
|
-
value: p.arg,
|
|
191
|
-
done: n.done
|
|
192
|
-
};
|
|
193
|
-
}
|
|
194
|
-
"throw" === p.type && (o = s, n.method = "throw", n.arg = p.arg);
|
|
195
|
-
}
|
|
196
|
-
};
|
|
197
|
-
}
|
|
198
|
-
function maybeInvokeDelegate(e, r) {
|
|
199
|
-
var n = r.method,
|
|
200
|
-
o = e.iterator[n];
|
|
201
|
-
if (o === t) return r.delegate = null, "throw" === n && e.iterator.return && (r.method = "return", r.arg = t, maybeInvokeDelegate(e, r), "throw" === r.method) || "return" !== n && (r.method = "throw", r.arg = new TypeError("The iterator does not provide a '" + n + "' method")), y;
|
|
202
|
-
var i = tryCatch(o, e.iterator, r.arg);
|
|
203
|
-
if ("throw" === i.type) return r.method = "throw", r.arg = i.arg, r.delegate = null, y;
|
|
204
|
-
var a = i.arg;
|
|
205
|
-
return a ? a.done ? (r[e.resultName] = a.value, r.next = e.nextLoc, "return" !== r.method && (r.method = "next", r.arg = t), r.delegate = null, y) : a : (r.method = "throw", r.arg = new TypeError("iterator result is not an object"), r.delegate = null, y);
|
|
206
|
-
}
|
|
207
|
-
function pushTryEntry(t) {
|
|
208
|
-
var e = {
|
|
209
|
-
tryLoc: t[0]
|
|
210
|
-
};
|
|
211
|
-
1 in t && (e.catchLoc = t[1]), 2 in t && (e.finallyLoc = t[2], e.afterLoc = t[3]), this.tryEntries.push(e);
|
|
212
|
-
}
|
|
213
|
-
function resetTryEntry(t) {
|
|
214
|
-
var e = t.completion || {};
|
|
215
|
-
e.type = "normal", delete e.arg, t.completion = e;
|
|
216
|
-
}
|
|
217
|
-
function Context(t) {
|
|
218
|
-
this.tryEntries = [{
|
|
219
|
-
tryLoc: "root"
|
|
220
|
-
}], t.forEach(pushTryEntry, this), this.reset(!0);
|
|
117
|
+
};
|
|
118
|
+
}(r, o, i), !0), u;
|
|
221
119
|
}
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
return i.next = i;
|
|
234
|
-
}
|
|
235
|
-
}
|
|
236
|
-
throw new TypeError(typeof e + " is not iterable");
|
|
120
|
+
var a = {};
|
|
121
|
+
function Generator() {}
|
|
122
|
+
function GeneratorFunction() {}
|
|
123
|
+
function GeneratorFunctionPrototype() {}
|
|
124
|
+
t = Object.getPrototypeOf;
|
|
125
|
+
var c = [][n] ? t(t([][n]())) : (_regeneratorDefine(t = {}, n, function () {
|
|
126
|
+
return this;
|
|
127
|
+
}), t),
|
|
128
|
+
u = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(c);
|
|
129
|
+
function f(e) {
|
|
130
|
+
return Object.setPrototypeOf ? Object.setPrototypeOf(e, GeneratorFunctionPrototype) : (e.__proto__ = GeneratorFunctionPrototype, _regeneratorDefine(e, o, "GeneratorFunction")), e.prototype = Object.create(u), e;
|
|
237
131
|
}
|
|
238
|
-
return GeneratorFunction.prototype = GeneratorFunctionPrototype,
|
|
239
|
-
value: GeneratorFunctionPrototype,
|
|
240
|
-
configurable: !0
|
|
241
|
-
}), o(GeneratorFunctionPrototype, "constructor", {
|
|
242
|
-
value: GeneratorFunction,
|
|
243
|
-
configurable: !0
|
|
244
|
-
}), GeneratorFunction.displayName = define(GeneratorFunctionPrototype, u, "GeneratorFunction"), e.isGeneratorFunction = function (t) {
|
|
245
|
-
var e = "function" == typeof t && t.constructor;
|
|
246
|
-
return !!e && (e === GeneratorFunction || "GeneratorFunction" === (e.displayName || e.name));
|
|
247
|
-
}, e.mark = function (t) {
|
|
248
|
-
return Object.setPrototypeOf ? Object.setPrototypeOf(t, GeneratorFunctionPrototype) : (t.__proto__ = GeneratorFunctionPrototype, define(t, u, "GeneratorFunction")), t.prototype = Object.create(g), t;
|
|
249
|
-
}, e.awrap = function (t) {
|
|
250
|
-
return {
|
|
251
|
-
__await: t
|
|
252
|
-
};
|
|
253
|
-
}, defineIteratorMethods(AsyncIterator.prototype), define(AsyncIterator.prototype, c, function () {
|
|
254
|
-
return this;
|
|
255
|
-
}), e.AsyncIterator = AsyncIterator, e.async = function (t, r, n, o, i) {
|
|
256
|
-
void 0 === i && (i = Promise);
|
|
257
|
-
var a = new AsyncIterator(wrap(t, r, n, o), i);
|
|
258
|
-
return e.isGeneratorFunction(r) ? a : a.next().then(function (t) {
|
|
259
|
-
return t.done ? t.value : a.next();
|
|
260
|
-
});
|
|
261
|
-
}, defineIteratorMethods(g), define(g, u, "Generator"), define(g, a, function () {
|
|
132
|
+
return GeneratorFunction.prototype = GeneratorFunctionPrototype, _regeneratorDefine(u, "constructor", GeneratorFunctionPrototype), _regeneratorDefine(GeneratorFunctionPrototype, "constructor", GeneratorFunction), GeneratorFunction.displayName = "GeneratorFunction", _regeneratorDefine(GeneratorFunctionPrototype, o, "GeneratorFunction"), _regeneratorDefine(u), _regeneratorDefine(u, o, "Generator"), _regeneratorDefine(u, n, function () {
|
|
262
133
|
return this;
|
|
263
|
-
}),
|
|
134
|
+
}), _regeneratorDefine(u, "toString", function () {
|
|
264
135
|
return "[object Generator]";
|
|
265
|
-
}),
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
return r.reverse(), function next() {
|
|
270
|
-
for (; r.length;) {
|
|
271
|
-
var t = r.pop();
|
|
272
|
-
if (t in e) return next.value = t, next.done = !1, next;
|
|
273
|
-
}
|
|
274
|
-
return next.done = !0, next;
|
|
136
|
+
}), (_regenerator = function () {
|
|
137
|
+
return {
|
|
138
|
+
w: i,
|
|
139
|
+
m: f
|
|
275
140
|
};
|
|
276
|
-
}
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
function handle(n, o) {
|
|
291
|
-
return a.type = "throw", a.arg = e, r.next = n, o && (r.method = "next", r.arg = t), !!o;
|
|
292
|
-
}
|
|
293
|
-
for (var o = this.tryEntries.length - 1; o >= 0; --o) {
|
|
294
|
-
var i = this.tryEntries[o],
|
|
295
|
-
a = i.completion;
|
|
296
|
-
if ("root" === i.tryLoc) return handle("end");
|
|
297
|
-
if (i.tryLoc <= this.prev) {
|
|
298
|
-
var c = n.call(i, "catchLoc"),
|
|
299
|
-
u = n.call(i, "finallyLoc");
|
|
300
|
-
if (c && u) {
|
|
301
|
-
if (this.prev < i.catchLoc) return handle(i.catchLoc, !0);
|
|
302
|
-
if (this.prev < i.finallyLoc) return handle(i.finallyLoc);
|
|
303
|
-
} else if (c) {
|
|
304
|
-
if (this.prev < i.catchLoc) return handle(i.catchLoc, !0);
|
|
305
|
-
} else {
|
|
306
|
-
if (!u) throw Error("try statement without catch or finally");
|
|
307
|
-
if (this.prev < i.finallyLoc) return handle(i.finallyLoc);
|
|
308
|
-
}
|
|
309
|
-
}
|
|
310
|
-
}
|
|
311
|
-
},
|
|
312
|
-
abrupt: function (t, e) {
|
|
313
|
-
for (var r = this.tryEntries.length - 1; r >= 0; --r) {
|
|
314
|
-
var o = this.tryEntries[r];
|
|
315
|
-
if (o.tryLoc <= this.prev && n.call(o, "finallyLoc") && this.prev < o.finallyLoc) {
|
|
316
|
-
var i = o;
|
|
317
|
-
break;
|
|
318
|
-
}
|
|
319
|
-
}
|
|
320
|
-
i && ("break" === t || "continue" === t) && i.tryLoc <= e && e <= i.finallyLoc && (i = null);
|
|
321
|
-
var a = i ? i.completion : {};
|
|
322
|
-
return a.type = t, a.arg = e, i ? (this.method = "next", this.next = i.finallyLoc, y) : this.complete(a);
|
|
323
|
-
},
|
|
324
|
-
complete: function (t, e) {
|
|
325
|
-
if ("throw" === t.type) throw t.arg;
|
|
326
|
-
return "break" === t.type || "continue" === t.type ? this.next = t.arg : "return" === t.type ? (this.rval = this.arg = t.arg, this.method = "return", this.next = "end") : "normal" === t.type && e && (this.next = e), y;
|
|
327
|
-
},
|
|
328
|
-
finish: function (t) {
|
|
329
|
-
for (var e = this.tryEntries.length - 1; e >= 0; --e) {
|
|
330
|
-
var r = this.tryEntries[e];
|
|
331
|
-
if (r.finallyLoc === t) return this.complete(r.completion, r.afterLoc), resetTryEntry(r), y;
|
|
332
|
-
}
|
|
333
|
-
},
|
|
334
|
-
catch: function (t) {
|
|
335
|
-
for (var e = this.tryEntries.length - 1; e >= 0; --e) {
|
|
336
|
-
var r = this.tryEntries[e];
|
|
337
|
-
if (r.tryLoc === t) {
|
|
338
|
-
var n = r.completion;
|
|
339
|
-
if ("throw" === n.type) {
|
|
340
|
-
var o = n.arg;
|
|
341
|
-
resetTryEntry(r);
|
|
342
|
-
}
|
|
343
|
-
return o;
|
|
344
|
-
}
|
|
345
|
-
}
|
|
346
|
-
throw Error("illegal catch attempt");
|
|
347
|
-
},
|
|
348
|
-
delegateYield: function (e, r, n) {
|
|
349
|
-
return this.delegate = {
|
|
350
|
-
iterator: values(e),
|
|
351
|
-
resultName: r,
|
|
352
|
-
nextLoc: n
|
|
353
|
-
}, "next" === this.method && (this.arg = t), y;
|
|
141
|
+
})();
|
|
142
|
+
}
|
|
143
|
+
function _regeneratorDefine(e, r, n, t) {
|
|
144
|
+
var i = Object.defineProperty;
|
|
145
|
+
try {
|
|
146
|
+
i({}, "", {});
|
|
147
|
+
} catch (e) {
|
|
148
|
+
i = 0;
|
|
149
|
+
}
|
|
150
|
+
_regeneratorDefine = function (e, r, n, t) {
|
|
151
|
+
function o(r, n) {
|
|
152
|
+
_regeneratorDefine(e, r, function (e) {
|
|
153
|
+
return this._invoke(r, n, e);
|
|
154
|
+
});
|
|
354
155
|
}
|
|
355
|
-
|
|
156
|
+
r ? i ? i(e, r, {
|
|
157
|
+
value: n,
|
|
158
|
+
enumerable: !t,
|
|
159
|
+
configurable: !t,
|
|
160
|
+
writable: !t
|
|
161
|
+
}) : e[r] = n : (o("next", 0), o("throw", 1), o("return", 2));
|
|
162
|
+
}, _regeneratorDefine(e, r, n, t);
|
|
356
163
|
}
|
|
357
164
|
|
|
358
165
|
var isValidUrl = function isValidUrl(url) {
|
|
359
166
|
return /(^http(s?):\/\/[^\s$.?#].[^\s]*)/i.test(url);
|
|
360
167
|
};
|
|
361
168
|
var getMetadata = /*#__PURE__*/function () {
|
|
362
|
-
var _ref = /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/
|
|
169
|
+
var _ref = /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regenerator().m(function _callee(url) {
|
|
363
170
|
var contents, $, getHostname, getTitle, meta, metas, metadata;
|
|
364
|
-
return
|
|
365
|
-
while (1) switch (_context.
|
|
171
|
+
return _regenerator().w(function (_context) {
|
|
172
|
+
while (1) switch (_context.n) {
|
|
366
173
|
case 0:
|
|
367
174
|
if (isValidUrl(url)) {
|
|
368
|
-
_context.
|
|
175
|
+
_context.n = 1;
|
|
369
176
|
break;
|
|
370
177
|
}
|
|
371
|
-
return _context.
|
|
372
|
-
case
|
|
373
|
-
_context.
|
|
178
|
+
return _context.a(2, {});
|
|
179
|
+
case 1:
|
|
180
|
+
_context.n = 2;
|
|
374
181
|
return fetch("https://corsproxy.io/?" + url).then(function (res) {
|
|
375
182
|
return res.text();
|
|
376
183
|
});
|
|
377
|
-
case
|
|
378
|
-
contents = _context.
|
|
184
|
+
case 2:
|
|
185
|
+
contents = _context.v;
|
|
379
186
|
$ = nodeHtmlParser.parse(contents);
|
|
380
187
|
getHostname = function getHostname() {
|
|
381
188
|
var _URL = new URL(url),
|
|
@@ -428,10 +235,7 @@ var getMetadata = /*#__PURE__*/function () {
|
|
|
428
235
|
hostname: getHostname(),
|
|
429
236
|
title: getTitle()
|
|
430
237
|
}, meta);
|
|
431
|
-
return _context.
|
|
432
|
-
case 15:
|
|
433
|
-
case "end":
|
|
434
|
-
return _context.stop();
|
|
238
|
+
return _context.a(2, metadata);
|
|
435
239
|
}
|
|
436
240
|
}, _callee);
|
|
437
241
|
}));
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"plasmic-link-preview.cjs.development.js","sources":["../src/lib/utils.ts","../src/lib/html-metadata-parser.ts","../src/index.tsx"],"sourcesContent":["import {\n CodeComponentMeta,\n default as registerComponent,\n} from \"@plasmicapp/host/registerComponent\";\nimport {\n GlobalContextMeta,\n default as registerGlobalContext,\n} from \"@plasmicapp/host/registerGlobalContext\";\nimport { default as registerToken } from \"@plasmicapp/host/registerToken\";\nimport React from \"react\";\n\nexport type Registerable = {\n registerComponent: typeof registerComponent;\n registerGlobalContext: typeof registerGlobalContext;\n registerToken: typeof registerToken;\n};\n\nexport function makeRegisterComponent<T extends React.ComponentType<any>>(\n component: T,\n meta: CodeComponentMeta<React.ComponentProps<T>>\n) {\n return function (loader?: Registerable) {\n registerComponentHelper(loader, component, meta);\n };\n}\n\nexport function makeRegisterGlobalContext<T extends React.ComponentType<any>>(\n component: T,\n meta: GlobalContextMeta<React.ComponentProps<T>>\n) {\n return function (loader?: Registerable) {\n if (loader) {\n loader.registerGlobalContext(component, meta);\n } else {\n registerGlobalContext(component, meta);\n }\n };\n}\n\nexport function registerComponentHelper<T extends React.ComponentType<any>>(\n loader: Registerable | undefined,\n component: T,\n meta: CodeComponentMeta<React.ComponentProps<T>>\n) {\n if (loader) {\n loader.registerComponent(component, meta);\n } else {\n registerComponent(component, meta);\n }\n}\n\ntype ReactElt = {\n children: ReactElt | ReactElt[];\n props: {\n children: ReactElt | ReactElt[];\n [prop: string]: any;\n } | null;\n type: React.ComponentType<any> | null;\n key: string | null;\n} | null;\n\nexport function traverseReactEltTree(\n children: React.ReactNode,\n callback: (elt: ReactElt) => void\n) {\n const rec = (elts: ReactElt | ReactElt[] | null) => {\n (Array.isArray(elts) ? elts : [elts]).forEach((elt) => {\n if (elt) {\n callback(elt);\n if (elt.children) {\n rec(elt.children);\n }\n if (elt.props?.children && elt.props.children !== elt.children) {\n rec(elt.props.children);\n }\n }\n });\n };\n rec(children as any);\n}\n\nexport function asArray<T>(x: T[] | T | undefined | null) {\n if (Array.isArray(x)) {\n return x;\n } else if (x == null) {\n return [];\n } else {\n return [x];\n }\n}\n","import { parse as HTML } from \"node-html-parser\";\n\ninterface Meta {\n title?: string;\n description?: string;\n image?: string;\n url?: string;\n type?: string;\n site_name?: string;\n}\n\nexport interface Metadata {\n title?: string;\n description?: string;\n image?: string;\n siteName?: string;\n hostname?: string;\n}\n\nconst isValidUrl = (url: string) => {\n return /(^http(s?):\\/\\/[^\\s$.?#].[^\\s]*)/i.test(url);\n};\n\nconst getMetadata = async (url: string): Promise<Metadata> => {\n if (!isValidUrl(url)) return {};\n\n const contents = await fetch(`https://corsproxy.io/?${url}`).then((res) =>\n res.text()\n );\n\n const $ = HTML(contents);\n\n const getHostname = () => {\n const { hostname } = new URL(url);\n return hostname;\n };\n\n const getTitle = () => {\n const title = $.querySelector(\"title\");\n return title?.text;\n };\n\n const meta: Meta = {};\n\n const metas = $.querySelectorAll(\"meta\")\n .map((el) => ({\n name: el.getAttribute(\"name\") || el.getAttribute(\"property\"),\n content: el.getAttribute(\"content\"),\n }))\n .filter((item) => item.name && item.content);\n\n [\n \"og:title\",\n \"og:description\",\n \"twitter:description\",\n // in order of priority, og:image is sufficient if present\n \"og:image\",\n \"twitter:image\",\n \"og:url\",\n \"og:site_name\",\n \"og:type\",\n ].forEach((metaName) => {\n const metasItem = metas.find((m) => m.name === metaName);\n if (!metasItem || !metasItem.name) return;\n const key = metasItem.name.split(\":\")[1] as keyof Meta;\n if (!meta[key]) meta[key] = metasItem.content;\n });\n\n [\"title\", \"description\", \"image\"].forEach((metaName) => {\n const metasItem = metas.find((m) => m.name === metaName);\n if (!metasItem || !metasItem.name) return;\n const key = metaName as keyof Meta;\n if (!meta[key]) meta[key] = metasItem.content;\n });\n\n if (!meta.image) {\n // find all images available and choose one!\n $.querySelectorAll(\"img\").every((el) => {\n const src: string | undefined = el.getAttribute(\"src\");\n if (src) {\n meta.image = new URL(src, url).href;\n return false;\n }\n return true;\n });\n }\n\n const metadata: Metadata = {\n hostname: getHostname(),\n title: getTitle(),\n ...meta,\n };\n\n return metadata;\n};\n\nexport default getMetadata;\nexport { isValidUrl };\n","import React, { useCallback, useEffect, useRef, useState } from \"react\";\nimport { Registerable, registerComponentHelper } from \"./lib/utils\";\n\nimport { DataProvider, usePlasmicCanvasContext } from \"@plasmicapp/host\";\nimport getMetadata, { isValidUrl, Metadata } from \"./lib/html-metadata-parser\";\n\nexport type LinkPreviewProps = {\n url: string;\n children: React.ReactNode;\n loadingMessage: React.ReactNode;\n noPreviewMessage: React.ReactNode;\n showLoading: boolean;\n showNoPreview: boolean;\n};\n\nexport const LinkPreview: React.FC<LinkPreviewProps> = ({\n url,\n children,\n loadingMessage,\n noPreviewMessage,\n showLoading,\n showNoPreview,\n}) => {\n const _isMounted = useRef(true);\n const [metadata, setMetadata] = useState<Metadata>({});\n const [isLoading, setIsLoading] = useState(false);\n\n const isEditMode = !!usePlasmicCanvasContext();\n\n const resetMetadata = useCallback(() => {\n setMetadata({\n title: \"\",\n description: \"\",\n image: \"\",\n siteName: \"\",\n hostname: \"\",\n });\n }, []);\n\n useEffect(() => {\n _isMounted.current = true;\n if (!url) return;\n\n setIsLoading(true);\n resetMetadata();\n getMetadata(url)\n .then((res) => {\n if (_isMounted.current) {\n setMetadata(res);\n setIsLoading(false);\n }\n })\n .catch((err) => {\n console.error(err);\n console.error(\"No metadata could be found for the given URL.\");\n if (_isMounted.current) {\n resetMetadata();\n setIsLoading(false);\n }\n });\n return () => {\n _isMounted.current = false;\n };\n }, [resetMetadata, url]);\n\n const showLoadingProp = isEditMode ? showLoading : false;\n const showNoPreviewProp = isEditMode ? showNoPreview : false;\n const hasChildren = (children as any)?.props.children;\n const hasMetadata =\n metadata?.title?.length && !metadata.title.startsWith(\"Origin DNS error\");\n const body = hasChildren ? <>{children}</> : <p>{metadata.title}</p>;\n const hidePreview =\n isLoading || showLoadingProp || showNoPreviewProp || !hasMetadata;\n const hasNoPreview = !isLoading && !hasMetadata;\n\n return (\n <div>\n <DataProvider name=\"metadata\" data={metadata}>\n {/* We want the metadata to always be available to the elements inside children slot. So we use CSS to hide it */}\n <div style={hidePreview ? { display: \"none\" } : {}}>{body}</div>\n {(hasNoPreview || showNoPreviewProp) && noPreviewMessage}\n {(isLoading || showLoadingProp) && loadingMessage}\n </DataProvider>\n </div>\n );\n};\n\nexport const rlpComponentName = \"plasmic-link-preview\";\n\nexport function registerLinkPreview(loader?: Registerable) {\n registerComponentHelper(loader, LinkPreview, {\n name: rlpComponentName,\n providesData: true,\n displayName: \"Link Preview\",\n props: {\n url: {\n type: \"string\",\n displayName: \"URL\",\n defaultValue: \"https://plasmic.app\",\n defaultValueHint: \"https://example.com\",\n validator: (value) => {\n if (isValidUrl(value)) return true;\n return \"Invalid URL\";\n },\n description: \"The URL for which you want to generate the link preview.\",\n },\n children: {\n type: \"slot\",\n hidePlaceholder: true,\n },\n noPreviewMessage: {\n type: \"slot\",\n displayName: \"'No Preview' Message\",\n hidePlaceholder: true,\n defaultValue: [\n {\n type: \"text\",\n value: \"no preview...\",\n },\n ],\n },\n showLoading: {\n type: \"boolean\",\n description:\n \"You can enable this prop to show the loading message, so you can easily customize it. This prop has no effect in the live app.\",\n },\n showNoPreview: {\n type: \"boolean\",\n description:\n \"You can enable this prop to show the 'No Preview' message, so you can easily customize it. This prop has no effect in the live app.\",\n },\n loadingMessage: {\n type: \"slot\",\n displayName: \"Loading Message\",\n hidePlaceholder: true,\n defaultValue: [\n {\n type: \"text\",\n value: \"loading preview...\",\n },\n ],\n },\n },\n importPath: \"@plasmicpkgs/plasmic-link-preview\",\n importName: \"LinkPreview\",\n });\n}\n"],"names":["registerComponentHelper","loader","component","meta","registerComponent","isValidUrl","url","test","getMetadata","_ref","_asyncToGenerator","_regeneratorRuntime","mark","_callee","contents","$","getHostname","getTitle","metas","metadata","wrap","_callee$","_context","prev","next","abrupt","fetch","then","res","text","sent","HTML","_URL","URL","hostname","title","querySelector","querySelectorAll","map","el","name","getAttribute","content","filter","item","forEach","metaName","metasItem","find","m","key","split","image","every","src","href","_extends","stop","_x","apply","arguments","LinkPreview","children","loadingMessage","noPreviewMessage","showLoading","showNoPreview","_isMounted","useRef","_useState","useState","setMetadata","_useState2","isLoading","setIsLoading","isEditMode","usePlasmicCanvasContext","resetMetadata","useCallback","description","siteName","useEffect","current","err","console","error","showLoadingProp","showNoPreviewProp","hasChildren","props","hasMetadata","_metadata$title","length","startsWith","body","React","hidePreview","hasNoPreview","DataProvider","data","style","display","rlpComponentName","registerLinkPreview","providesData","displayName","type","defaultValue","defaultValueHint","validator","value","hidePlaceholder","importPath","importName"],"mappings":";;;;;;;;;;;;;SAuCgBA,uBAAuBA,CACrCC,MAAgC,EAChCC,SAAY,EACZC,IAAgD;EAEhD,IAAIF,MAAM,EAAE;IACVA,MAAM,CAACG,iBAAiB,CAACF,SAAS,EAAEC,IAAI,CAAC;GAC1C,MAAM;IACLC,iBAAiB,CAACF,SAAS,EAAEC,IAAI,CAAC;;AAEtC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AC9BA,IAAME,UAAU,GAAG,SAAbA,UAAUA,CAAIC,GAAW;EAC7B,OAAO,mCAAmC,CAACC,IAAI,CAACD,GAAG,CAAC;AACtD,CAAC;AAED,IAAME,WAAW;EAAA,IAAAC,IAAA,gBAAAC,iBAAA,cAAAC,mBAAA,GAAAC,IAAA,CAAG,SAAAC,QAAOP,GAAW;IAAA,IAAAQ,QAAA,EAAAC,CAAA,EAAAC,WAAA,EAAAC,QAAA,EAAAd,IAAA,EAAAe,KAAA,EAAAC,QAAA;IAAA,OAAAR,mBAAA,GAAAS,IAAA,UAAAC,SAAAC,QAAA;MAAA,kBAAAA,QAAA,CAAAC,IAAA,GAAAD,QAAA,CAAAE,IAAA;QAAA;UAAA,IAC/BnB,UAAU,CAACC,GAAG,CAAC;YAAAgB,QAAA,CAAAE,IAAA;YAAA;;UAAA,OAAAF,QAAA,CAAAG,MAAA,WAAS,EAAE;QAAA;UAAAH,QAAA,CAAAE,IAAA;UAAA,OAERE,KAAK,4BAA0BpB,GAAK,CAAC,CAACqB,IAAI,CAAC,UAACC,GAAG;YAAA,OACpEA,GAAG,CAACC,IAAI,EAAE;YACX;QAAA;UAFKf,QAAQ,GAAAQ,QAAA,CAAAQ,IAAA;UAIRf,CAAC,GAAGgB,oBAAI,CAACjB,QAAQ,CAAC;UAElBE,WAAW,GAAG,SAAdA,WAAWA;YACf,IAAAgB,IAAA,GAAqB,IAAIC,GAAG,CAAC3B,GAAG,CAAC;cAAzB4B,QAAQ,GAAAF,IAAA,CAARE,QAAQ;YAChB,OAAOA,QAAQ;WAChB;UAEKjB,QAAQ,GAAG,SAAXA,QAAQA;YACZ,IAAMkB,KAAK,GAAGpB,CAAC,CAACqB,aAAa,CAAC,OAAO,CAAC;YACtC,OAAOD,KAAK,oBAALA,KAAK,CAAEN,IAAI;WACnB;UAEK1B,IAAI,GAAS,EAAE;UAEfe,KAAK,GAAGH,CAAC,CAACsB,gBAAgB,CAAC,MAAM,CAAC,CACrCC,GAAG,CAAC,UAACC,EAAE;YAAA,OAAM;cACZC,IAAI,EAAED,EAAE,CAACE,YAAY,CAAC,MAAM,CAAC,IAAIF,EAAE,CAACE,YAAY,CAAC,UAAU,CAAC;cAC5DC,OAAO,EAAEH,EAAE,CAACE,YAAY,CAAC,SAAS;aACnC;WAAC,CAAC,CACFE,MAAM,CAAC,UAACC,IAAI;YAAA,OAAKA,IAAI,CAACJ,IAAI,IAAII,IAAI,CAACF,OAAO;YAAC;UAE9C,CACE,UAAU,EACV,gBAAgB,EAChB,qBAAqB;;UAErB,UAAU,EACV,eAAe,EACf,QAAQ,EACR,cAAc,EACd,SAAS,CACV,CAACG,OAAO,CAAC,UAACC,QAAQ;YACjB,IAAMC,SAAS,GAAG7B,KAAK,CAAC8B,IAAI,CAAC,UAACC,CAAC;cAAA,OAAKA,CAAC,CAACT,IAAI,KAAKM,QAAQ;cAAC;YACxD,IAAI,CAACC,SAAS,IAAI,CAACA,SAAS,CAACP,IAAI,EAAE;YACnC,IAAMU,GAAG,GAAGH,SAAS,CAACP,IAAI,CAACW,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAe;YACtD,IAAI,CAAChD,IAAI,CAAC+C,GAAG,CAAC,EAAE/C,IAAI,CAAC+C,GAAG,CAAC,GAAGH,SAAS,CAACL,OAAO;WAC9C,CAAC;UAEF,CAAC,OAAO,EAAE,aAAa,EAAE,OAAO,CAAC,CAACG,OAAO,CAAC,UAACC,QAAQ;YACjD,IAAMC,SAAS,GAAG7B,KAAK,CAAC8B,IAAI,CAAC,UAACC,CAAC;cAAA,OAAKA,CAAC,CAACT,IAAI,KAAKM,QAAQ;cAAC;YACxD,IAAI,CAACC,SAAS,IAAI,CAACA,SAAS,CAACP,IAAI,EAAE;YACnC,IAAMU,GAAG,GAAGJ,QAAsB;YAClC,IAAI,CAAC3C,IAAI,CAAC+C,GAAG,CAAC,EAAE/C,IAAI,CAAC+C,GAAG,CAAC,GAAGH,SAAS,CAACL,OAAO;WAC9C,CAAC;UAEF,IAAI,CAACvC,IAAI,CAACiD,KAAK,EAAE;;YAEfrC,CAAC,CAACsB,gBAAgB,CAAC,KAAK,CAAC,CAACgB,KAAK,CAAC,UAACd,EAAE;cACjC,IAAMe,GAAG,GAAuBf,EAAE,CAACE,YAAY,CAAC,KAAK,CAAC;cACtD,IAAIa,GAAG,EAAE;gBACPnD,IAAI,CAACiD,KAAK,GAAG,IAAInB,GAAG,CAACqB,GAAG,EAAEhD,GAAG,CAAC,CAACiD,IAAI;gBACnC,OAAO,KAAK;;cAEd,OAAO,IAAI;aACZ,CAAC;;UAGEpC,QAAQ,GAAAqC,QAAA;YACZtB,QAAQ,EAAElB,WAAW,EAAE;YACvBmB,KAAK,EAAElB,QAAQ;aACZd,IAAI;UAAA,OAAAmB,QAAA,CAAAG,MAAA,WAGFN,QAAQ;QAAA;QAAA;UAAA,OAAAG,QAAA,CAAAmC,IAAA;;OAAA5C,OAAA;GAChB;EAAA,gBAvEKL,WAAWA,CAAAkD,EAAA;IAAA,OAAAjD,IAAA,CAAAkD,KAAA,OAAAC,SAAA;;AAAA,GAuEhB;;IC/EYC,WAAW,GAA+B,SAA1CA,WAAWA,CAAApD,IAAA;;MACtBH,GAAG,GAAAG,IAAA,CAAHH,GAAG;IACHwD,QAAQ,GAAArD,IAAA,CAARqD,QAAQ;IACRC,cAAc,GAAAtD,IAAA,CAAdsD,cAAc;IACdC,gBAAgB,GAAAvD,IAAA,CAAhBuD,gBAAgB;IAChBC,WAAW,GAAAxD,IAAA,CAAXwD,WAAW;IACXC,aAAa,GAAAzD,IAAA,CAAbyD,aAAa;EAEb,IAAMC,UAAU,GAAGC,YAAM,CAAC,IAAI,CAAC;EAC/B,IAAAC,SAAA,GAAgCC,cAAQ,CAAW,EAAE,CAAC;IAA/CnD,QAAQ,GAAAkD,SAAA;IAAEE,WAAW,GAAAF,SAAA;EAC5B,IAAAG,UAAA,GAAkCF,cAAQ,CAAC,KAAK,CAAC;IAA1CG,SAAS,GAAAD,UAAA;IAAEE,YAAY,GAAAF,UAAA;EAE9B,IAAMG,UAAU,GAAG,CAAC,CAACC,4BAAuB,EAAE;EAE9C,IAAMC,aAAa,GAAGC,iBAAW,CAAC;IAChCP,WAAW,CAAC;MACVpC,KAAK,EAAE,EAAE;MACT4C,WAAW,EAAE,EAAE;MACf3B,KAAK,EAAE,EAAE;MACT4B,QAAQ,EAAE,EAAE;MACZ9C,QAAQ,EAAE;KACX,CAAC;GACH,EAAE,EAAE,CAAC;EAEN+C,eAAS,CAAC;IACRd,UAAU,CAACe,OAAO,GAAG,IAAI;IACzB,IAAI,CAAC5E,GAAG,EAAE;IAEVoE,YAAY,CAAC,IAAI,CAAC;IAClBG,aAAa,EAAE;IACfrE,WAAW,CAACF,GAAG,CAAC,CACbqB,IAAI,CAAC,UAACC,GAAG;MACR,IAAIuC,UAAU,CAACe,OAAO,EAAE;QACtBX,WAAW,CAAC3C,GAAG,CAAC;QAChB8C,YAAY,CAAC,KAAK,CAAC;;KAEtB,CAAC,SACI,CAAC,UAACS,GAAG;MACTC,OAAO,CAACC,KAAK,CAACF,GAAG,CAAC;MAClBC,OAAO,CAACC,KAAK,CAAC,+CAA+C,CAAC;MAC9D,IAAIlB,UAAU,CAACe,OAAO,EAAE;QACtBL,aAAa,EAAE;QACfH,YAAY,CAAC,KAAK,CAAC;;KAEtB,CAAC;IACJ,OAAO;MACLP,UAAU,CAACe,OAAO,GAAG,KAAK;KAC3B;GACF,EAAE,CAACL,aAAa,EAAEvE,GAAG,CAAC,CAAC;EAExB,IAAMgF,eAAe,GAAGX,UAAU,GAAGV,WAAW,GAAG,KAAK;EACxD,IAAMsB,iBAAiB,GAAGZ,UAAU,GAAGT,aAAa,GAAG,KAAK;EAC5D,IAAMsB,WAAW,GAAI1B,QAAgB,oBAAhBA,QAAgB,CAAE2B,KAAK,CAAC3B,QAAQ;EACrD,IAAM4B,WAAW,GACf,CAAAvE,QAAQ,aAAAwE,eAAA,GAARxE,QAAQ,CAAEgB,KAAK,qBAAfwD,eAAA,CAAiBC,MAAM,KAAI,CAACzE,QAAQ,CAACgB,KAAK,CAAC0D,UAAU,CAAC,kBAAkB,CAAC;EAC3E,IAAMC,IAAI,GAAGN,WAAW,GAAGO,4DAAGjC,QAAQ,CAAI,GAAGiC,wCAAI5E,QAAQ,CAACgB,KAAK,CAAK;EACpE,IAAM6D,WAAW,GACfvB,SAAS,IAAIa,eAAe,IAAIC,iBAAiB,IAAI,CAACG,WAAW;EACnE,IAAMO,YAAY,GAAG,CAACxB,SAAS,IAAI,CAACiB,WAAW;EAE/C,OACEK,0CACEA,6BAACG,iBAAY;IAAC1D,IAAI,EAAC,UAAU;IAAC2D,IAAI,EAAEhF;KAElC4E;IAAKK,KAAK,EAAEJ,WAAW,GAAG;MAAEK,OAAO,EAAE;KAAQ,GAAG;KAAKP,IAAI,CAAO,EAC/D,CAACG,YAAY,IAAIV,iBAAiB,KAAKvB,gBAAgB,EACvD,CAACS,SAAS,IAAIa,eAAe,KAAKvB,cAAc,CACpC,CACX;AAEV,CAAC;AAED,IAAauC,gBAAgB,GAAG,sBAAsB;AAEtD,SAAgBC,mBAAmBA,CAACtG,MAAqB;EACvDD,uBAAuB,CAACC,MAAM,EAAE4D,WAAW,EAAE;IAC3CrB,IAAI,EAAE8D,gBAAgB;IACtBE,YAAY,EAAE,IAAI;IAClBC,WAAW,EAAE,cAAc;IAC3BhB,KAAK,EAAE;MACLnF,GAAG,EAAE;QACHoG,IAAI,EAAE,QAAQ;QACdD,WAAW,EAAE,KAAK;QAClBE,YAAY,EAAE,qBAAqB;QACnCC,gBAAgB,EAAE,qBAAqB;QACvCC,SAAS,EAAE,SAAAA,UAACC,KAAK;UACf,IAAIzG,UAAU,CAACyG,KAAK,CAAC,EAAE,OAAO,IAAI;UAClC,OAAO,aAAa;SACrB;QACD/B,WAAW,EAAE;OACd;MACDjB,QAAQ,EAAE;QACR4C,IAAI,EAAE,MAAM;QACZK,eAAe,EAAE;OAClB;MACD/C,gBAAgB,EAAE;QAChB0C,IAAI,EAAE,MAAM;QACZD,WAAW,EAAE,sBAAsB;QACnCM,eAAe,EAAE,IAAI;QACrBJ,YAAY,EAAE,CACZ;UACED,IAAI,EAAE,MAAM;UACZI,KAAK,EAAE;SACR;OAEJ;MACD7C,WAAW,EAAE;QACXyC,IAAI,EAAE,SAAS;QACf3B,WAAW,EACT;OACH;MACDb,aAAa,EAAE;QACbwC,IAAI,EAAE,SAAS;QACf3B,WAAW,EACT;OACH;MACDhB,cAAc,EAAE;QACd2C,IAAI,EAAE,MAAM;QACZD,WAAW,EAAE,iBAAiB;QAC9BM,eAAe,EAAE,IAAI;QACrBJ,YAAY,EAAE,CACZ;UACED,IAAI,EAAE,MAAM;UACZI,KAAK,EAAE;SACR;;KAGN;IACDE,UAAU,EAAE,mCAAmC;IAC/CC,UAAU,EAAE;GACb,CAAC;AACJ;;;;;;"}
|
|
1
|
+
{"version":3,"file":"plasmic-link-preview.cjs.development.js","sources":["../src/lib/utils.ts","../src/lib/html-metadata-parser.ts","../src/index.tsx"],"sourcesContent":["import {\n CodeComponentMeta,\n default as registerComponent,\n} from \"@plasmicapp/host/registerComponent\";\nimport {\n GlobalContextMeta,\n default as registerGlobalContext,\n} from \"@plasmicapp/host/registerGlobalContext\";\nimport { default as registerToken } from \"@plasmicapp/host/registerToken\";\nimport React from \"react\";\n\nexport type Registerable = {\n registerComponent: typeof registerComponent;\n registerGlobalContext: typeof registerGlobalContext;\n registerToken: typeof registerToken;\n};\n\nexport function makeRegisterComponent<T extends React.ComponentType<any>>(\n component: T,\n meta: CodeComponentMeta<React.ComponentProps<T>>\n) {\n return function (loader?: Registerable) {\n registerComponentHelper(loader, component, meta);\n };\n}\n\nexport function makeRegisterGlobalContext<T extends React.ComponentType<any>>(\n component: T,\n meta: GlobalContextMeta<React.ComponentProps<T>>\n) {\n return function (loader?: Registerable) {\n if (loader) {\n loader.registerGlobalContext(component, meta);\n } else {\n registerGlobalContext(component, meta);\n }\n };\n}\n\nexport function registerComponentHelper<T extends React.ComponentType<any>>(\n loader: Registerable | undefined,\n component: T,\n meta: CodeComponentMeta<React.ComponentProps<T>>\n) {\n if (loader) {\n loader.registerComponent(component, meta);\n } else {\n registerComponent(component, meta);\n }\n}\n\ntype ReactElt = {\n children: ReactElt | ReactElt[];\n props: {\n children: ReactElt | ReactElt[];\n [prop: string]: any;\n } | null;\n type: React.ComponentType<any> | null;\n key: string | null;\n} | null;\n\nexport function traverseReactEltTree(\n children: React.ReactNode,\n callback: (elt: ReactElt) => void\n) {\n const rec = (elts: ReactElt | ReactElt[] | null) => {\n (Array.isArray(elts) ? elts : [elts]).forEach((elt) => {\n if (elt) {\n callback(elt);\n if (elt.children) {\n rec(elt.children);\n }\n if (elt.props?.children && elt.props.children !== elt.children) {\n rec(elt.props.children);\n }\n }\n });\n };\n rec(children as any);\n}\n\nexport function asArray<T>(x: T[] | T | undefined | null) {\n if (Array.isArray(x)) {\n return x;\n } else if (x == null) {\n return [];\n } else {\n return [x];\n }\n}\n","import { parse as HTML } from \"node-html-parser\";\n\ninterface Meta {\n title?: string;\n description?: string;\n image?: string;\n url?: string;\n type?: string;\n site_name?: string;\n}\n\nexport interface Metadata {\n title?: string;\n description?: string;\n image?: string;\n siteName?: string;\n hostname?: string;\n}\n\nconst isValidUrl = (url: string) => {\n return /(^http(s?):\\/\\/[^\\s$.?#].[^\\s]*)/i.test(url);\n};\n\nconst getMetadata = async (url: string): Promise<Metadata> => {\n if (!isValidUrl(url)) return {};\n\n const contents = await fetch(`https://corsproxy.io/?${url}`).then((res) =>\n res.text()\n );\n\n const $ = HTML(contents);\n\n const getHostname = () => {\n const { hostname } = new URL(url);\n return hostname;\n };\n\n const getTitle = () => {\n const title = $.querySelector(\"title\");\n return title?.text;\n };\n\n const meta: Meta = {};\n\n const metas = $.querySelectorAll(\"meta\")\n .map((el) => ({\n name: el.getAttribute(\"name\") || el.getAttribute(\"property\"),\n content: el.getAttribute(\"content\"),\n }))\n .filter((item) => item.name && item.content);\n\n [\n \"og:title\",\n \"og:description\",\n \"twitter:description\",\n // in order of priority, og:image is sufficient if present\n \"og:image\",\n \"twitter:image\",\n \"og:url\",\n \"og:site_name\",\n \"og:type\",\n ].forEach((metaName) => {\n const metasItem = metas.find((m) => m.name === metaName);\n if (!metasItem || !metasItem.name) return;\n const key = metasItem.name.split(\":\")[1] as keyof Meta;\n if (!meta[key]) meta[key] = metasItem.content;\n });\n\n [\"title\", \"description\", \"image\"].forEach((metaName) => {\n const metasItem = metas.find((m) => m.name === metaName);\n if (!metasItem || !metasItem.name) return;\n const key = metaName as keyof Meta;\n if (!meta[key]) meta[key] = metasItem.content;\n });\n\n if (!meta.image) {\n // find all images available and choose one!\n $.querySelectorAll(\"img\").every((el) => {\n const src: string | undefined = el.getAttribute(\"src\");\n if (src) {\n meta.image = new URL(src, url).href;\n return false;\n }\n return true;\n });\n }\n\n const metadata: Metadata = {\n hostname: getHostname(),\n title: getTitle(),\n ...meta,\n };\n\n return metadata;\n};\n\nexport default getMetadata;\nexport { isValidUrl };\n","import React, { useCallback, useEffect, useRef, useState } from \"react\";\nimport { Registerable, registerComponentHelper } from \"./lib/utils\";\n\nimport { DataProvider, usePlasmicCanvasContext } from \"@plasmicapp/host\";\nimport getMetadata, { isValidUrl, Metadata } from \"./lib/html-metadata-parser\";\n\nexport type LinkPreviewProps = {\n url: string;\n children: React.ReactNode;\n loadingMessage: React.ReactNode;\n noPreviewMessage: React.ReactNode;\n showLoading: boolean;\n showNoPreview: boolean;\n};\n\nexport const LinkPreview: React.FC<LinkPreviewProps> = ({\n url,\n children,\n loadingMessage,\n noPreviewMessage,\n showLoading,\n showNoPreview,\n}) => {\n const _isMounted = useRef(true);\n const [metadata, setMetadata] = useState<Metadata>({});\n const [isLoading, setIsLoading] = useState(false);\n\n const isEditMode = !!usePlasmicCanvasContext();\n\n const resetMetadata = useCallback(() => {\n setMetadata({\n title: \"\",\n description: \"\",\n image: \"\",\n siteName: \"\",\n hostname: \"\",\n });\n }, []);\n\n useEffect(() => {\n _isMounted.current = true;\n if (!url) return;\n\n setIsLoading(true);\n resetMetadata();\n getMetadata(url)\n .then((res) => {\n if (_isMounted.current) {\n setMetadata(res);\n setIsLoading(false);\n }\n })\n .catch((err) => {\n console.error(err);\n console.error(\"No metadata could be found for the given URL.\");\n if (_isMounted.current) {\n resetMetadata();\n setIsLoading(false);\n }\n });\n return () => {\n _isMounted.current = false;\n };\n }, [resetMetadata, url]);\n\n const showLoadingProp = isEditMode ? showLoading : false;\n const showNoPreviewProp = isEditMode ? showNoPreview : false;\n const hasChildren = (children as any)?.props.children;\n const hasMetadata =\n metadata?.title?.length && !metadata.title.startsWith(\"Origin DNS error\");\n const body = hasChildren ? <>{children}</> : <p>{metadata.title}</p>;\n const hidePreview =\n isLoading || showLoadingProp || showNoPreviewProp || !hasMetadata;\n const hasNoPreview = !isLoading && !hasMetadata;\n\n return (\n <div>\n <DataProvider name=\"metadata\" data={metadata}>\n {/* We want the metadata to always be available to the elements inside children slot. So we use CSS to hide it */}\n <div style={hidePreview ? { display: \"none\" } : {}}>{body}</div>\n {(hasNoPreview || showNoPreviewProp) && noPreviewMessage}\n {(isLoading || showLoadingProp) && loadingMessage}\n </DataProvider>\n </div>\n );\n};\n\nexport const rlpComponentName = \"plasmic-link-preview\";\n\nexport function registerLinkPreview(loader?: Registerable) {\n registerComponentHelper(loader, LinkPreview, {\n name: rlpComponentName,\n providesData: true,\n displayName: \"Link Preview\",\n props: {\n url: {\n type: \"string\",\n displayName: \"URL\",\n defaultValue: \"https://plasmic.app\",\n defaultValueHint: \"https://example.com\",\n validator: (value) => {\n if (isValidUrl(value)) return true;\n return \"Invalid URL\";\n },\n description: \"The URL for which you want to generate the link preview.\",\n },\n children: {\n type: \"slot\",\n hidePlaceholder: true,\n },\n noPreviewMessage: {\n type: \"slot\",\n displayName: \"'No Preview' Message\",\n hidePlaceholder: true,\n defaultValue: [\n {\n type: \"text\",\n value: \"no preview...\",\n },\n ],\n },\n showLoading: {\n type: \"boolean\",\n description:\n \"You can enable this prop to show the loading message, so you can easily customize it. This prop has no effect in the live app.\",\n },\n showNoPreview: {\n type: \"boolean\",\n description:\n \"You can enable this prop to show the 'No Preview' message, so you can easily customize it. This prop has no effect in the live app.\",\n },\n loadingMessage: {\n type: \"slot\",\n displayName: \"Loading Message\",\n hidePlaceholder: true,\n defaultValue: [\n {\n type: \"text\",\n value: \"loading preview...\",\n },\n ],\n },\n },\n importPath: \"@plasmicpkgs/plasmic-link-preview\",\n importName: \"LinkPreview\",\n });\n}\n"],"names":["registerComponentHelper","loader","component","meta","registerComponent","isValidUrl","url","test","getMetadata","_ref","_asyncToGenerator","_regenerator","m","_callee","contents","$","getHostname","getTitle","metas","metadata","w","_context","n","a","fetch","then","res","text","v","HTML","_URL","URL","hostname","title","querySelector","querySelectorAll","map","el","name","getAttribute","content","filter","item","forEach","metaName","metasItem","find","key","split","image","every","src","href","_extends","_x","apply","arguments","LinkPreview","children","loadingMessage","noPreviewMessage","showLoading","showNoPreview","_isMounted","useRef","_useState","useState","setMetadata","_useState2","isLoading","setIsLoading","isEditMode","usePlasmicCanvasContext","resetMetadata","useCallback","description","siteName","useEffect","current","err","console","error","showLoadingProp","showNoPreviewProp","hasChildren","props","hasMetadata","_metadata$title","length","startsWith","body","React","hidePreview","hasNoPreview","DataProvider","data","style","display","rlpComponentName","registerLinkPreview","providesData","displayName","type","defaultValue","defaultValueHint","validator","value","hidePlaceholder","importPath","importName"],"mappings":"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"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";function t(t){return t&&"object"==typeof t&&"default"in t?t.default:t}Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react"),r=t(e),n=t(require("@plasmicapp/host/registerComponent"));require("@plasmicapp/host/registerGlobalContext");var o=require("@plasmicapp/host"),i=require("node-html-parser");function a(t,e,r,n,o,i,a){try{var c=t[i](a),u=c.value}catch(t){return void r(t)}c.done?e(u):Promise.resolve(u).then(n,o)}function c(t){return function(){var e=this,r=arguments;return new Promise((function(n,o){var i=t.apply(e,r);function c(t){a(i,n,o,c,u,"next",t)}function u(t){a(i,n,o,c,u,"throw",t)}c(void 0)}))}}function u(){return(u=Object.assign?Object.assign.bind():function(t){for(var e=1;e<arguments.length;e++){var r=arguments[e];for(var n in r)({}).hasOwnProperty.call(r,n)&&(t[n]=r[n])}return t}).apply(null,arguments)}function l(){l=function(){return e};var t,e={},r=Object.prototype,n=r.hasOwnProperty,o=Object.defineProperty||function(t,e,r){t[e]=r.value},i="function"==typeof Symbol?Symbol:{},a=i.iterator||"@@iterator",c=i.asyncIterator||"@@asyncIterator",u=i.toStringTag||"@@toStringTag";function s(t,e,r){return Object.defineProperty(t,e,{value:r,enumerable:!0,configurable:!0,writable:!0}),t[e]}try{s({},"")}catch(t){s=function(t,e,r){return t[e]=r}}function f(t,e,r,n){var i=Object.create((e&&e.prototype instanceof m?e:m).prototype),a=new S(n||[]);return o(i,"_invoke",{value:k(t,r,a)}),i}function h(t,e,r){try{return{type:"normal",arg:t.call(e,r)}}catch(t){return{type:"throw",arg:t}}}e.wrap=f;var p="suspendedStart",v="executing",d="completed",y={};function m(){}function g(){}function w(){}var b={};s(b,a,(function(){return this}));var L=Object.getPrototypeOf,x=L&&L(L(G([])));x&&x!==r&&n.call(x,a)&&(b=x);var E=w.prototype=m.prototype=Object.create(b);function P(t){["next","throw","return"].forEach((function(e){s(t,e,(function(t){return this._invoke(e,t)}))}))}function N(t,e){function r(o,i,a,c){var u=h(t[o],t,i);if("throw"!==u.type){var l=u.arg,s=l.value;return s&&"object"==typeof s&&n.call(s,"__await")?e.resolve(s.__await).then((function(t){r("next",t,a,c)}),(function(t){r("throw",t,a,c)})):e.resolve(s).then((function(t){l.value=t,a(l)}),(function(t){return r("throw",t,a,c)}))}c(u.arg)}var i;o(this,"_invoke",{value:function(t,n){function o(){return new e((function(e,o){r(t,n,e,o)}))}return i=i?i.then(o,o):o()}})}function k(e,r,n){var o=p;return function(i,a){if(o===v)throw Error("Generator is already running");if(o===d){if("throw"===i)throw a;return{value:t,done:!0}}for(n.method=i,n.arg=a;;){var c=n.delegate;if(c){var u=O(c,n);if(u){if(u===y)continue;return u}}if("next"===n.method)n.sent=n._sent=n.arg;else if("throw"===n.method){if(o===p)throw o=d,n.arg;n.dispatchException(n.arg)}else"return"===n.method&&n.abrupt("return",n.arg);o=v;var l=h(e,r,n);if("normal"===l.type){if(o=n.done?d:"suspendedYield",l.arg===y)continue;return{value:l.arg,done:n.done}}"throw"===l.type&&(o=d,n.method="throw",n.arg=l.arg)}}}function O(e,r){var n=r.method,o=e.iterator[n];if(o===t)return r.delegate=null,"throw"===n&&e.iterator.return&&(r.method="return",r.arg=t,O(e,r),"throw"===r.method)||"return"!==n&&(r.method="throw",r.arg=new TypeError("The iterator does not provide a '"+n+"' method")),y;var i=h(o,e.iterator,r.arg);if("throw"===i.type)return r.method="throw",r.arg=i.arg,r.delegate=null,y;var a=i.arg;return a?a.done?(r[e.resultName]=a.value,r.next=e.nextLoc,"return"!==r.method&&(r.method="next",r.arg=t),r.delegate=null,y):a:(r.method="throw",r.arg=new TypeError("iterator result is not an object"),r.delegate=null,y)}function _(t){var e={tryLoc:t[0]};1 in t&&(e.catchLoc=t[1]),2 in t&&(e.finallyLoc=t[2],e.afterLoc=t[3]),this.tryEntries.push(e)}function j(t){var e=t.completion||{};e.type="normal",delete e.arg,t.completion=e}function S(t){this.tryEntries=[{tryLoc:"root"}],t.forEach(_,this),this.reset(!0)}function G(e){if(e||""===e){var r=e[a];if(r)return r.call(e);if("function"==typeof e.next)return e;if(!isNaN(e.length)){var o=-1,i=function r(){for(;++o<e.length;)if(n.call(e,o))return r.value=e[o],r.done=!1,r;return r.value=t,r.done=!0,r};return i.next=i}}throw new TypeError(typeof e+" is not iterable")}return g.prototype=w,o(E,"constructor",{value:w,configurable:!0}),o(w,"constructor",{value:g,configurable:!0}),g.displayName=s(w,u,"GeneratorFunction"),e.isGeneratorFunction=function(t){var e="function"==typeof t&&t.constructor;return!!e&&(e===g||"GeneratorFunction"===(e.displayName||e.name))},e.mark=function(t){return Object.setPrototypeOf?Object.setPrototypeOf(t,w):(t.__proto__=w,s(t,u,"GeneratorFunction")),t.prototype=Object.create(E),t},e.awrap=function(t){return{__await:t}},P(N.prototype),s(N.prototype,c,(function(){return this})),e.AsyncIterator=N,e.async=function(t,r,n,o,i){void 0===i&&(i=Promise);var a=new N(f(t,r,n,o),i);return e.isGeneratorFunction(r)?a:a.next().then((function(t){return t.done?t.value:a.next()}))},P(E),s(E,u,"Generator"),s(E,a,(function(){return this})),s(E,"toString",(function(){return"[object Generator]"})),e.keys=function(t){var e=Object(t),r=[];for(var n in e)r.push(n);return r.reverse(),function t(){for(;r.length;){var n=r.pop();if(n in e)return t.value=n,t.done=!1,t}return t.done=!0,t}},e.values=G,S.prototype={constructor:S,reset:function(e){if(this.prev=0,this.next=0,this.sent=this._sent=t,this.done=!1,this.delegate=null,this.method="next",this.arg=t,this.tryEntries.forEach(j),!e)for(var r in this)"t"===r.charAt(0)&&n.call(this,r)&&!isNaN(+r.slice(1))&&(this[r]=t)},stop:function(){this.done=!0;var t=this.tryEntries[0].completion;if("throw"===t.type)throw t.arg;return this.rval},dispatchException:function(e){if(this.done)throw e;var r=this;function o(n,o){return c.type="throw",c.arg=e,r.next=n,o&&(r.method="next",r.arg=t),!!o}for(var i=this.tryEntries.length-1;i>=0;--i){var a=this.tryEntries[i],c=a.completion;if("root"===a.tryLoc)return o("end");if(a.tryLoc<=this.prev){var u=n.call(a,"catchLoc"),l=n.call(a,"finallyLoc");if(u&&l){if(this.prev<a.catchLoc)return o(a.catchLoc,!0);if(this.prev<a.finallyLoc)return o(a.finallyLoc)}else if(u){if(this.prev<a.catchLoc)return o(a.catchLoc,!0)}else{if(!l)throw Error("try statement without catch or finally");if(this.prev<a.finallyLoc)return o(a.finallyLoc)}}}},abrupt:function(t,e){for(var r=this.tryEntries.length-1;r>=0;--r){var o=this.tryEntries[r];if(o.tryLoc<=this.prev&&n.call(o,"finallyLoc")&&this.prev<o.finallyLoc){var i=o;break}}i&&("break"===t||"continue"===t)&&i.tryLoc<=e&&e<=i.finallyLoc&&(i=null);var a=i?i.completion:{};return a.type=t,a.arg=e,i?(this.method="next",this.next=i.finallyLoc,y):this.complete(a)},complete:function(t,e){if("throw"===t.type)throw t.arg;return"break"===t.type||"continue"===t.type?this.next=t.arg:"return"===t.type?(this.rval=this.arg=t.arg,this.method="return",this.next="end"):"normal"===t.type&&e&&(this.next=e),y},finish:function(t){for(var e=this.tryEntries.length-1;e>=0;--e){var r=this.tryEntries[e];if(r.finallyLoc===t)return this.complete(r.completion,r.afterLoc),j(r),y}},catch:function(t){for(var e=this.tryEntries.length-1;e>=0;--e){var r=this.tryEntries[e];if(r.tryLoc===t){var n=r.completion;if("throw"===n.type){var o=n.arg;j(r)}return o}}throw Error("illegal catch attempt")},delegateYield:function(e,r,n){return this.delegate={iterator:G(e),resultName:r,nextLoc:n},"next"===this.method&&(this.arg=t),y}},e}var s=function(t){return/(^http(s?):\/\/[^\s$.?#].[^\s]*)/i.test(t)},f=function(){var t=c(l().mark((function t(e){var r,n,o,a,c,f;return l().wrap((function(t){for(;;)switch(t.prev=t.next){case 0:if(s(e)){t.next=2;break}return t.abrupt("return",{});case 2:return t.next=4,fetch("https://corsproxy.io/?"+e).then((function(t){return t.text()}));case 4:return r=i.parse(t.sent),n=function(){return new URL(e).hostname},o=function(){var t=r.querySelector("title");return null==t?void 0:t.text},a={},c=r.querySelectorAll("meta").map((function(t){return{name:t.getAttribute("name")||t.getAttribute("property"),content:t.getAttribute("content")}})).filter((function(t){return t.name&&t.content})),["og:title","og:description","twitter:description","og:image","twitter:image","og:url","og:site_name","og:type"].forEach((function(t){var e=c.find((function(e){return e.name===t}));if(e&&e.name){var r=e.name.split(":")[1];a[r]||(a[r]=e.content)}})),["title","description","image"].forEach((function(t){var e=c.find((function(e){return e.name===t}));e&&e.name&&(a[t]||(a[t]=e.content))})),a.image||r.querySelectorAll("img").every((function(t){var r=t.getAttribute("src");return!r||(a.image=new URL(r,e).href,!1)})),f=u({hostname:n(),title:o()},a),t.abrupt("return",f);case 15:case"end":return t.stop()}}),t)})));return function(e){return t.apply(this,arguments)}}(),h=function(t){var n,i=t.url,a=t.children,c=t.loadingMessage,u=t.noPreviewMessage,l=t.showLoading,s=t.showNoPreview,h=e.useRef(!0),p=e.useState({}),v=p[0],d=p[1],y=e.useState(!1),m=y[0],g=y[1],w=!!o.usePlasmicCanvasContext(),b=e.useCallback((function(){d({title:"",description:"",image:"",siteName:"",hostname:""})}),[]);e.useEffect((function(){if(h.current=!0,i)return g(!0),b(),f(i).then((function(t){h.current&&(d(t),g(!1))})).catch((function(t){console.error(t),console.error("No metadata could be found for the given URL."),h.current&&(b(),g(!1))})),function(){h.current=!1}}),[b,i]);var L=!!w&&l,x=!!w&&s,E=null==a?void 0:a.props.children,P=(null==v||null==(n=v.title)?void 0:n.length)&&!v.title.startsWith("Origin DNS error"),N=E?r.createElement(r.Fragment,null,a):r.createElement("p",null,v.title),k=!m&&!P;return r.createElement("div",null,r.createElement(o.DataProvider,{name:"metadata",data:v},r.createElement("div",{style:m||L||x||!P?{display:"none"}:{}},N),(k||x)&&u,(m||L)&&c))};exports.LinkPreview=h,exports.registerLinkPreview=function(t){!function(t,e,r){t?t.registerComponent(e,r):n(e,r)}(t,h,{name:"plasmic-link-preview",providesData:!0,displayName:"Link Preview",props:{url:{type:"string",displayName:"URL",defaultValue:"https://plasmic.app",defaultValueHint:"https://example.com",validator:function(t){return!!s(t)||"Invalid URL"},description:"The URL for which you want to generate the link preview."},children:{type:"slot",hidePlaceholder:!0},noPreviewMessage:{type:"slot",displayName:"'No Preview' Message",hidePlaceholder:!0,defaultValue:[{type:"text",value:"no preview..."}]},showLoading:{type:"boolean",description:"You can enable this prop to show the loading message, so you can easily customize it. This prop has no effect in the live app."},showNoPreview:{type:"boolean",description:"You can enable this prop to show the 'No Preview' message, so you can easily customize it. This prop has no effect in the live app."},loadingMessage:{type:"slot",displayName:"Loading Message",hidePlaceholder:!0,defaultValue:[{type:"text",value:"loading preview..."}]}},importPath:"@plasmicpkgs/plasmic-link-preview",importName:"LinkPreview"})},exports.rlpComponentName="plasmic-link-preview";
|
|
1
|
+
"use strict";function e(e){return e&&"object"==typeof e&&"default"in e?e.default:e}Object.defineProperty(exports,"__esModule",{value:!0});var t=require("react"),n=e(t),r=e(require("@plasmicapp/host/registerComponent"));require("@plasmicapp/host/registerGlobalContext");var o=require("@plasmicapp/host"),i=require("node-html-parser");function a(e,t,n,r,o,i,a){try{var u=e[i](a),c=u.value}catch(e){return void n(e)}u.done?t(c):Promise.resolve(c).then(r,o)}function u(e){return function(){var t=this,n=arguments;return new Promise((function(r,o){var i=e.apply(t,n);function u(e){a(i,r,o,u,c,"next",e)}function c(e){a(i,r,o,u,c,"throw",e)}u(void 0)}))}}function c(){return(c=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var r in n)({}).hasOwnProperty.call(n,r)&&(e[r]=n[r])}return e}).apply(null,arguments)}function l(){var e,t,n="function"==typeof Symbol?Symbol:{},r=n.iterator||"@@iterator",o=n.toStringTag||"@@toStringTag";function i(n,r,o,i){var c=Object.create((r&&r.prototype instanceof u?r:u).prototype);return s(c,"_invoke",function(n,r,o){var i,u,c,l=0,s=o||[],p=!1,f={p:0,n:0,v:e,a:v,f:v.bind(e,4),d:function(t,n){return i=t,u=0,c=e,f.n=n,a}};function v(n,r){for(u=n,c=r,t=0;!p&&l&&!o&&t<s.length;t++){var o,i=s[t],v=f.p,h=i[2];n>3?(o=h===r)&&(c=i[(u=i[4])?5:(u=3,3)],i[4]=i[5]=e):i[0]<=v&&((o=n<2&&v<i[1])?(u=0,f.v=r,f.n=i[1]):v<h&&(o=n<3||i[0]>r||r>h)&&(i[4]=n,i[5]=r,f.n=h,u=0))}if(o||n>1)return a;throw p=!0,r}return function(o,s,h){if(l>1)throw TypeError("Generator is already running");for(p&&1===s&&v(s,h),u=s,c=h;(t=u<2?e:c)||!p;){i||(u?u<3?(u>1&&(f.n=-1),v(u,c)):f.n=c:f.v=c);try{if(l=2,i){if(u||(o="next"),t=i[o]){if(!(t=t.call(i,c)))throw TypeError("iterator result is not an object");if(!t.done)return t;c=t.value,u<2&&(u=0)}else 1===u&&(t=i.return)&&t.call(i),u<2&&(c=TypeError("The iterator does not provide a '"+o+"' method"),u=1);i=e}else if((t=(p=f.n<0)?c:n.call(r,f))!==a)break}catch(t){i=e,u=1,c=t}finally{l=1}}return{value:t,done:p}}}(n,o,i),!0),c}var a={};function u(){}function c(){}function p(){}t=Object.getPrototypeOf;var f=[][r]?t(t([][r]())):(s(t={},r,(function(){return this})),t),v=p.prototype=u.prototype=Object.create(f);function h(e){return Object.setPrototypeOf?Object.setPrototypeOf(e,p):(e.__proto__=p,s(e,o,"GeneratorFunction")),e.prototype=Object.create(v),e}return c.prototype=p,s(v,"constructor",p),s(p,"constructor",c),c.displayName="GeneratorFunction",s(p,o,"GeneratorFunction"),s(v),s(v,o,"Generator"),s(v,r,(function(){return this})),s(v,"toString",(function(){return"[object Generator]"})),(l=function(){return{w:i,m:h}})()}function s(e,t,n,r){var o=Object.defineProperty;try{o({},"",{})}catch(e){o=0}(s=function(e,t,n,r){function i(t,n){s(e,t,(function(e){return this._invoke(t,n,e)}))}t?o?o(e,t,{value:n,enumerable:!r,configurable:!r,writable:!r}):e[t]=n:(i("next",0),i("throw",1),i("return",2))})(e,t,n,r)}var p=function(e){return/(^http(s?):\/\/[^\s$.?#].[^\s]*)/i.test(e)},f=function(){var e=u(l().m((function e(t){var n,r,o,a,u,s;return l().w((function(e){for(;;)switch(e.n){case 0:if(p(t)){e.n=1;break}return e.a(2,{});case 1:return e.n=2,fetch("https://corsproxy.io/?"+t).then((function(e){return e.text()}));case 2:return n=i.parse(e.v),r=function(){return new URL(t).hostname},o=function(){var e=n.querySelector("title");return null==e?void 0:e.text},a={},u=n.querySelectorAll("meta").map((function(e){return{name:e.getAttribute("name")||e.getAttribute("property"),content:e.getAttribute("content")}})).filter((function(e){return e.name&&e.content})),["og:title","og:description","twitter:description","og:image","twitter:image","og:url","og:site_name","og:type"].forEach((function(e){var t=u.find((function(t){return t.name===e}));if(t&&t.name){var n=t.name.split(":")[1];a[n]||(a[n]=t.content)}})),["title","description","image"].forEach((function(e){var t=u.find((function(t){return t.name===e}));t&&t.name&&(a[e]||(a[e]=t.content))})),a.image||n.querySelectorAll("img").every((function(e){var n=e.getAttribute("src");return!n||(a.image=new URL(n,t).href,!1)})),s=c({hostname:r(),title:o()},a),e.a(2,s)}}),e)})));return function(t){return e.apply(this,arguments)}}(),v=function(e){var r,i=e.url,a=e.children,u=e.loadingMessage,c=e.noPreviewMessage,l=e.showLoading,s=e.showNoPreview,p=t.useRef(!0),v=t.useState({}),h=v[0],m=v[1],d=t.useState(!1),g=d[0],y=d[1],w=!!o.usePlasmicCanvasContext(),b=t.useCallback((function(){m({title:"",description:"",image:"",siteName:"",hostname:""})}),[]);t.useEffect((function(){if(p.current=!0,i)return y(!0),b(),f(i).then((function(e){p.current&&(m(e),y(!1))})).catch((function(e){console.error(e),console.error("No metadata could be found for the given URL."),p.current&&(b(),y(!1))})),function(){p.current=!1}}),[b,i]);var P=!!w&&l,x=!!w&&s,O=null==a?void 0:a.props.children,k=(null==h||null==(r=h.title)?void 0:r.length)&&!h.title.startsWith("Origin DNS error"),N=O?n.createElement(n.Fragment,null,a):n.createElement("p",null,h.title),j=!g&&!k;return n.createElement("div",null,n.createElement(o.DataProvider,{name:"metadata",data:h},n.createElement("div",{style:g||P||x||!k?{display:"none"}:{}},N),(j||x)&&c,(g||P)&&u))};exports.LinkPreview=v,exports.registerLinkPreview=function(e){!function(e,t,n){e?e.registerComponent(t,n):r(t,n)}(e,v,{name:"plasmic-link-preview",providesData:!0,displayName:"Link Preview",props:{url:{type:"string",displayName:"URL",defaultValue:"https://plasmic.app",defaultValueHint:"https://example.com",validator:function(e){return!!p(e)||"Invalid URL"},description:"The URL for which you want to generate the link preview."},children:{type:"slot",hidePlaceholder:!0},noPreviewMessage:{type:"slot",displayName:"'No Preview' Message",hidePlaceholder:!0,defaultValue:[{type:"text",value:"no preview..."}]},showLoading:{type:"boolean",description:"You can enable this prop to show the loading message, so you can easily customize it. This prop has no effect in the live app."},showNoPreview:{type:"boolean",description:"You can enable this prop to show the 'No Preview' message, so you can easily customize it. This prop has no effect in the live app."},loadingMessage:{type:"slot",displayName:"Loading Message",hidePlaceholder:!0,defaultValue:[{type:"text",value:"loading preview..."}]}},importPath:"@plasmicpkgs/plasmic-link-preview",importName:"LinkPreview"})},exports.rlpComponentName="plasmic-link-preview";
|
|
2
2
|
//# sourceMappingURL=plasmic-link-preview.cjs.production.min.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"plasmic-link-preview.cjs.production.min.js","sources":["../src/lib/html-metadata-parser.ts","../src/index.tsx","../src/lib/utils.ts"],"sourcesContent":["import { parse as HTML } from \"node-html-parser\";\n\ninterface Meta {\n title?: string;\n description?: string;\n image?: string;\n url?: string;\n type?: string;\n site_name?: string;\n}\n\nexport interface Metadata {\n title?: string;\n description?: string;\n image?: string;\n siteName?: string;\n hostname?: string;\n}\n\nconst isValidUrl = (url: string) => {\n return /(^http(s?):\\/\\/[^\\s$.?#].[^\\s]*)/i.test(url);\n};\n\nconst getMetadata = async (url: string): Promise<Metadata> => {\n if (!isValidUrl(url)) return {};\n\n const contents = await fetch(`https://corsproxy.io/?${url}`).then((res) =>\n res.text()\n );\n\n const $ = HTML(contents);\n\n const getHostname = () => {\n const { hostname } = new URL(url);\n return hostname;\n };\n\n const getTitle = () => {\n const title = $.querySelector(\"title\");\n return title?.text;\n };\n\n const meta: Meta = {};\n\n const metas = $.querySelectorAll(\"meta\")\n .map((el) => ({\n name: el.getAttribute(\"name\") || el.getAttribute(\"property\"),\n content: el.getAttribute(\"content\"),\n }))\n .filter((item) => item.name && item.content);\n\n [\n \"og:title\",\n \"og:description\",\n \"twitter:description\",\n // in order of priority, og:image is sufficient if present\n \"og:image\",\n \"twitter:image\",\n \"og:url\",\n \"og:site_name\",\n \"og:type\",\n ].forEach((metaName) => {\n const metasItem = metas.find((m) => m.name === metaName);\n if (!metasItem || !metasItem.name) return;\n const key = metasItem.name.split(\":\")[1] as keyof Meta;\n if (!meta[key]) meta[key] = metasItem.content;\n });\n\n [\"title\", \"description\", \"image\"].forEach((metaName) => {\n const metasItem = metas.find((m) => m.name === metaName);\n if (!metasItem || !metasItem.name) return;\n const key = metaName as keyof Meta;\n if (!meta[key]) meta[key] = metasItem.content;\n });\n\n if (!meta.image) {\n // find all images available and choose one!\n $.querySelectorAll(\"img\").every((el) => {\n const src: string | undefined = el.getAttribute(\"src\");\n if (src) {\n meta.image = new URL(src, url).href;\n return false;\n }\n return true;\n });\n }\n\n const metadata: Metadata = {\n hostname: getHostname(),\n title: getTitle(),\n ...meta,\n };\n\n return metadata;\n};\n\nexport default getMetadata;\nexport { isValidUrl };\n","import React, { useCallback, useEffect, useRef, useState } from \"react\";\nimport { Registerable, registerComponentHelper } from \"./lib/utils\";\n\nimport { DataProvider, usePlasmicCanvasContext } from \"@plasmicapp/host\";\nimport getMetadata, { isValidUrl, Metadata } from \"./lib/html-metadata-parser\";\n\nexport type LinkPreviewProps = {\n url: string;\n children: React.ReactNode;\n loadingMessage: React.ReactNode;\n noPreviewMessage: React.ReactNode;\n showLoading: boolean;\n showNoPreview: boolean;\n};\n\nexport const LinkPreview: React.FC<LinkPreviewProps> = ({\n url,\n children,\n loadingMessage,\n noPreviewMessage,\n showLoading,\n showNoPreview,\n}) => {\n const _isMounted = useRef(true);\n const [metadata, setMetadata] = useState<Metadata>({});\n const [isLoading, setIsLoading] = useState(false);\n\n const isEditMode = !!usePlasmicCanvasContext();\n\n const resetMetadata = useCallback(() => {\n setMetadata({\n title: \"\",\n description: \"\",\n image: \"\",\n siteName: \"\",\n hostname: \"\",\n });\n }, []);\n\n useEffect(() => {\n _isMounted.current = true;\n if (!url) return;\n\n setIsLoading(true);\n resetMetadata();\n getMetadata(url)\n .then((res) => {\n if (_isMounted.current) {\n setMetadata(res);\n setIsLoading(false);\n }\n })\n .catch((err) => {\n console.error(err);\n console.error(\"No metadata could be found for the given URL.\");\n if (_isMounted.current) {\n resetMetadata();\n setIsLoading(false);\n }\n });\n return () => {\n _isMounted.current = false;\n };\n }, [resetMetadata, url]);\n\n const showLoadingProp = isEditMode ? showLoading : false;\n const showNoPreviewProp = isEditMode ? showNoPreview : false;\n const hasChildren = (children as any)?.props.children;\n const hasMetadata =\n metadata?.title?.length && !metadata.title.startsWith(\"Origin DNS error\");\n const body = hasChildren ? <>{children}</> : <p>{metadata.title}</p>;\n const hidePreview =\n isLoading || showLoadingProp || showNoPreviewProp || !hasMetadata;\n const hasNoPreview = !isLoading && !hasMetadata;\n\n return (\n <div>\n <DataProvider name=\"metadata\" data={metadata}>\n {/* We want the metadata to always be available to the elements inside children slot. So we use CSS to hide it */}\n <div style={hidePreview ? { display: \"none\" } : {}}>{body}</div>\n {(hasNoPreview || showNoPreviewProp) && noPreviewMessage}\n {(isLoading || showLoadingProp) && loadingMessage}\n </DataProvider>\n </div>\n );\n};\n\nexport const rlpComponentName = \"plasmic-link-preview\";\n\nexport function registerLinkPreview(loader?: Registerable) {\n registerComponentHelper(loader, LinkPreview, {\n name: rlpComponentName,\n providesData: true,\n displayName: \"Link Preview\",\n props: {\n url: {\n type: \"string\",\n displayName: \"URL\",\n defaultValue: \"https://plasmic.app\",\n defaultValueHint: \"https://example.com\",\n validator: (value) => {\n if (isValidUrl(value)) return true;\n return \"Invalid URL\";\n },\n description: \"The URL for which you want to generate the link preview.\",\n },\n children: {\n type: \"slot\",\n hidePlaceholder: true,\n },\n noPreviewMessage: {\n type: \"slot\",\n displayName: \"'No Preview' Message\",\n hidePlaceholder: true,\n defaultValue: [\n {\n type: \"text\",\n value: \"no preview...\",\n },\n ],\n },\n showLoading: {\n type: \"boolean\",\n description:\n \"You can enable this prop to show the loading message, so you can easily customize it. This prop has no effect in the live app.\",\n },\n showNoPreview: {\n type: \"boolean\",\n description:\n \"You can enable this prop to show the 'No Preview' message, so you can easily customize it. This prop has no effect in the live app.\",\n },\n loadingMessage: {\n type: \"slot\",\n displayName: \"Loading Message\",\n hidePlaceholder: true,\n defaultValue: [\n {\n type: \"text\",\n value: \"loading preview...\",\n },\n ],\n },\n },\n importPath: \"@plasmicpkgs/plasmic-link-preview\",\n importName: \"LinkPreview\",\n });\n}\n","import {\n CodeComponentMeta,\n default as registerComponent,\n} from \"@plasmicapp/host/registerComponent\";\nimport {\n GlobalContextMeta,\n default as registerGlobalContext,\n} from \"@plasmicapp/host/registerGlobalContext\";\nimport { default as registerToken } from \"@plasmicapp/host/registerToken\";\nimport React from \"react\";\n\nexport type Registerable = {\n registerComponent: typeof registerComponent;\n registerGlobalContext: typeof registerGlobalContext;\n registerToken: typeof registerToken;\n};\n\nexport function makeRegisterComponent<T extends React.ComponentType<any>>(\n component: T,\n meta: CodeComponentMeta<React.ComponentProps<T>>\n) {\n return function (loader?: Registerable) {\n registerComponentHelper(loader, component, meta);\n };\n}\n\nexport function makeRegisterGlobalContext<T extends React.ComponentType<any>>(\n component: T,\n meta: GlobalContextMeta<React.ComponentProps<T>>\n) {\n return function (loader?: Registerable) {\n if (loader) {\n loader.registerGlobalContext(component, meta);\n } else {\n registerGlobalContext(component, meta);\n }\n };\n}\n\nexport function registerComponentHelper<T extends React.ComponentType<any>>(\n loader: Registerable | undefined,\n component: T,\n meta: CodeComponentMeta<React.ComponentProps<T>>\n) {\n if (loader) {\n loader.registerComponent(component, meta);\n } else {\n registerComponent(component, meta);\n }\n}\n\ntype ReactElt = {\n children: ReactElt | ReactElt[];\n props: {\n children: ReactElt | ReactElt[];\n [prop: string]: any;\n } | null;\n type: React.ComponentType<any> | null;\n key: string | null;\n} | null;\n\nexport function traverseReactEltTree(\n children: React.ReactNode,\n callback: (elt: ReactElt) => void\n) {\n const rec = (elts: ReactElt | ReactElt[] | null) => {\n (Array.isArray(elts) ? elts : [elts]).forEach((elt) => {\n if (elt) {\n callback(elt);\n if (elt.children) {\n rec(elt.children);\n }\n if (elt.props?.children && elt.props.children !== elt.children) {\n rec(elt.props.children);\n }\n }\n });\n };\n rec(children as any);\n}\n\nexport function asArray<T>(x: T[] | T | undefined | null) {\n if (Array.isArray(x)) {\n return x;\n } else if (x == null) {\n return [];\n } else {\n return [x];\n }\n}\n"],"names":["isValidUrl","url","test","getMetadata","_ref","_asyncToGenerator","_regeneratorRuntime","mark","_callee","$","getHostname","getTitle","meta","metas","metadata","wrap","_context","prev","next","abrupt","fetch","then","res","text","HTML","sent","URL","hostname","title","querySelector","querySelectorAll","map","el","name","getAttribute","content","filter","item","forEach","metaName","metasItem","find","m","key","split","image","every","src","href","_extends","stop","_x","apply","arguments","LinkPreview","children","loadingMessage","noPreviewMessage","showLoading","showNoPreview","_isMounted","useRef","_useState","useState","setMetadata","_useState2","isLoading","setIsLoading","isEditMode","usePlasmicCanvasContext","resetMetadata","useCallback","description","siteName","useEffect","current","err","console","error","showLoadingProp","showNoPreviewProp","hasChildren","props","hasMetadata","_metadata$title","length","startsWith","body","React","hasNoPreview","DataProvider","data","style","display","loader","component","registerComponent","registerComponentHelper","providesData","displayName","type","defaultValue","defaultValueHint","validator","value","hidePlaceholder","importPath","importName"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"plasmic-link-preview.cjs.production.min.js","sources":["../src/lib/html-metadata-parser.ts","../src/index.tsx","../src/lib/utils.ts"],"sourcesContent":["import { parse as HTML } from \"node-html-parser\";\n\ninterface Meta {\n title?: string;\n description?: string;\n image?: string;\n url?: string;\n type?: string;\n site_name?: string;\n}\n\nexport interface Metadata {\n title?: string;\n description?: string;\n image?: string;\n siteName?: string;\n hostname?: string;\n}\n\nconst isValidUrl = (url: string) => {\n return /(^http(s?):\\/\\/[^\\s$.?#].[^\\s]*)/i.test(url);\n};\n\nconst getMetadata = async (url: string): Promise<Metadata> => {\n if (!isValidUrl(url)) return {};\n\n const contents = await fetch(`https://corsproxy.io/?${url}`).then((res) =>\n res.text()\n );\n\n const $ = HTML(contents);\n\n const getHostname = () => {\n const { hostname } = new URL(url);\n return hostname;\n };\n\n const getTitle = () => {\n const title = $.querySelector(\"title\");\n return title?.text;\n };\n\n const meta: Meta = {};\n\n const metas = $.querySelectorAll(\"meta\")\n .map((el) => ({\n name: el.getAttribute(\"name\") || el.getAttribute(\"property\"),\n content: el.getAttribute(\"content\"),\n }))\n .filter((item) => item.name && item.content);\n\n [\n \"og:title\",\n \"og:description\",\n \"twitter:description\",\n // in order of priority, og:image is sufficient if present\n \"og:image\",\n \"twitter:image\",\n \"og:url\",\n \"og:site_name\",\n \"og:type\",\n ].forEach((metaName) => {\n const metasItem = metas.find((m) => m.name === metaName);\n if (!metasItem || !metasItem.name) return;\n const key = metasItem.name.split(\":\")[1] as keyof Meta;\n if (!meta[key]) meta[key] = metasItem.content;\n });\n\n [\"title\", \"description\", \"image\"].forEach((metaName) => {\n const metasItem = metas.find((m) => m.name === metaName);\n if (!metasItem || !metasItem.name) return;\n const key = metaName as keyof Meta;\n if (!meta[key]) meta[key] = metasItem.content;\n });\n\n if (!meta.image) {\n // find all images available and choose one!\n $.querySelectorAll(\"img\").every((el) => {\n const src: string | undefined = el.getAttribute(\"src\");\n if (src) {\n meta.image = new URL(src, url).href;\n return false;\n }\n return true;\n });\n }\n\n const metadata: Metadata = {\n hostname: getHostname(),\n title: getTitle(),\n ...meta,\n };\n\n return metadata;\n};\n\nexport default getMetadata;\nexport { isValidUrl };\n","import React, { useCallback, useEffect, useRef, useState } from \"react\";\nimport { Registerable, registerComponentHelper } from \"./lib/utils\";\n\nimport { DataProvider, usePlasmicCanvasContext } from \"@plasmicapp/host\";\nimport getMetadata, { isValidUrl, Metadata } from \"./lib/html-metadata-parser\";\n\nexport type LinkPreviewProps = {\n url: string;\n children: React.ReactNode;\n loadingMessage: React.ReactNode;\n noPreviewMessage: React.ReactNode;\n showLoading: boolean;\n showNoPreview: boolean;\n};\n\nexport const LinkPreview: React.FC<LinkPreviewProps> = ({\n url,\n children,\n loadingMessage,\n noPreviewMessage,\n showLoading,\n showNoPreview,\n}) => {\n const _isMounted = useRef(true);\n const [metadata, setMetadata] = useState<Metadata>({});\n const [isLoading, setIsLoading] = useState(false);\n\n const isEditMode = !!usePlasmicCanvasContext();\n\n const resetMetadata = useCallback(() => {\n setMetadata({\n title: \"\",\n description: \"\",\n image: \"\",\n siteName: \"\",\n hostname: \"\",\n });\n }, []);\n\n useEffect(() => {\n _isMounted.current = true;\n if (!url) return;\n\n setIsLoading(true);\n resetMetadata();\n getMetadata(url)\n .then((res) => {\n if (_isMounted.current) {\n setMetadata(res);\n setIsLoading(false);\n }\n })\n .catch((err) => {\n console.error(err);\n console.error(\"No metadata could be found for the given URL.\");\n if (_isMounted.current) {\n resetMetadata();\n setIsLoading(false);\n }\n });\n return () => {\n _isMounted.current = false;\n };\n }, [resetMetadata, url]);\n\n const showLoadingProp = isEditMode ? showLoading : false;\n const showNoPreviewProp = isEditMode ? showNoPreview : false;\n const hasChildren = (children as any)?.props.children;\n const hasMetadata =\n metadata?.title?.length && !metadata.title.startsWith(\"Origin DNS error\");\n const body = hasChildren ? <>{children}</> : <p>{metadata.title}</p>;\n const hidePreview =\n isLoading || showLoadingProp || showNoPreviewProp || !hasMetadata;\n const hasNoPreview = !isLoading && !hasMetadata;\n\n return (\n <div>\n <DataProvider name=\"metadata\" data={metadata}>\n {/* We want the metadata to always be available to the elements inside children slot. So we use CSS to hide it */}\n <div style={hidePreview ? { display: \"none\" } : {}}>{body}</div>\n {(hasNoPreview || showNoPreviewProp) && noPreviewMessage}\n {(isLoading || showLoadingProp) && loadingMessage}\n </DataProvider>\n </div>\n );\n};\n\nexport const rlpComponentName = \"plasmic-link-preview\";\n\nexport function registerLinkPreview(loader?: Registerable) {\n registerComponentHelper(loader, LinkPreview, {\n name: rlpComponentName,\n providesData: true,\n displayName: \"Link Preview\",\n props: {\n url: {\n type: \"string\",\n displayName: \"URL\",\n defaultValue: \"https://plasmic.app\",\n defaultValueHint: \"https://example.com\",\n validator: (value) => {\n if (isValidUrl(value)) return true;\n return \"Invalid URL\";\n },\n description: \"The URL for which you want to generate the link preview.\",\n },\n children: {\n type: \"slot\",\n hidePlaceholder: true,\n },\n noPreviewMessage: {\n type: \"slot\",\n displayName: \"'No Preview' Message\",\n hidePlaceholder: true,\n defaultValue: [\n {\n type: \"text\",\n value: \"no preview...\",\n },\n ],\n },\n showLoading: {\n type: \"boolean\",\n description:\n \"You can enable this prop to show the loading message, so you can easily customize it. This prop has no effect in the live app.\",\n },\n showNoPreview: {\n type: \"boolean\",\n description:\n \"You can enable this prop to show the 'No Preview' message, so you can easily customize it. This prop has no effect in the live app.\",\n },\n loadingMessage: {\n type: \"slot\",\n displayName: \"Loading Message\",\n hidePlaceholder: true,\n defaultValue: [\n {\n type: \"text\",\n value: \"loading preview...\",\n },\n ],\n },\n },\n importPath: \"@plasmicpkgs/plasmic-link-preview\",\n importName: \"LinkPreview\",\n });\n}\n","import {\n CodeComponentMeta,\n default as registerComponent,\n} from \"@plasmicapp/host/registerComponent\";\nimport {\n GlobalContextMeta,\n default as registerGlobalContext,\n} from \"@plasmicapp/host/registerGlobalContext\";\nimport { default as registerToken } from \"@plasmicapp/host/registerToken\";\nimport React from \"react\";\n\nexport type Registerable = {\n registerComponent: typeof registerComponent;\n registerGlobalContext: typeof registerGlobalContext;\n registerToken: typeof registerToken;\n};\n\nexport function makeRegisterComponent<T extends React.ComponentType<any>>(\n component: T,\n meta: CodeComponentMeta<React.ComponentProps<T>>\n) {\n return function (loader?: Registerable) {\n registerComponentHelper(loader, component, meta);\n };\n}\n\nexport function makeRegisterGlobalContext<T extends React.ComponentType<any>>(\n component: T,\n meta: GlobalContextMeta<React.ComponentProps<T>>\n) {\n return function (loader?: Registerable) {\n if (loader) {\n loader.registerGlobalContext(component, meta);\n } else {\n registerGlobalContext(component, meta);\n }\n };\n}\n\nexport function registerComponentHelper<T extends React.ComponentType<any>>(\n loader: Registerable | undefined,\n component: T,\n meta: CodeComponentMeta<React.ComponentProps<T>>\n) {\n if (loader) {\n loader.registerComponent(component, meta);\n } else {\n registerComponent(component, meta);\n }\n}\n\ntype ReactElt = {\n children: ReactElt | ReactElt[];\n props: {\n children: ReactElt | ReactElt[];\n [prop: string]: any;\n } | null;\n type: React.ComponentType<any> | null;\n key: string | null;\n} | null;\n\nexport function traverseReactEltTree(\n children: React.ReactNode,\n callback: (elt: ReactElt) => void\n) {\n const rec = (elts: ReactElt | ReactElt[] | null) => {\n (Array.isArray(elts) ? elts : [elts]).forEach((elt) => {\n if (elt) {\n callback(elt);\n if (elt.children) {\n rec(elt.children);\n }\n if (elt.props?.children && elt.props.children !== elt.children) {\n rec(elt.props.children);\n }\n }\n });\n };\n rec(children as any);\n}\n\nexport function asArray<T>(x: T[] | T | undefined | null) {\n if (Array.isArray(x)) {\n return x;\n } else if (x == null) {\n return [];\n } else {\n return [x];\n }\n}\n"],"names":["isValidUrl","url","test","getMetadata","_ref","_asyncToGenerator","_regenerator","m","_callee","$","getHostname","getTitle","meta","metas","metadata","w","_context","n","a","fetch","then","res","text","HTML","v","URL","hostname","title","querySelector","querySelectorAll","map","el","name","getAttribute","content","filter","item","forEach","metaName","metasItem","find","key","split","image","every","src","href","_extends","_x","apply","arguments","LinkPreview","children","loadingMessage","noPreviewMessage","showLoading","showNoPreview","_isMounted","useRef","_useState","useState","setMetadata","_useState2","isLoading","setIsLoading","isEditMode","usePlasmicCanvasContext","resetMetadata","useCallback","description","siteName","useEffect","current","err","console","error","showLoadingProp","showNoPreviewProp","hasChildren","props","hasMetadata","_metadata$title","length","startsWith","body","React","hasNoPreview","DataProvider","data","style","display","loader","component","registerComponent","registerComponentHelper","providesData","displayName","type","defaultValue","defaultValueHint","validator","value","hidePlaceholder","importPath","importName"],"mappings":"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"}
|
|
@@ -46,329 +46,136 @@ function _extends() {
|
|
|
46
46
|
return n;
|
|
47
47
|
}, _extends.apply(null, arguments);
|
|
48
48
|
}
|
|
49
|
-
function
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
return o(a, "_invoke", {
|
|
84
|
-
value: makeInvokeMethod(t, r, c)
|
|
85
|
-
}), a;
|
|
86
|
-
}
|
|
87
|
-
function tryCatch(t, e, r) {
|
|
88
|
-
try {
|
|
89
|
-
return {
|
|
90
|
-
type: "normal",
|
|
91
|
-
arg: t.call(e, r)
|
|
92
|
-
};
|
|
93
|
-
} catch (t) {
|
|
94
|
-
return {
|
|
95
|
-
type: "throw",
|
|
96
|
-
arg: t
|
|
97
|
-
};
|
|
98
|
-
}
|
|
99
|
-
}
|
|
100
|
-
e.wrap = wrap;
|
|
101
|
-
var h = "suspendedStart",
|
|
102
|
-
l = "suspendedYield",
|
|
103
|
-
f = "executing",
|
|
104
|
-
s = "completed",
|
|
105
|
-
y = {};
|
|
106
|
-
function Generator() {}
|
|
107
|
-
function GeneratorFunction() {}
|
|
108
|
-
function GeneratorFunctionPrototype() {}
|
|
109
|
-
var p = {};
|
|
110
|
-
define(p, a, function () {
|
|
111
|
-
return this;
|
|
112
|
-
});
|
|
113
|
-
var d = Object.getPrototypeOf,
|
|
114
|
-
v = d && d(d(values([])));
|
|
115
|
-
v && v !== r && n.call(v, a) && (p = v);
|
|
116
|
-
var g = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(p);
|
|
117
|
-
function defineIteratorMethods(t) {
|
|
118
|
-
["next", "throw", "return"].forEach(function (e) {
|
|
119
|
-
define(t, e, function (t) {
|
|
120
|
-
return this._invoke(e, t);
|
|
121
|
-
});
|
|
122
|
-
});
|
|
123
|
-
}
|
|
124
|
-
function AsyncIterator(t, e) {
|
|
125
|
-
function invoke(r, o, i, a) {
|
|
126
|
-
var c = tryCatch(t[r], t, o);
|
|
127
|
-
if ("throw" !== c.type) {
|
|
128
|
-
var u = c.arg,
|
|
129
|
-
h = u.value;
|
|
130
|
-
return h && "object" == typeof h && n.call(h, "__await") ? e.resolve(h.__await).then(function (t) {
|
|
131
|
-
invoke("next", t, i, a);
|
|
132
|
-
}, function (t) {
|
|
133
|
-
invoke("throw", t, i, a);
|
|
134
|
-
}) : e.resolve(h).then(function (t) {
|
|
135
|
-
u.value = t, i(u);
|
|
136
|
-
}, function (t) {
|
|
137
|
-
return invoke("throw", t, i, a);
|
|
138
|
-
});
|
|
139
|
-
}
|
|
140
|
-
a(c.arg);
|
|
141
|
-
}
|
|
142
|
-
var r;
|
|
143
|
-
o(this, "_invoke", {
|
|
144
|
-
value: function (t, n) {
|
|
145
|
-
function callInvokeWithMethodAndArg() {
|
|
146
|
-
return new e(function (e, r) {
|
|
147
|
-
invoke(t, n, e, r);
|
|
148
|
-
});
|
|
49
|
+
function _regenerator() {
|
|
50
|
+
/*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/babel/babel/blob/main/packages/babel-helpers/LICENSE */
|
|
51
|
+
var e,
|
|
52
|
+
t,
|
|
53
|
+
r = "function" == typeof Symbol ? Symbol : {},
|
|
54
|
+
n = r.iterator || "@@iterator",
|
|
55
|
+
o = r.toStringTag || "@@toStringTag";
|
|
56
|
+
function i(r, n, o, i) {
|
|
57
|
+
var c = n && n.prototype instanceof Generator ? n : Generator,
|
|
58
|
+
u = Object.create(c.prototype);
|
|
59
|
+
return _regeneratorDefine(u, "_invoke", function (r, n, o) {
|
|
60
|
+
var i,
|
|
61
|
+
c,
|
|
62
|
+
u,
|
|
63
|
+
f = 0,
|
|
64
|
+
p = o || [],
|
|
65
|
+
y = !1,
|
|
66
|
+
G = {
|
|
67
|
+
p: 0,
|
|
68
|
+
n: 0,
|
|
69
|
+
v: e,
|
|
70
|
+
a: d,
|
|
71
|
+
f: d.bind(e, 4),
|
|
72
|
+
d: function (t, r) {
|
|
73
|
+
return i = t, c = 0, u = e, G.n = r, a;
|
|
74
|
+
}
|
|
75
|
+
};
|
|
76
|
+
function d(r, n) {
|
|
77
|
+
for (c = r, u = n, t = 0; !y && f && !o && t < p.length; t++) {
|
|
78
|
+
var o,
|
|
79
|
+
i = p[t],
|
|
80
|
+
d = G.p,
|
|
81
|
+
l = i[2];
|
|
82
|
+
r > 3 ? (o = l === n) && (u = i[(c = i[4]) ? 5 : (c = 3, 3)], i[4] = i[5] = e) : i[0] <= d && ((o = r < 2 && d < i[1]) ? (c = 0, G.v = n, G.n = i[1]) : d < l && (o = r < 3 || i[0] > n || n > l) && (i[4] = r, i[5] = n, G.n = l, c = 0));
|
|
149
83
|
}
|
|
150
|
-
|
|
84
|
+
if (o || r > 1) return a;
|
|
85
|
+
throw y = !0, n;
|
|
151
86
|
}
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
87
|
+
return function (o, p, l) {
|
|
88
|
+
if (f > 1) throw TypeError("Generator is already running");
|
|
89
|
+
for (y && 1 === p && d(p, l), c = p, u = l; (t = c < 2 ? e : u) || !y;) {
|
|
90
|
+
i || (c ? c < 3 ? (c > 1 && (G.n = -1), d(c, u)) : G.n = u : G.v = u);
|
|
91
|
+
try {
|
|
92
|
+
if (f = 2, i) {
|
|
93
|
+
if (c || (o = "next"), t = i[o]) {
|
|
94
|
+
if (!(t = t.call(i, u))) throw TypeError("iterator result is not an object");
|
|
95
|
+
if (!t.done) return t;
|
|
96
|
+
u = t.value, c < 2 && (c = 0);
|
|
97
|
+
} else 1 === c && (t = i.return) && t.call(i), c < 2 && (u = TypeError("The iterator does not provide a '" + o + "' method"), c = 1);
|
|
98
|
+
i = e;
|
|
99
|
+
} else if ((t = (y = G.n < 0) ? u : r.call(n, G)) !== a) break;
|
|
100
|
+
} catch (t) {
|
|
101
|
+
i = e, c = 1, u = t;
|
|
102
|
+
} finally {
|
|
103
|
+
f = 1;
|
|
104
|
+
}
|
|
105
|
+
}
|
|
160
106
|
return {
|
|
161
107
|
value: t,
|
|
162
|
-
done:
|
|
108
|
+
done: y
|
|
163
109
|
};
|
|
164
|
-
}
|
|
165
|
-
|
|
166
|
-
var c = n.delegate;
|
|
167
|
-
if (c) {
|
|
168
|
-
var u = maybeInvokeDelegate(c, n);
|
|
169
|
-
if (u) {
|
|
170
|
-
if (u === y) continue;
|
|
171
|
-
return u;
|
|
172
|
-
}
|
|
173
|
-
}
|
|
174
|
-
if ("next" === n.method) n.sent = n._sent = n.arg;else if ("throw" === n.method) {
|
|
175
|
-
if (o === h) throw o = s, n.arg;
|
|
176
|
-
n.dispatchException(n.arg);
|
|
177
|
-
} else "return" === n.method && n.abrupt("return", n.arg);
|
|
178
|
-
o = f;
|
|
179
|
-
var p = tryCatch(e, r, n);
|
|
180
|
-
if ("normal" === p.type) {
|
|
181
|
-
if (o = n.done ? s : l, p.arg === y) continue;
|
|
182
|
-
return {
|
|
183
|
-
value: p.arg,
|
|
184
|
-
done: n.done
|
|
185
|
-
};
|
|
186
|
-
}
|
|
187
|
-
"throw" === p.type && (o = s, n.method = "throw", n.arg = p.arg);
|
|
188
|
-
}
|
|
189
|
-
};
|
|
190
|
-
}
|
|
191
|
-
function maybeInvokeDelegate(e, r) {
|
|
192
|
-
var n = r.method,
|
|
193
|
-
o = e.iterator[n];
|
|
194
|
-
if (o === t) return r.delegate = null, "throw" === n && e.iterator.return && (r.method = "return", r.arg = t, maybeInvokeDelegate(e, r), "throw" === r.method) || "return" !== n && (r.method = "throw", r.arg = new TypeError("The iterator does not provide a '" + n + "' method")), y;
|
|
195
|
-
var i = tryCatch(o, e.iterator, r.arg);
|
|
196
|
-
if ("throw" === i.type) return r.method = "throw", r.arg = i.arg, r.delegate = null, y;
|
|
197
|
-
var a = i.arg;
|
|
198
|
-
return a ? a.done ? (r[e.resultName] = a.value, r.next = e.nextLoc, "return" !== r.method && (r.method = "next", r.arg = t), r.delegate = null, y) : a : (r.method = "throw", r.arg = new TypeError("iterator result is not an object"), r.delegate = null, y);
|
|
199
|
-
}
|
|
200
|
-
function pushTryEntry(t) {
|
|
201
|
-
var e = {
|
|
202
|
-
tryLoc: t[0]
|
|
203
|
-
};
|
|
204
|
-
1 in t && (e.catchLoc = t[1]), 2 in t && (e.finallyLoc = t[2], e.afterLoc = t[3]), this.tryEntries.push(e);
|
|
205
|
-
}
|
|
206
|
-
function resetTryEntry(t) {
|
|
207
|
-
var e = t.completion || {};
|
|
208
|
-
e.type = "normal", delete e.arg, t.completion = e;
|
|
209
|
-
}
|
|
210
|
-
function Context(t) {
|
|
211
|
-
this.tryEntries = [{
|
|
212
|
-
tryLoc: "root"
|
|
213
|
-
}], t.forEach(pushTryEntry, this), this.reset(!0);
|
|
110
|
+
};
|
|
111
|
+
}(r, o, i), !0), u;
|
|
214
112
|
}
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
return i.next = i;
|
|
227
|
-
}
|
|
228
|
-
}
|
|
229
|
-
throw new TypeError(typeof e + " is not iterable");
|
|
113
|
+
var a = {};
|
|
114
|
+
function Generator() {}
|
|
115
|
+
function GeneratorFunction() {}
|
|
116
|
+
function GeneratorFunctionPrototype() {}
|
|
117
|
+
t = Object.getPrototypeOf;
|
|
118
|
+
var c = [][n] ? t(t([][n]())) : (_regeneratorDefine(t = {}, n, function () {
|
|
119
|
+
return this;
|
|
120
|
+
}), t),
|
|
121
|
+
u = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(c);
|
|
122
|
+
function f(e) {
|
|
123
|
+
return Object.setPrototypeOf ? Object.setPrototypeOf(e, GeneratorFunctionPrototype) : (e.__proto__ = GeneratorFunctionPrototype, _regeneratorDefine(e, o, "GeneratorFunction")), e.prototype = Object.create(u), e;
|
|
230
124
|
}
|
|
231
|
-
return GeneratorFunction.prototype = GeneratorFunctionPrototype,
|
|
232
|
-
value: GeneratorFunctionPrototype,
|
|
233
|
-
configurable: !0
|
|
234
|
-
}), o(GeneratorFunctionPrototype, "constructor", {
|
|
235
|
-
value: GeneratorFunction,
|
|
236
|
-
configurable: !0
|
|
237
|
-
}), GeneratorFunction.displayName = define(GeneratorFunctionPrototype, u, "GeneratorFunction"), e.isGeneratorFunction = function (t) {
|
|
238
|
-
var e = "function" == typeof t && t.constructor;
|
|
239
|
-
return !!e && (e === GeneratorFunction || "GeneratorFunction" === (e.displayName || e.name));
|
|
240
|
-
}, e.mark = function (t) {
|
|
241
|
-
return Object.setPrototypeOf ? Object.setPrototypeOf(t, GeneratorFunctionPrototype) : (t.__proto__ = GeneratorFunctionPrototype, define(t, u, "GeneratorFunction")), t.prototype = Object.create(g), t;
|
|
242
|
-
}, e.awrap = function (t) {
|
|
243
|
-
return {
|
|
244
|
-
__await: t
|
|
245
|
-
};
|
|
246
|
-
}, defineIteratorMethods(AsyncIterator.prototype), define(AsyncIterator.prototype, c, function () {
|
|
247
|
-
return this;
|
|
248
|
-
}), e.AsyncIterator = AsyncIterator, e.async = function (t, r, n, o, i) {
|
|
249
|
-
void 0 === i && (i = Promise);
|
|
250
|
-
var a = new AsyncIterator(wrap(t, r, n, o), i);
|
|
251
|
-
return e.isGeneratorFunction(r) ? a : a.next().then(function (t) {
|
|
252
|
-
return t.done ? t.value : a.next();
|
|
253
|
-
});
|
|
254
|
-
}, defineIteratorMethods(g), define(g, u, "Generator"), define(g, a, function () {
|
|
125
|
+
return GeneratorFunction.prototype = GeneratorFunctionPrototype, _regeneratorDefine(u, "constructor", GeneratorFunctionPrototype), _regeneratorDefine(GeneratorFunctionPrototype, "constructor", GeneratorFunction), GeneratorFunction.displayName = "GeneratorFunction", _regeneratorDefine(GeneratorFunctionPrototype, o, "GeneratorFunction"), _regeneratorDefine(u), _regeneratorDefine(u, o, "Generator"), _regeneratorDefine(u, n, function () {
|
|
255
126
|
return this;
|
|
256
|
-
}),
|
|
127
|
+
}), _regeneratorDefine(u, "toString", function () {
|
|
257
128
|
return "[object Generator]";
|
|
258
|
-
}),
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
return r.reverse(), function next() {
|
|
263
|
-
for (; r.length;) {
|
|
264
|
-
var t = r.pop();
|
|
265
|
-
if (t in e) return next.value = t, next.done = !1, next;
|
|
266
|
-
}
|
|
267
|
-
return next.done = !0, next;
|
|
129
|
+
}), (_regenerator = function () {
|
|
130
|
+
return {
|
|
131
|
+
w: i,
|
|
132
|
+
m: f
|
|
268
133
|
};
|
|
269
|
-
}
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
function handle(n, o) {
|
|
284
|
-
return a.type = "throw", a.arg = e, r.next = n, o && (r.method = "next", r.arg = t), !!o;
|
|
285
|
-
}
|
|
286
|
-
for (var o = this.tryEntries.length - 1; o >= 0; --o) {
|
|
287
|
-
var i = this.tryEntries[o],
|
|
288
|
-
a = i.completion;
|
|
289
|
-
if ("root" === i.tryLoc) return handle("end");
|
|
290
|
-
if (i.tryLoc <= this.prev) {
|
|
291
|
-
var c = n.call(i, "catchLoc"),
|
|
292
|
-
u = n.call(i, "finallyLoc");
|
|
293
|
-
if (c && u) {
|
|
294
|
-
if (this.prev < i.catchLoc) return handle(i.catchLoc, !0);
|
|
295
|
-
if (this.prev < i.finallyLoc) return handle(i.finallyLoc);
|
|
296
|
-
} else if (c) {
|
|
297
|
-
if (this.prev < i.catchLoc) return handle(i.catchLoc, !0);
|
|
298
|
-
} else {
|
|
299
|
-
if (!u) throw Error("try statement without catch or finally");
|
|
300
|
-
if (this.prev < i.finallyLoc) return handle(i.finallyLoc);
|
|
301
|
-
}
|
|
302
|
-
}
|
|
303
|
-
}
|
|
304
|
-
},
|
|
305
|
-
abrupt: function (t, e) {
|
|
306
|
-
for (var r = this.tryEntries.length - 1; r >= 0; --r) {
|
|
307
|
-
var o = this.tryEntries[r];
|
|
308
|
-
if (o.tryLoc <= this.prev && n.call(o, "finallyLoc") && this.prev < o.finallyLoc) {
|
|
309
|
-
var i = o;
|
|
310
|
-
break;
|
|
311
|
-
}
|
|
312
|
-
}
|
|
313
|
-
i && ("break" === t || "continue" === t) && i.tryLoc <= e && e <= i.finallyLoc && (i = null);
|
|
314
|
-
var a = i ? i.completion : {};
|
|
315
|
-
return a.type = t, a.arg = e, i ? (this.method = "next", this.next = i.finallyLoc, y) : this.complete(a);
|
|
316
|
-
},
|
|
317
|
-
complete: function (t, e) {
|
|
318
|
-
if ("throw" === t.type) throw t.arg;
|
|
319
|
-
return "break" === t.type || "continue" === t.type ? this.next = t.arg : "return" === t.type ? (this.rval = this.arg = t.arg, this.method = "return", this.next = "end") : "normal" === t.type && e && (this.next = e), y;
|
|
320
|
-
},
|
|
321
|
-
finish: function (t) {
|
|
322
|
-
for (var e = this.tryEntries.length - 1; e >= 0; --e) {
|
|
323
|
-
var r = this.tryEntries[e];
|
|
324
|
-
if (r.finallyLoc === t) return this.complete(r.completion, r.afterLoc), resetTryEntry(r), y;
|
|
325
|
-
}
|
|
326
|
-
},
|
|
327
|
-
catch: function (t) {
|
|
328
|
-
for (var e = this.tryEntries.length - 1; e >= 0; --e) {
|
|
329
|
-
var r = this.tryEntries[e];
|
|
330
|
-
if (r.tryLoc === t) {
|
|
331
|
-
var n = r.completion;
|
|
332
|
-
if ("throw" === n.type) {
|
|
333
|
-
var o = n.arg;
|
|
334
|
-
resetTryEntry(r);
|
|
335
|
-
}
|
|
336
|
-
return o;
|
|
337
|
-
}
|
|
338
|
-
}
|
|
339
|
-
throw Error("illegal catch attempt");
|
|
340
|
-
},
|
|
341
|
-
delegateYield: function (e, r, n) {
|
|
342
|
-
return this.delegate = {
|
|
343
|
-
iterator: values(e),
|
|
344
|
-
resultName: r,
|
|
345
|
-
nextLoc: n
|
|
346
|
-
}, "next" === this.method && (this.arg = t), y;
|
|
134
|
+
})();
|
|
135
|
+
}
|
|
136
|
+
function _regeneratorDefine(e, r, n, t) {
|
|
137
|
+
var i = Object.defineProperty;
|
|
138
|
+
try {
|
|
139
|
+
i({}, "", {});
|
|
140
|
+
} catch (e) {
|
|
141
|
+
i = 0;
|
|
142
|
+
}
|
|
143
|
+
_regeneratorDefine = function (e, r, n, t) {
|
|
144
|
+
function o(r, n) {
|
|
145
|
+
_regeneratorDefine(e, r, function (e) {
|
|
146
|
+
return this._invoke(r, n, e);
|
|
147
|
+
});
|
|
347
148
|
}
|
|
348
|
-
|
|
149
|
+
r ? i ? i(e, r, {
|
|
150
|
+
value: n,
|
|
151
|
+
enumerable: !t,
|
|
152
|
+
configurable: !t,
|
|
153
|
+
writable: !t
|
|
154
|
+
}) : e[r] = n : (o("next", 0), o("throw", 1), o("return", 2));
|
|
155
|
+
}, _regeneratorDefine(e, r, n, t);
|
|
349
156
|
}
|
|
350
157
|
|
|
351
158
|
var isValidUrl = function isValidUrl(url) {
|
|
352
159
|
return /(^http(s?):\/\/[^\s$.?#].[^\s]*)/i.test(url);
|
|
353
160
|
};
|
|
354
161
|
var getMetadata = /*#__PURE__*/function () {
|
|
355
|
-
var _ref = /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/
|
|
162
|
+
var _ref = /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regenerator().m(function _callee(url) {
|
|
356
163
|
var contents, $, getHostname, getTitle, meta, metas, metadata;
|
|
357
|
-
return
|
|
358
|
-
while (1) switch (_context.
|
|
164
|
+
return _regenerator().w(function (_context) {
|
|
165
|
+
while (1) switch (_context.n) {
|
|
359
166
|
case 0:
|
|
360
167
|
if (isValidUrl(url)) {
|
|
361
|
-
_context.
|
|
168
|
+
_context.n = 1;
|
|
362
169
|
break;
|
|
363
170
|
}
|
|
364
|
-
return _context.
|
|
365
|
-
case
|
|
366
|
-
_context.
|
|
171
|
+
return _context.a(2, {});
|
|
172
|
+
case 1:
|
|
173
|
+
_context.n = 2;
|
|
367
174
|
return fetch("https://corsproxy.io/?" + url).then(function (res) {
|
|
368
175
|
return res.text();
|
|
369
176
|
});
|
|
370
|
-
case
|
|
371
|
-
contents = _context.
|
|
177
|
+
case 2:
|
|
178
|
+
contents = _context.v;
|
|
372
179
|
$ = parse(contents);
|
|
373
180
|
getHostname = function getHostname() {
|
|
374
181
|
var _URL = new URL(url),
|
|
@@ -421,10 +228,7 @@ var getMetadata = /*#__PURE__*/function () {
|
|
|
421
228
|
hostname: getHostname(),
|
|
422
229
|
title: getTitle()
|
|
423
230
|
}, meta);
|
|
424
|
-
return _context.
|
|
425
|
-
case 15:
|
|
426
|
-
case "end":
|
|
427
|
-
return _context.stop();
|
|
231
|
+
return _context.a(2, metadata);
|
|
428
232
|
}
|
|
429
233
|
}, _callee);
|
|
430
234
|
}));
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"plasmic-link-preview.esm.js","sources":["../src/lib/utils.ts","../src/lib/html-metadata-parser.ts","../src/index.tsx"],"sourcesContent":["import {\n CodeComponentMeta,\n default as registerComponent,\n} from \"@plasmicapp/host/registerComponent\";\nimport {\n GlobalContextMeta,\n default as registerGlobalContext,\n} from \"@plasmicapp/host/registerGlobalContext\";\nimport { default as registerToken } from \"@plasmicapp/host/registerToken\";\nimport React from \"react\";\n\nexport type Registerable = {\n registerComponent: typeof registerComponent;\n registerGlobalContext: typeof registerGlobalContext;\n registerToken: typeof registerToken;\n};\n\nexport function makeRegisterComponent<T extends React.ComponentType<any>>(\n component: T,\n meta: CodeComponentMeta<React.ComponentProps<T>>\n) {\n return function (loader?: Registerable) {\n registerComponentHelper(loader, component, meta);\n };\n}\n\nexport function makeRegisterGlobalContext<T extends React.ComponentType<any>>(\n component: T,\n meta: GlobalContextMeta<React.ComponentProps<T>>\n) {\n return function (loader?: Registerable) {\n if (loader) {\n loader.registerGlobalContext(component, meta);\n } else {\n registerGlobalContext(component, meta);\n }\n };\n}\n\nexport function registerComponentHelper<T extends React.ComponentType<any>>(\n loader: Registerable | undefined,\n component: T,\n meta: CodeComponentMeta<React.ComponentProps<T>>\n) {\n if (loader) {\n loader.registerComponent(component, meta);\n } else {\n registerComponent(component, meta);\n }\n}\n\ntype ReactElt = {\n children: ReactElt | ReactElt[];\n props: {\n children: ReactElt | ReactElt[];\n [prop: string]: any;\n } | null;\n type: React.ComponentType<any> | null;\n key: string | null;\n} | null;\n\nexport function traverseReactEltTree(\n children: React.ReactNode,\n callback: (elt: ReactElt) => void\n) {\n const rec = (elts: ReactElt | ReactElt[] | null) => {\n (Array.isArray(elts) ? elts : [elts]).forEach((elt) => {\n if (elt) {\n callback(elt);\n if (elt.children) {\n rec(elt.children);\n }\n if (elt.props?.children && elt.props.children !== elt.children) {\n rec(elt.props.children);\n }\n }\n });\n };\n rec(children as any);\n}\n\nexport function asArray<T>(x: T[] | T | undefined | null) {\n if (Array.isArray(x)) {\n return x;\n } else if (x == null) {\n return [];\n } else {\n return [x];\n }\n}\n","import { parse as HTML } from \"node-html-parser\";\n\ninterface Meta {\n title?: string;\n description?: string;\n image?: string;\n url?: string;\n type?: string;\n site_name?: string;\n}\n\nexport interface Metadata {\n title?: string;\n description?: string;\n image?: string;\n siteName?: string;\n hostname?: string;\n}\n\nconst isValidUrl = (url: string) => {\n return /(^http(s?):\\/\\/[^\\s$.?#].[^\\s]*)/i.test(url);\n};\n\nconst getMetadata = async (url: string): Promise<Metadata> => {\n if (!isValidUrl(url)) return {};\n\n const contents = await fetch(`https://corsproxy.io/?${url}`).then((res) =>\n res.text()\n );\n\n const $ = HTML(contents);\n\n const getHostname = () => {\n const { hostname } = new URL(url);\n return hostname;\n };\n\n const getTitle = () => {\n const title = $.querySelector(\"title\");\n return title?.text;\n };\n\n const meta: Meta = {};\n\n const metas = $.querySelectorAll(\"meta\")\n .map((el) => ({\n name: el.getAttribute(\"name\") || el.getAttribute(\"property\"),\n content: el.getAttribute(\"content\"),\n }))\n .filter((item) => item.name && item.content);\n\n [\n \"og:title\",\n \"og:description\",\n \"twitter:description\",\n // in order of priority, og:image is sufficient if present\n \"og:image\",\n \"twitter:image\",\n \"og:url\",\n \"og:site_name\",\n \"og:type\",\n ].forEach((metaName) => {\n const metasItem = metas.find((m) => m.name === metaName);\n if (!metasItem || !metasItem.name) return;\n const key = metasItem.name.split(\":\")[1] as keyof Meta;\n if (!meta[key]) meta[key] = metasItem.content;\n });\n\n [\"title\", \"description\", \"image\"].forEach((metaName) => {\n const metasItem = metas.find((m) => m.name === metaName);\n if (!metasItem || !metasItem.name) return;\n const key = metaName as keyof Meta;\n if (!meta[key]) meta[key] = metasItem.content;\n });\n\n if (!meta.image) {\n // find all images available and choose one!\n $.querySelectorAll(\"img\").every((el) => {\n const src: string | undefined = el.getAttribute(\"src\");\n if (src) {\n meta.image = new URL(src, url).href;\n return false;\n }\n return true;\n });\n }\n\n const metadata: Metadata = {\n hostname: getHostname(),\n title: getTitle(),\n ...meta,\n };\n\n return metadata;\n};\n\nexport default getMetadata;\nexport { isValidUrl };\n","import React, { useCallback, useEffect, useRef, useState } from \"react\";\nimport { Registerable, registerComponentHelper } from \"./lib/utils\";\n\nimport { DataProvider, usePlasmicCanvasContext } from \"@plasmicapp/host\";\nimport getMetadata, { isValidUrl, Metadata } from \"./lib/html-metadata-parser\";\n\nexport type LinkPreviewProps = {\n url: string;\n children: React.ReactNode;\n loadingMessage: React.ReactNode;\n noPreviewMessage: React.ReactNode;\n showLoading: boolean;\n showNoPreview: boolean;\n};\n\nexport const LinkPreview: React.FC<LinkPreviewProps> = ({\n url,\n children,\n loadingMessage,\n noPreviewMessage,\n showLoading,\n showNoPreview,\n}) => {\n const _isMounted = useRef(true);\n const [metadata, setMetadata] = useState<Metadata>({});\n const [isLoading, setIsLoading] = useState(false);\n\n const isEditMode = !!usePlasmicCanvasContext();\n\n const resetMetadata = useCallback(() => {\n setMetadata({\n title: \"\",\n description: \"\",\n image: \"\",\n siteName: \"\",\n hostname: \"\",\n });\n }, []);\n\n useEffect(() => {\n _isMounted.current = true;\n if (!url) return;\n\n setIsLoading(true);\n resetMetadata();\n getMetadata(url)\n .then((res) => {\n if (_isMounted.current) {\n setMetadata(res);\n setIsLoading(false);\n }\n })\n .catch((err) => {\n console.error(err);\n console.error(\"No metadata could be found for the given URL.\");\n if (_isMounted.current) {\n resetMetadata();\n setIsLoading(false);\n }\n });\n return () => {\n _isMounted.current = false;\n };\n }, [resetMetadata, url]);\n\n const showLoadingProp = isEditMode ? showLoading : false;\n const showNoPreviewProp = isEditMode ? showNoPreview : false;\n const hasChildren = (children as any)?.props.children;\n const hasMetadata =\n metadata?.title?.length && !metadata.title.startsWith(\"Origin DNS error\");\n const body = hasChildren ? <>{children}</> : <p>{metadata.title}</p>;\n const hidePreview =\n isLoading || showLoadingProp || showNoPreviewProp || !hasMetadata;\n const hasNoPreview = !isLoading && !hasMetadata;\n\n return (\n <div>\n <DataProvider name=\"metadata\" data={metadata}>\n {/* We want the metadata to always be available to the elements inside children slot. So we use CSS to hide it */}\n <div style={hidePreview ? { display: \"none\" } : {}}>{body}</div>\n {(hasNoPreview || showNoPreviewProp) && noPreviewMessage}\n {(isLoading || showLoadingProp) && loadingMessage}\n </DataProvider>\n </div>\n );\n};\n\nexport const rlpComponentName = \"plasmic-link-preview\";\n\nexport function registerLinkPreview(loader?: Registerable) {\n registerComponentHelper(loader, LinkPreview, {\n name: rlpComponentName,\n providesData: true,\n displayName: \"Link Preview\",\n props: {\n url: {\n type: \"string\",\n displayName: \"URL\",\n defaultValue: \"https://plasmic.app\",\n defaultValueHint: \"https://example.com\",\n validator: (value) => {\n if (isValidUrl(value)) return true;\n return \"Invalid URL\";\n },\n description: \"The URL for which you want to generate the link preview.\",\n },\n children: {\n type: \"slot\",\n hidePlaceholder: true,\n },\n noPreviewMessage: {\n type: \"slot\",\n displayName: \"'No Preview' Message\",\n hidePlaceholder: true,\n defaultValue: [\n {\n type: \"text\",\n value: \"no preview...\",\n },\n ],\n },\n showLoading: {\n type: \"boolean\",\n description:\n \"You can enable this prop to show the loading message, so you can easily customize it. This prop has no effect in the live app.\",\n },\n showNoPreview: {\n type: \"boolean\",\n description:\n \"You can enable this prop to show the 'No Preview' message, so you can easily customize it. This prop has no effect in the live app.\",\n },\n loadingMessage: {\n type: \"slot\",\n displayName: \"Loading Message\",\n hidePlaceholder: true,\n defaultValue: [\n {\n type: \"text\",\n value: \"loading preview...\",\n },\n ],\n },\n },\n importPath: \"@plasmicpkgs/plasmic-link-preview\",\n importName: \"LinkPreview\",\n });\n}\n"],"names":["registerComponentHelper","loader","component","meta","registerComponent","isValidUrl","url","test","getMetadata","_ref","_asyncToGenerator","_regeneratorRuntime","mark","_callee","contents","$","getHostname","getTitle","metas","metadata","wrap","_callee$","_context","prev","next","abrupt","fetch","then","res","text","sent","HTML","_URL","URL","hostname","title","querySelector","querySelectorAll","map","el","name","getAttribute","content","filter","item","forEach","metaName","metasItem","find","m","key","split","image","every","src","href","_extends","stop","_x","apply","arguments","LinkPreview","children","loadingMessage","noPreviewMessage","showLoading","showNoPreview","_isMounted","useRef","_useState","useState","setMetadata","_useState2","isLoading","setIsLoading","isEditMode","usePlasmicCanvasContext","resetMetadata","useCallback","description","siteName","useEffect","current","err","console","error","showLoadingProp","showNoPreviewProp","hasChildren","props","hasMetadata","_metadata$title","length","startsWith","body","React","hidePreview","hasNoPreview","DataProvider","data","style","display","rlpComponentName","registerLinkPreview","providesData","displayName","type","defaultValue","defaultValueHint","validator","value","hidePlaceholder","importPath","importName"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"plasmic-link-preview.esm.js","sources":["../src/lib/utils.ts","../src/lib/html-metadata-parser.ts","../src/index.tsx"],"sourcesContent":["import {\n CodeComponentMeta,\n default as registerComponent,\n} from \"@plasmicapp/host/registerComponent\";\nimport {\n GlobalContextMeta,\n default as registerGlobalContext,\n} from \"@plasmicapp/host/registerGlobalContext\";\nimport { default as registerToken } from \"@plasmicapp/host/registerToken\";\nimport React from \"react\";\n\nexport type Registerable = {\n registerComponent: typeof registerComponent;\n registerGlobalContext: typeof registerGlobalContext;\n registerToken: typeof registerToken;\n};\n\nexport function makeRegisterComponent<T extends React.ComponentType<any>>(\n component: T,\n meta: CodeComponentMeta<React.ComponentProps<T>>\n) {\n return function (loader?: Registerable) {\n registerComponentHelper(loader, component, meta);\n };\n}\n\nexport function makeRegisterGlobalContext<T extends React.ComponentType<any>>(\n component: T,\n meta: GlobalContextMeta<React.ComponentProps<T>>\n) {\n return function (loader?: Registerable) {\n if (loader) {\n loader.registerGlobalContext(component, meta);\n } else {\n registerGlobalContext(component, meta);\n }\n };\n}\n\nexport function registerComponentHelper<T extends React.ComponentType<any>>(\n loader: Registerable | undefined,\n component: T,\n meta: CodeComponentMeta<React.ComponentProps<T>>\n) {\n if (loader) {\n loader.registerComponent(component, meta);\n } else {\n registerComponent(component, meta);\n }\n}\n\ntype ReactElt = {\n children: ReactElt | ReactElt[];\n props: {\n children: ReactElt | ReactElt[];\n [prop: string]: any;\n } | null;\n type: React.ComponentType<any> | null;\n key: string | null;\n} | null;\n\nexport function traverseReactEltTree(\n children: React.ReactNode,\n callback: (elt: ReactElt) => void\n) {\n const rec = (elts: ReactElt | ReactElt[] | null) => {\n (Array.isArray(elts) ? elts : [elts]).forEach((elt) => {\n if (elt) {\n callback(elt);\n if (elt.children) {\n rec(elt.children);\n }\n if (elt.props?.children && elt.props.children !== elt.children) {\n rec(elt.props.children);\n }\n }\n });\n };\n rec(children as any);\n}\n\nexport function asArray<T>(x: T[] | T | undefined | null) {\n if (Array.isArray(x)) {\n return x;\n } else if (x == null) {\n return [];\n } else {\n return [x];\n }\n}\n","import { parse as HTML } from \"node-html-parser\";\n\ninterface Meta {\n title?: string;\n description?: string;\n image?: string;\n url?: string;\n type?: string;\n site_name?: string;\n}\n\nexport interface Metadata {\n title?: string;\n description?: string;\n image?: string;\n siteName?: string;\n hostname?: string;\n}\n\nconst isValidUrl = (url: string) => {\n return /(^http(s?):\\/\\/[^\\s$.?#].[^\\s]*)/i.test(url);\n};\n\nconst getMetadata = async (url: string): Promise<Metadata> => {\n if (!isValidUrl(url)) return {};\n\n const contents = await fetch(`https://corsproxy.io/?${url}`).then((res) =>\n res.text()\n );\n\n const $ = HTML(contents);\n\n const getHostname = () => {\n const { hostname } = new URL(url);\n return hostname;\n };\n\n const getTitle = () => {\n const title = $.querySelector(\"title\");\n return title?.text;\n };\n\n const meta: Meta = {};\n\n const metas = $.querySelectorAll(\"meta\")\n .map((el) => ({\n name: el.getAttribute(\"name\") || el.getAttribute(\"property\"),\n content: el.getAttribute(\"content\"),\n }))\n .filter((item) => item.name && item.content);\n\n [\n \"og:title\",\n \"og:description\",\n \"twitter:description\",\n // in order of priority, og:image is sufficient if present\n \"og:image\",\n \"twitter:image\",\n \"og:url\",\n \"og:site_name\",\n \"og:type\",\n ].forEach((metaName) => {\n const metasItem = metas.find((m) => m.name === metaName);\n if (!metasItem || !metasItem.name) return;\n const key = metasItem.name.split(\":\")[1] as keyof Meta;\n if (!meta[key]) meta[key] = metasItem.content;\n });\n\n [\"title\", \"description\", \"image\"].forEach((metaName) => {\n const metasItem = metas.find((m) => m.name === metaName);\n if (!metasItem || !metasItem.name) return;\n const key = metaName as keyof Meta;\n if (!meta[key]) meta[key] = metasItem.content;\n });\n\n if (!meta.image) {\n // find all images available and choose one!\n $.querySelectorAll(\"img\").every((el) => {\n const src: string | undefined = el.getAttribute(\"src\");\n if (src) {\n meta.image = new URL(src, url).href;\n return false;\n }\n return true;\n });\n }\n\n const metadata: Metadata = {\n hostname: getHostname(),\n title: getTitle(),\n ...meta,\n };\n\n return metadata;\n};\n\nexport default getMetadata;\nexport { isValidUrl };\n","import React, { useCallback, useEffect, useRef, useState } from \"react\";\nimport { Registerable, registerComponentHelper } from \"./lib/utils\";\n\nimport { DataProvider, usePlasmicCanvasContext } from \"@plasmicapp/host\";\nimport getMetadata, { isValidUrl, Metadata } from \"./lib/html-metadata-parser\";\n\nexport type LinkPreviewProps = {\n url: string;\n children: React.ReactNode;\n loadingMessage: React.ReactNode;\n noPreviewMessage: React.ReactNode;\n showLoading: boolean;\n showNoPreview: boolean;\n};\n\nexport const LinkPreview: React.FC<LinkPreviewProps> = ({\n url,\n children,\n loadingMessage,\n noPreviewMessage,\n showLoading,\n showNoPreview,\n}) => {\n const _isMounted = useRef(true);\n const [metadata, setMetadata] = useState<Metadata>({});\n const [isLoading, setIsLoading] = useState(false);\n\n const isEditMode = !!usePlasmicCanvasContext();\n\n const resetMetadata = useCallback(() => {\n setMetadata({\n title: \"\",\n description: \"\",\n image: \"\",\n siteName: \"\",\n hostname: \"\",\n });\n }, []);\n\n useEffect(() => {\n _isMounted.current = true;\n if (!url) return;\n\n setIsLoading(true);\n resetMetadata();\n getMetadata(url)\n .then((res) => {\n if (_isMounted.current) {\n setMetadata(res);\n setIsLoading(false);\n }\n })\n .catch((err) => {\n console.error(err);\n console.error(\"No metadata could be found for the given URL.\");\n if (_isMounted.current) {\n resetMetadata();\n setIsLoading(false);\n }\n });\n return () => {\n _isMounted.current = false;\n };\n }, [resetMetadata, url]);\n\n const showLoadingProp = isEditMode ? showLoading : false;\n const showNoPreviewProp = isEditMode ? showNoPreview : false;\n const hasChildren = (children as any)?.props.children;\n const hasMetadata =\n metadata?.title?.length && !metadata.title.startsWith(\"Origin DNS error\");\n const body = hasChildren ? <>{children}</> : <p>{metadata.title}</p>;\n const hidePreview =\n isLoading || showLoadingProp || showNoPreviewProp || !hasMetadata;\n const hasNoPreview = !isLoading && !hasMetadata;\n\n return (\n <div>\n <DataProvider name=\"metadata\" data={metadata}>\n {/* We want the metadata to always be available to the elements inside children slot. So we use CSS to hide it */}\n <div style={hidePreview ? { display: \"none\" } : {}}>{body}</div>\n {(hasNoPreview || showNoPreviewProp) && noPreviewMessage}\n {(isLoading || showLoadingProp) && loadingMessage}\n </DataProvider>\n </div>\n );\n};\n\nexport const rlpComponentName = \"plasmic-link-preview\";\n\nexport function registerLinkPreview(loader?: Registerable) {\n registerComponentHelper(loader, LinkPreview, {\n name: rlpComponentName,\n providesData: true,\n displayName: \"Link Preview\",\n props: {\n url: {\n type: \"string\",\n displayName: \"URL\",\n defaultValue: \"https://plasmic.app\",\n defaultValueHint: \"https://example.com\",\n validator: (value) => {\n if (isValidUrl(value)) return true;\n return \"Invalid URL\";\n },\n description: \"The URL for which you want to generate the link preview.\",\n },\n children: {\n type: \"slot\",\n hidePlaceholder: true,\n },\n noPreviewMessage: {\n type: \"slot\",\n displayName: \"'No Preview' Message\",\n hidePlaceholder: true,\n defaultValue: [\n {\n type: \"text\",\n value: \"no preview...\",\n },\n ],\n },\n showLoading: {\n type: \"boolean\",\n description:\n \"You can enable this prop to show the loading message, so you can easily customize it. This prop has no effect in the live app.\",\n },\n showNoPreview: {\n type: \"boolean\",\n description:\n \"You can enable this prop to show the 'No Preview' message, so you can easily customize it. This prop has no effect in the live app.\",\n },\n loadingMessage: {\n type: \"slot\",\n displayName: \"Loading Message\",\n hidePlaceholder: true,\n defaultValue: [\n {\n type: \"text\",\n value: \"loading preview...\",\n },\n ],\n },\n },\n importPath: \"@plasmicpkgs/plasmic-link-preview\",\n importName: \"LinkPreview\",\n });\n}\n"],"names":["registerComponentHelper","loader","component","meta","registerComponent","isValidUrl","url","test","getMetadata","_ref","_asyncToGenerator","_regenerator","m","_callee","contents","$","getHostname","getTitle","metas","metadata","w","_context","n","a","fetch","then","res","text","v","HTML","_URL","URL","hostname","title","querySelector","querySelectorAll","map","el","name","getAttribute","content","filter","item","forEach","metaName","metasItem","find","key","split","image","every","src","href","_extends","_x","apply","arguments","LinkPreview","children","loadingMessage","noPreviewMessage","showLoading","showNoPreview","_isMounted","useRef","_useState","useState","setMetadata","_useState2","isLoading","setIsLoading","isEditMode","usePlasmicCanvasContext","resetMetadata","useCallback","description","siteName","useEffect","current","err","console","error","showLoadingProp","showNoPreviewProp","hasChildren","props","hasMetadata","_metadata$title","length","startsWith","body","React","hidePreview","hasNoPreview","DataProvider","data","style","display","rlpComponentName","registerLinkPreview","providesData","displayName","type","defaultValue","defaultValueHint","validator","value","hidePlaceholder","importPath","importName"],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@plasmicpkgs/plasmic-link-preview",
|
|
3
|
-
"version": "1.0.
|
|
3
|
+
"version": "1.0.148",
|
|
4
4
|
"description": "A React component that renders beautiful, fully-customizable link previews.",
|
|
5
5
|
"main": "dist/index.js",
|
|
6
6
|
"types": "dist/index.d.ts",
|
|
@@ -28,7 +28,7 @@
|
|
|
28
28
|
"analyze": "size-limit --why"
|
|
29
29
|
},
|
|
30
30
|
"devDependencies": {
|
|
31
|
-
"@plasmicapp/data-sources": "1.0.
|
|
31
|
+
"@plasmicapp/data-sources": "1.0.4",
|
|
32
32
|
"@plasmicapp/host": "2.0.2",
|
|
33
33
|
"@types/node": "^14.0.26",
|
|
34
34
|
"@types/react": "^18",
|
|
@@ -47,5 +47,5 @@
|
|
|
47
47
|
"dependencies": {
|
|
48
48
|
"node-html-parser": "^6.1.11"
|
|
49
49
|
},
|
|
50
|
-
"gitHead": "
|
|
50
|
+
"gitHead": "aed0870defb894a50985f5b656f3f50e167b835e"
|
|
51
51
|
}
|