@plasmicapp/react-web 0.2.79 → 0.2.83

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (61) hide show
  1. package/dist/all.d.ts +17 -1
  2. package/dist/react-web.cjs.development.js +108 -40
  3. package/dist/react-web.cjs.development.js.map +1 -1
  4. package/dist/react-web.cjs.production.min.js +1 -1
  5. package/dist/react-web.cjs.production.min.js.map +1 -1
  6. package/dist/react-web.esm.js +108 -40
  7. package/dist/react-web.esm.js.map +1 -1
  8. package/dist/render/PlasmicImg/index.d.ts +17 -1
  9. package/lib/plasmic.css +0 -3
  10. package/package.json +1 -1
  11. package/skinny/dist/collection-utils-4dae6efa.js +292 -0
  12. package/skinny/dist/{collection-utils-976df07d.js.map → collection-utils-4dae6efa.js.map} +1 -1
  13. package/skinny/dist/collection-utils-57ec40f9.js +292 -0
  14. package/skinny/dist/{collection-utils-21ad9cae.js.map → collection-utils-57ec40f9.js.map} +1 -1
  15. package/skinny/dist/collection-utils-b0b8f30e.js +287 -234
  16. package/skinny/dist/props-utils-5c0ad25a.js +59 -0
  17. package/skinny/dist/{props-utils-6cf101b2.js.map → props-utils-5c0ad25a.js.map} +1 -1
  18. package/skinny/dist/props-utils-c632595f.js +53 -33
  19. package/skinny/dist/props-utils-fd5f444e.js +59 -0
  20. package/skinny/dist/{props-utils-1f98cfd3.js.map → props-utils-fd5f444e.js.map} +1 -1
  21. package/skinny/dist/react-utils-118d8539.js +186 -168
  22. package/skinny/dist/react-utils-2a2fd6c9.js +339 -0
  23. package/skinny/dist/react-utils-2a2fd6c9.js.map +1 -0
  24. package/skinny/dist/react-utils-675565b4.js +334 -0
  25. package/skinny/dist/react-utils-675565b4.js.map +1 -0
  26. package/skinny/dist/render/PlasmicImg/index.d.ts +17 -1
  27. package/skinny/dist/render/PlasmicImg/index.js +90 -33
  28. package/skinny/dist/render/PlasmicImg/index.js.map +1 -1
  29. package/skinny/dist/render/PlasmicImg.d.ts +62 -55
  30. package/skinny/dist/tslib.es6-00014098.js +143 -123
  31. package/skinny/dist/collection-utils-21ad9cae.js +0 -238
  32. package/skinny/dist/collection-utils-87ffc0ed.js +0 -238
  33. package/skinny/dist/collection-utils-87ffc0ed.js.map +0 -1
  34. package/skinny/dist/collection-utils-976df07d.js +0 -238
  35. package/skinny/dist/collection-utils-aadc3a43.js +0 -238
  36. package/skinny/dist/collection-utils-aadc3a43.js.map +0 -1
  37. package/skinny/dist/collection-utils-b8a2fd59.js +0 -238
  38. package/skinny/dist/collection-utils-b8a2fd59.js.map +0 -1
  39. package/skinny/dist/props-utils-1f98cfd3.js +0 -40
  40. package/skinny/dist/props-utils-40224c71.js +0 -40
  41. package/skinny/dist/props-utils-40224c71.js.map +0 -1
  42. package/skinny/dist/props-utils-69f9ba8b.js +0 -40
  43. package/skinny/dist/props-utils-69f9ba8b.js.map +0 -1
  44. package/skinny/dist/props-utils-6cf101b2.js +0 -39
  45. package/skinny/dist/props-utils-85691c9c.js +0 -40
  46. package/skinny/dist/props-utils-85691c9c.js.map +0 -1
  47. package/skinny/dist/react-utils-06bae09a.js +0 -254
  48. package/skinny/dist/react-utils-06bae09a.js.map +0 -1
  49. package/skinny/dist/react-utils-14af9d28.js +0 -172
  50. package/skinny/dist/react-utils-14af9d28.js.map +0 -1
  51. package/skinny/dist/react-utils-834a65c3.js +0 -254
  52. package/skinny/dist/react-utils-834a65c3.js.map +0 -1
  53. package/skinny/dist/react-utils-ae69f4e0.js +0 -254
  54. package/skinny/dist/react-utils-ae69f4e0.js.map +0 -1
  55. package/skinny/dist/react-utils-cca81efc.js +0 -245
  56. package/skinny/dist/react-utils-cca81efc.js.map +0 -1
  57. package/skinny/dist/stories/Button.d.ts +0 -29
  58. package/skinny/dist/stories/Header.d.ts +0 -10
  59. package/skinny/dist/stories/Page.d.ts +0 -10
  60. package/skinny/dist/tslib.es6-10d3f595.js +0 -132
  61. package/skinny/dist/tslib.es6-10d3f595.js.map +0 -1
@@ -0,0 +1,334 @@
1
+ import classNames from "classnames";
2
+ import React__default from "react";
3
+
4
+ function notNil(x) {
5
+ return x != null;
6
+ }
7
+ function pick(obj) {
8
+ var keys = [];
9
+ for (var _i = 1; _i < arguments.length; _i++) {
10
+ keys[_i - 1] = arguments[_i];
11
+ }
12
+ if (Object.keys(obj).length === 0) {
13
+ return obj;
14
+ }
15
+ var res = {};
16
+ for (var _a = 0, keys_1 = keys; _a < keys_1.length; _a++) {
17
+ var key = keys_1[_a];
18
+ if (key in obj) {
19
+ res[key] = obj[key];
20
+ }
21
+ }
22
+ return res;
23
+ }
24
+ function omit(obj) {
25
+ var keys = [];
26
+ for (var _i = 1; _i < arguments.length; _i++) {
27
+ keys[_i - 1] = arguments[_i];
28
+ }
29
+ if (Object.keys(obj).length === 0) {
30
+ return obj;
31
+ }
32
+ var res = {};
33
+ for (var _a = 0, _b = Object.keys(obj); _a < _b.length; _a++) {
34
+ var key = _b[_a];
35
+ if (!keys.includes(key)) {
36
+ res[key] = obj[key];
37
+ }
38
+ }
39
+ return res;
40
+ }
41
+ function isSubset(a1, a2) {
42
+ return a1.every(function (x) {
43
+ return a2.includes(x);
44
+ });
45
+ }
46
+ function chainSingleArgFuncs() {
47
+ var funcs = [];
48
+ for (var _i = 0; _i < arguments.length; _i++) {
49
+ funcs[_i] = arguments[_i];
50
+ }
51
+ if (funcs.length === 0) {
52
+ return undefined;
53
+ }
54
+ return function (arg) {
55
+ var res = arg;
56
+ for (var _i = 0, funcs_1 = funcs; _i < funcs_1.length; _i++) {
57
+ var func = funcs_1[_i];
58
+ res = func(res);
59
+ }
60
+ return res;
61
+ };
62
+ }
63
+ function isString(x) {
64
+ return typeof x === "string";
65
+ }
66
+ function groupBy(collection, keyFunc) {
67
+ var result = {};
68
+ for (var _i = 0, collection_1 = collection; _i < collection_1.length; _i++) {
69
+ var obj = collection_1[_i];
70
+ var key = keyFunc(obj);
71
+ if (key in result) {
72
+ result[key].push(obj);
73
+ } else {
74
+ result[key] = [obj];
75
+ }
76
+ }
77
+ return result;
78
+ }
79
+ function mapValues(obj, mapper) {
80
+ var result = {};
81
+ for (var key in obj) {
82
+ result[key] = mapper(obj[key]);
83
+ }
84
+ return result;
85
+ }
86
+
87
+ /*! *****************************************************************************
88
+ Copyright (c) Microsoft Corporation.
89
+
90
+ Permission to use, copy, modify, and/or distribute this software for any
91
+ purpose with or without fee is hereby granted.
92
+
93
+ THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
94
+ REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
95
+ AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
96
+ INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
97
+ LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
98
+ OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
99
+ PERFORMANCE OF THIS SOFTWARE.
100
+ ***************************************************************************** */
101
+
102
+ var __assign = function () {
103
+ __assign =
104
+ Object.assign ||
105
+ function __assign(t) {
106
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
107
+ s = arguments[i];
108
+ for (var p in s)
109
+ if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];
110
+ }
111
+ return t;
112
+ };
113
+ return __assign.apply(this, arguments);
114
+ };
115
+
116
+ function __rest(s, e) {
117
+ var t = {};
118
+ for (var p in s)
119
+ if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
120
+ t[p] = s[p];
121
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
122
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
123
+ if (
124
+ e.indexOf(p[i]) < 0 &&
125
+ Object.prototype.propertyIsEnumerable.call(s, p[i])
126
+ )
127
+ t[p[i]] = s[p[i]];
128
+ }
129
+ return t;
130
+ }
131
+
132
+ function __spreadArray(to, from) {
133
+ for (var i = 0, il = from.length, j = to.length; i < il; i++, j++)
134
+ to[j] = from[i];
135
+ return to;
136
+ }
137
+
138
+ var isBrowser = typeof window !== "undefined";
139
+ var NONE = Symbol("NONE");
140
+ var useIsomorphicLayoutEffect = isBrowser
141
+ ? React__default.useLayoutEffect
142
+ : React__default.useEffect;
143
+ function createElementWithChildren(elementType, props, children) {
144
+ if (Array.isArray(children)) {
145
+ return React__default.createElement.apply(
146
+ React__default,
147
+ __spreadArray([elementType, props], children)
148
+ );
149
+ } else if (children || "children" in props) {
150
+ // Only call React.createElement with `children` if there are actual children,
151
+ // or if there was an explicit (albeit undefined) children passed via
152
+ // props. Otherwise, if you pass `undefined` as the children argument
153
+ // to React.createElement, the created element will have prop {children: undefined}.
154
+ // If the `root` is an PlasmicGeneratedComponent, and these props with {children: undefined}
155
+ // are used, then it will be taken as a `children` override, and will thus blank out
156
+ // everything under the root node.
157
+ return React__default.createElement(elementType, props, children);
158
+ } else {
159
+ return React__default.createElement(elementType, props);
160
+ }
161
+ }
162
+ function ensureNotArray(children) {
163
+ if (Array.isArray(children)) {
164
+ if (children.length === 1) {
165
+ return children[0];
166
+ } else {
167
+ return React__default.createElement.apply(
168
+ React__default,
169
+ __spreadArray([React__default.Fragment, {}], children)
170
+ );
171
+ }
172
+ } else {
173
+ return children;
174
+ }
175
+ }
176
+ /**
177
+ * Flattens ReactNode into an array of ReactChild, but does NOT replace
178
+ * missing keys with array index, as React.Children.toArray() does.
179
+ */
180
+ function toChildArray(children) {
181
+ if (isReactChild(children)) {
182
+ return [children];
183
+ } else if (Array.isArray(children)) {
184
+ return children.flatMap(toChildArray);
185
+ } else {
186
+ return [];
187
+ }
188
+ }
189
+ function isReactText(child) {
190
+ return typeof child === "string" || typeof child === "number";
191
+ }
192
+ function isReactChild(child) {
193
+ return React__default.isValidElement(child) || isReactText(child);
194
+ }
195
+ function isReactNode(x) {
196
+ return (
197
+ typeof x === "string" ||
198
+ typeof x === "number" ||
199
+ React__default.isValidElement(x)
200
+ );
201
+ }
202
+ function mergeProps(props) {
203
+ var restProps = [];
204
+ for (var _i = 1; _i < arguments.length; _i++) {
205
+ restProps[_i - 1] = arguments[_i];
206
+ }
207
+ if (
208
+ restProps.every(function (rest) {
209
+ return Object.keys(rest).length === 0;
210
+ })
211
+ ) {
212
+ return props;
213
+ }
214
+ var result = __assign({}, props);
215
+ for (var _a = 0, restProps_1 = restProps; _a < restProps_1.length; _a++) {
216
+ var rest = restProps_1[_a];
217
+ for (var _b = 0, _c = Object.keys(rest); _b < _c.length; _b++) {
218
+ var key = _c[_b];
219
+ result[key] = mergePropVals(key, result[key], rest[key]);
220
+ }
221
+ }
222
+ return result;
223
+ }
224
+ function updateRef(ref, value) {
225
+ if (!ref) {
226
+ return;
227
+ }
228
+ if (typeof ref === "function") {
229
+ ref(value);
230
+ } else {
231
+ if (!Object.isFrozen(ref)) {
232
+ ref.current = value;
233
+ }
234
+ }
235
+ }
236
+ function mergeRefs() {
237
+ var refs = [];
238
+ for (var _i = 0; _i < arguments.length; _i++) {
239
+ refs[_i] = arguments[_i];
240
+ }
241
+ return function (value) {
242
+ for (var _i = 0, refs_1 = refs; _i < refs_1.length; _i++) {
243
+ var ref = refs_1[_i];
244
+ updateRef(ref, value);
245
+ }
246
+ };
247
+ }
248
+ function mergePropVals(name, val1, val2) {
249
+ if (val1 === NONE || val2 === NONE) {
250
+ // The NONE sentinel always skips all merging and returns null
251
+ return null;
252
+ } else if (val1 == null) {
253
+ // If either of them is nil, prefer the other
254
+ return val2;
255
+ } else if (val2 == null) {
256
+ return val1;
257
+ } else if (name === "className") {
258
+ // Special case for className -- always combine both class names
259
+ return classNames(val1, val2);
260
+ } else if (name === "style") {
261
+ // Special case for style -- always shallow-merge style dicts
262
+ return __assign(__assign({}, val1), val2);
263
+ } else if (name === "ref") {
264
+ // Special case for ref
265
+ return mergeRefs(val1, val2);
266
+ } else if (typeof val1 !== typeof val2) {
267
+ // If the type of the two values are different, then no way to merge them.
268
+ // Prefer val2.
269
+ return val2;
270
+ } else if (name.startsWith("on") && typeof val1 === "function") {
271
+ // Special case for event handlers -- always call both handlers
272
+ return function () {
273
+ var args = [];
274
+ for (var _i = 0; _i < arguments.length; _i++) {
275
+ args[_i] = arguments[_i];
276
+ }
277
+ var res;
278
+ if (typeof val1 === "function") {
279
+ res = val1.apply(void 0, args);
280
+ }
281
+ if (typeof val2 === "function") {
282
+ res = val2.apply(void 0, args);
283
+ }
284
+ return res;
285
+ };
286
+ } else {
287
+ // For all else, prefer val2
288
+ return val2;
289
+ }
290
+ }
291
+ function getElementTypeName(element) {
292
+ var _a, _b, _c, _d;
293
+ if (typeof element.type === "string") {
294
+ return element.type;
295
+ } else {
296
+ var comp = element.type;
297
+ return (_d =
298
+ (_b =
299
+ (_a = comp.displayName) !== null && _a !== void 0 ? _a : comp.name) !==
300
+ null && _b !== void 0
301
+ ? _b
302
+ : (_c = comp.render) === null || _c === void 0
303
+ ? void 0
304
+ : _c.name) !== null && _d !== void 0
305
+ ? _d
306
+ : "Component";
307
+ }
308
+ }
309
+
310
+ export {
311
+ NONE as N,
312
+ __rest as _,
313
+ __assign as a,
314
+ __spreadArray as b,
315
+ createElementWithChildren as c,
316
+ mergePropVals as d,
317
+ ensureNotArray as e,
318
+ isSubset as f,
319
+ chainSingleArgFuncs as g,
320
+ isBrowser as h,
321
+ isReactNode as i,
322
+ mapValues as j,
323
+ groupBy as k,
324
+ isString as l,
325
+ mergeProps as m,
326
+ notNil as n,
327
+ omit as o,
328
+ pick as p,
329
+ getElementTypeName as q,
330
+ mergeRefs as r,
331
+ toChildArray as t,
332
+ useIsomorphicLayoutEffect as u,
333
+ };
334
+ //# sourceMappingURL=react-utils-675565b4.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"react-utils-675565b4.js","sources":["../../src/common.ts","../../node_modules/tslib/tslib.es6.js","../../src/react-utils.tsx"],"sourcesContent":["export function notNil<T>(x: T | undefined | null): x is T {\n return x != null;\n}\n\nexport function pick<T>(\n obj: T,\n ...keys: (string | number | symbol)[]\n): Partial<T> {\n if (Object.keys(obj).length === 0) {\n return obj;\n }\n const res: any = {};\n for (const key of keys) {\n if (key in obj) {\n res[key] = obj[key as keyof T];\n }\n }\n return res as Partial<T>;\n}\n\nexport function pickBy<T>(\n obj: T,\n func: (key: string, val: any) => boolean\n): Partial<T> {\n const res: any = {};\n for (const [key, val] of Object.entries(obj)) {\n if (func(key, val)) {\n res[key] = obj[key as keyof T];\n }\n }\n return res as Partial<T>;\n}\n\nexport function omit<T>(obj: T, ...keys: (keyof T)[]): Partial<T> {\n if (Object.keys(obj).length === 0) {\n return obj;\n }\n const res: Partial<T> = {};\n for (const key of Object.keys(obj) as (keyof T)[]) {\n if (!keys.includes(key)) {\n res[key] = obj[key];\n }\n }\n return res;\n}\n\nexport function isSubset<T>(a1: T[], a2: T[]) {\n return a1.every((x) => a2.includes(x));\n}\n\nexport function chainSingleArgFuncs<A>(...funcs: ((arg: A) => A)[]) {\n if (funcs.length === 0) {\n return undefined;\n }\n return (arg: A) => {\n let res: A = arg;\n for (const func of funcs) {\n res = func(res);\n }\n return res;\n };\n}\n\nexport function ensure<T>(x: T | null | undefined): T {\n if (x === null || x === undefined) {\n debugger;\n throw new Error(`Value must not be undefined or null`);\n } else {\n return x;\n }\n}\n\nexport function isString(x: any): x is string {\n return typeof x === \"string\";\n}\n\nexport function groupBy<T>(\n collection: T[],\n keyFunc: (x: T) => string\n): Record<string, T[]> {\n const result: Record<string, T[]> = {};\n for (const obj of collection) {\n const key = keyFunc(obj);\n if (key in result) {\n result[key].push(obj);\n } else {\n result[key] = [obj];\n }\n }\n return result;\n}\n\nexport function mapValues<V, V2>(\n obj: Record<string, V>,\n mapper: (value: V) => V2\n): Record<string, V2> {\n const result: Record<string, V2> = {};\n for (const key in obj) {\n result[key] = mapper(obj[key]);\n }\n return result;\n}\n","/*! *****************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n if (typeof b !== \"function\" && b !== null)\r\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (_) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });\r\n}) : (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\r\n\r\nexport function __spreadArray(to, from) {\r\n for (var i = 0, il = from.length, j = to.length; i < il; i++, j++)\r\n to[j] = from[i];\r\n return to;\r\n}\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === \"return\" } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n o[\"default\"] = v;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\r\n __setModuleDefault(result, mod);\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\r\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\r\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\r\n}\r\n","import classNames from \"classnames\";\nimport React from \"react\";\n\nexport const isBrowser = typeof window !== \"undefined\";\nexport const NONE = Symbol(\"NONE\");\n\nexport const useIsomorphicLayoutEffect = isBrowser\n ? React.useLayoutEffect\n : React.useEffect;\n\nexport function createElementWithChildren(\n elementType: any,\n props: any,\n children: React.ReactNode\n) {\n if (Array.isArray(children)) {\n return React.createElement(\n elementType,\n props,\n ...children\n ) as React.ReactElement;\n } else if (children || \"children\" in props) {\n // Only call React.createElement with `children` if there are actual children,\n // or if there was an explicit (albeit undefined) children passed via\n // props. Otherwise, if you pass `undefined` as the children argument\n // to React.createElement, the created element will have prop {children: undefined}.\n // If the `root` is an PlasmicGeneratedComponent, and these props with {children: undefined}\n // are used, then it will be taken as a `children` override, and will thus blank out\n // everything under the root node.\n return React.createElement(elementType, props, children);\n } else {\n return React.createElement(elementType, props);\n }\n}\n\nexport function ensureNotArray(children: React.ReactNode) {\n if (Array.isArray(children)) {\n if (children.length === 1) {\n return children[0];\n } else {\n return React.createElement(React.Fragment, {}, ...children);\n }\n } else {\n return children;\n }\n}\n\n/**\n * Flattens ReactNode into an array of ReactChild, but does NOT replace\n * missing keys with array index, as React.Children.toArray() does.\n */\nexport function toChildArray(children: React.ReactNode): React.ReactChild[] {\n if (isReactChild(children)) {\n return [children];\n } else if (Array.isArray(children)) {\n return children.flatMap(toChildArray);\n } else {\n return [];\n }\n}\n\nexport function isReactText(child: React.ReactNode): child is React.ReactText {\n return typeof child === \"string\" || typeof child === \"number\";\n}\n\nexport function isReactChild(\n child: React.ReactNode\n): child is React.ReactChild {\n return React.isValidElement(child) || isReactText(child);\n}\n\nexport function isReactFragment(\n child: React.ReactNode\n): child is React.ReactElement {\n return React.isValidElement(child) && child.type === React.Fragment;\n}\n\nexport function isReactNode(x: any) {\n return (\n typeof x === \"string\" || typeof x === \"number\" || React.isValidElement(x)\n );\n}\n\n// From https://stackoverflow.com/questions/54775790/forcing-excess-property-checking-on-variable-passed-to-typescript-function\nexport type StrictProps<T, TExpected> = Exclude<\n keyof T,\n keyof TExpected\n> extends never\n ? {}\n : \"Unexpected extraneous props\";\n\nexport type HTMLElementRefOf<T extends keyof JSX.IntrinsicElements> = Exclude<\n React.ComponentProps<T>[\"ref\"],\n string\n>;\n\nexport function mergeProps(\n props: Record<string, any>,\n ...restProps: Record<string, any>[]\n): Record<string, any> {\n if (restProps.every((rest) => Object.keys(rest).length === 0)) {\n return props;\n }\n\n const result = { ...props };\n\n for (const rest of restProps) {\n for (const key of Object.keys(rest)) {\n result[key] = mergePropVals(key, result[key], rest[key]);\n }\n }\n\n return result;\n}\n\nfunction updateRef<T>(ref: React.Ref<T> | undefined, value: T | null) {\n if (!ref) {\n return;\n }\n\n if (typeof ref === \"function\") {\n ref(value);\n } else {\n if (!Object.isFrozen(ref)) {\n (ref as React.MutableRefObject<T | null>).current = value;\n }\n }\n}\n\nexport function mergeRefs<T>(...refs: (React.Ref<T> | undefined)[]) {\n return (value: T) => {\n for (const ref of refs) {\n updateRef(ref, value);\n }\n };\n}\n\nexport function mergePropVals(name: string, val1: any, val2: any): any {\n if (val1 === NONE || val2 === NONE) {\n // The NONE sentinel always skips all merging and returns null\n return null;\n } else if (val1 == null) {\n // If either of them is nil, prefer the other\n return val2;\n } else if (val2 == null) {\n return val1;\n } else if (name === \"className\") {\n // Special case for className -- always combine both class names\n return classNames(val1, val2);\n } else if (name === \"style\") {\n // Special case for style -- always shallow-merge style dicts\n return { ...val1, ...val2 };\n } else if (name === \"ref\") {\n // Special case for ref\n return mergeRefs(val1, val2);\n } else if (typeof val1 !== typeof val2) {\n // If the type of the two values are different, then no way to merge them.\n // Prefer val2.\n return val2;\n } else if (name.startsWith(\"on\") && typeof val1 === \"function\") {\n // Special case for event handlers -- always call both handlers\n return (...args: any[]) => {\n let res: any;\n if (typeof val1 === \"function\") {\n res = val1(...args);\n }\n if (typeof val2 === \"function\") {\n res = val2(...args);\n }\n return res;\n };\n } else {\n // For all else, prefer val2\n return val2;\n }\n}\n\nexport function getElementTypeName(element: React.ReactElement) {\n if (typeof element.type === \"string\") {\n return element.type;\n } else {\n const comp = element.type as any;\n return comp.displayName ?? comp.name ?? comp.render?.name ?? \"Component\";\n }\n}\n"],"names":["React"],"mappings":"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"}
@@ -17,7 +17,7 @@ export interface PlasmicImgProps extends ImgTagProps {
17
17
  * Either an object with the src string, and its full width and height,
18
18
  * or just a src string with unknown intrinsic dimensions.
19
19
  */
20
- src: string | {
20
+ src?: string | {
21
21
  src: string;
22
22
  fullHeight: number;
23
23
  fullWidth: number;
@@ -34,6 +34,22 @@ export interface PlasmicImgProps extends ImgTagProps {
34
34
  * css height
35
35
  */
36
36
  displayHeight?: number | string;
37
+ /**
38
+ * css min-width
39
+ */
40
+ displayMinWidth?: number | string;
41
+ /**
42
+ * css min-height
43
+ */
44
+ displayMinHeight?: number | string;
45
+ /**
46
+ * css max-width
47
+ */
48
+ displayMaxWidth?: number | string;
49
+ /**
50
+ * css max-height
51
+ */
52
+ displayMaxHeight?: number | string;
37
53
  /**
38
54
  * For variable quality formats like jpg, the quality from 0 to 100
39
55
  */
@@ -11,24 +11,83 @@ var IMG_SIZES = [16, 32, 48, 64, 96, 128, 256, 384];
11
11
  var DEVICE_SIZES = [640, 750, 828, 1080, 1200, 1920, 2048, 3840];
12
12
  var ALL_SIZES = __spreadArray(__spreadArray([], IMG_SIZES), DEVICE_SIZES);
13
13
  var PlasmicImg = React__default.forwardRef(function PlasmicImg(props, ref) {
14
- var src = props.src, className = props.className, displayWidth = props.displayWidth, displayHeight = props.displayHeight, quality = props.quality, loader = props.loader, containerRef = props.containerRef, style = props.style, rest = __rest(props, ["src", "className", "displayWidth", "displayHeight", "quality", "loader", "containerRef", "style"]);
15
- var _a = typeof src === "string"
14
+ var src = props.src, className = props.className, displayWidth = props.displayWidth, displayHeight = props.displayHeight, displayMinWidth = props.displayMinWidth, displayMinHeight = props.displayMinHeight, displayMaxWidth = props.displayMaxWidth, displayMaxHeight = props.displayMaxHeight, quality = props.quality, loader = props.loader, containerRef = props.containerRef, style = props.style, rest = __rest(props, ["src", "className", "displayWidth", "displayHeight", "displayMinWidth", "displayMinHeight", "displayMaxWidth", "displayMaxHeight", "quality", "loader", "containerRef", "style"]);
15
+ var _a = typeof src === "string" || !src
16
16
  ? { fullWidth: undefined, fullHeight: undefined }
17
17
  : src, fullWidth = _a.fullWidth, fullHeight = _a.fullHeight;
18
- var srcStr = typeof src === "string" ? src : src.src;
18
+ var srcStr = src ? (typeof src === "string" ? src : src.src) : "";
19
19
  // Assume external image if either dimension is null and use usual <img>
20
- // (or if the image is an SVG)
21
- if (fullHeight == null || fullWidth == null || srcStr.endsWith(".svg")) {
20
+ if (fullHeight == null || fullWidth == null) {
22
21
  return (React__default.createElement("img", __assign({ src: srcStr, className: className, style: style }, rest, { ref: ref })));
23
22
  }
24
- var _b = getWidths(displayWidth, fullWidth), sizes = _b.sizes, widthDescs = _b.widthDescs;
23
+ if (isSvg(srcStr) && (displayHeight == null || displayHeight === "auto") && (displayWidth == null || displayWidth === "auto")) {
24
+ displayWidth = "100%";
25
+ }
26
+ if (fullWidth &&
27
+ fullHeight &&
28
+ (!displayWidth || displayWidth === "auto") &&
29
+ !!getPixelLength(displayHeight)) {
30
+ // If there's a pixel length specified for displayHeight but not displayWidth,
31
+ // then we can derive the pixel length for displayWidth. Having an explicit
32
+ // displayWidth makes this a fixed-size image, which makes it possible for us to
33
+ // generate better markup!
34
+ displayWidth = (getPixelLength(displayHeight) * fullWidth) / fullHeight;
35
+ }
36
+ var _b = getWidths(displayWidth, fullWidth, { minWidth: displayMinWidth }), sizes = _b.sizes, widthDescs = _b.widthDescs;
25
37
  var imageLoader = getImageLoader(loader);
26
38
  var spacerSvg = "<svg width=\"" + fullWidth + "\" height=\"" + fullHeight + "\" xmlns=\"http://www.w3.org/2000/svg\" version=\"1.1\"/>";
27
39
  var spacerSvgBase64 = typeof window === "undefined"
28
40
  ? Buffer.from(spacerSvg).toString("base64")
29
41
  : window.btoa(spacerSvg);
30
- return (React__default.createElement("div", { className: classNames(className, "__wab_img-wrapper"), ref: containerRef, style: __assign(__assign({}, style), { width: isPercentage(displayWidth) ? displayWidth : undefined, height: isPercentage(displayHeight) ? displayHeight : undefined }) },
31
- React__default.createElement("img", { alt: "", "aria-hidden": true, className: "__wab_img-spacer-svg", src: "data:image/svg+xml;base64," + spacerSvgBase64, style: __assign({ width: isPercentage(displayWidth) ? "100%" : displayWidth, height: isPercentage(displayHeight) ? "100%" : displayHeight }, (style ? pick(style, "objectFit", "objectPosition") : {})) }),
42
+ var wrapperStyle = __assign({}, (style || {}));
43
+ var spacerStyle = pick(style || {}, "objectFit", "objectPosition");
44
+ if (displayWidth != null && displayWidth !== "auto") {
45
+ // If width is set, set it on the wrapper along with min/max width
46
+ // and just use `width: 100%` on the spacer
47
+ spacerStyle.width = "100%";
48
+ wrapperStyle.width = displayWidth;
49
+ wrapperStyle.minWidth = displayMinWidth;
50
+ wrapperStyle.maxWidth = displayMaxWidth;
51
+ }
52
+ else {
53
+ // Otherwise, we want auto sizing from the spacer, so set width there.
54
+ //
55
+ // But if we have min/max width, it should be set in the wrapper and it
56
+ // can be percentage values (and we add corresponding min/max width to
57
+ // 100% in the spacer). In general it ends up with the correct effect,
58
+ // but some edge cases might make `min-width: 100%` shrink the image more
59
+ // than it should.
60
+ spacerStyle.width = displayWidth;
61
+ wrapperStyle.width = "auto";
62
+ if (displayMinWidth) {
63
+ spacerStyle.minWidth = "100%";
64
+ wrapperStyle.minWidth = displayMinWidth;
65
+ }
66
+ if (displayMaxWidth != null && displayMaxWidth !== "none") {
67
+ spacerStyle.maxWidth = "100%";
68
+ wrapperStyle.maxWidth = displayMaxWidth;
69
+ }
70
+ }
71
+ if (displayHeight != null && displayHeight !== "auto") {
72
+ spacerStyle.height = "100%";
73
+ wrapperStyle.height = displayHeight;
74
+ wrapperStyle.minHeight = displayMinHeight;
75
+ wrapperStyle.maxHeight = displayMaxHeight;
76
+ }
77
+ else {
78
+ spacerStyle.height = displayHeight;
79
+ wrapperStyle.height = "auto";
80
+ if (displayMinHeight) {
81
+ spacerStyle.minHeight = "100%";
82
+ wrapperStyle.minHeight = displayMinHeight;
83
+ }
84
+ if (displayMaxHeight != null && displayMaxHeight !== "none") {
85
+ spacerStyle.maxHeight = "100%";
86
+ wrapperStyle.maxHeight = displayMaxHeight;
87
+ }
88
+ }
89
+ return (React__default.createElement("div", { className: classNames(className, "__wab_img-wrapper"), ref: containerRef, style: wrapperStyle },
90
+ React__default.createElement("img", { alt: "", "aria-hidden": true, className: "__wab_img-spacer-svg", src: "data:image/svg+xml;base64," + spacerSvgBase64, style: spacerStyle }),
32
91
  makePicture({
33
92
  imageLoader: imageLoader,
34
93
  widthDescs: widthDescs,
@@ -73,7 +132,10 @@ function makePicture(opts) {
73
132
  }) + " " + wd.desc;
74
133
  })
75
134
  .join(", ")
76
- : undefined, sizes: imageLoader ? sizes : undefined, style: style ? pick(style, "objectFit", "objectPosition") : undefined }))));
135
+ : undefined, sizes: imageLoader && imageLoader.supportsUrl(src) ? sizes : undefined, style: __assign(__assign({}, (style ? pick(style, "objectFit", "objectPosition") : {})), { width: 0, height: 0 }) }))));
136
+ }
137
+ function isSvg(src) {
138
+ return (src.endsWith(".svg") || src.startsWith("data:image/svg"));
77
139
  }
78
140
  function getClosestPresetSize(width, fullWidth) {
79
141
  var _a;
@@ -98,18 +160,20 @@ function getClosestPresetSize(width, fullWidth) {
98
160
  /**
99
161
  * Computes the appropriate srcSet and sizes to use
100
162
  */
101
- function getWidths(width, fullWidth) {
102
- var pixelWidth = getPixelWidth(width);
103
- if (pixelWidth != null) {
163
+ function getWidths(width, fullWidth, extra) {
164
+ var minWidth = extra === null || extra === void 0 ? void 0 : extra.minWidth;
165
+ var pixelWidth = getPixelLength(width);
166
+ var pixelMinWidth = getPixelLength(minWidth);
167
+ if (pixelWidth != null && (!minWidth || pixelMinWidth != null)) {
104
168
  // If there's an exact width, then we just need to display it at 1x and 2x density
105
169
  return {
106
170
  widthDescs: [
107
171
  {
108
- width: getClosestPresetSize(pixelWidth, fullWidth),
172
+ width: getClosestPresetSize(Math.max(pixelWidth, pixelMinWidth !== null && pixelMinWidth !== void 0 ? pixelMinWidth : 0), fullWidth),
109
173
  desc: "1x",
110
174
  },
111
175
  {
112
- width: getClosestPresetSize(pixelWidth * 2, fullWidth),
176
+ width: getClosestPresetSize(Math.max(pixelWidth, pixelMinWidth !== null && pixelMinWidth !== void 0 ? pixelMinWidth : 0) * 2, fullWidth),
113
177
  desc: "2x",
114
178
  },
115
179
  ],
@@ -133,38 +197,31 @@ function getWidths(width, fullWidth) {
133
197
  };
134
198
  }
135
199
  return {
136
- widthDescs: usefulSizes.map(function (size, i) { return ({
137
- width:
200
+ widthDescs: usefulSizes.map(function (size) { return ({
201
+ width: getClosestPresetSize(size, fullWidth),
138
202
  // If this is the last (buggest) useful width, but it is
139
203
  // still within the bounds set by DEVICE_SIZES, then just
140
204
  // use the original, unresized image. This means if we match
141
205
  // the largest size, we use unresized and best quality image.
142
206
  // We only do this, though, if fullWidth is "reasonable" --
143
207
  // smaller than the largest size we would consider.
144
- i === usefulSizes.length - 1 &&
145
- fullWidth < DEVICE_SIZES[DEVICE_SIZES.length - 1]
146
- ? undefined
147
- : size,
208
+ // i === usefulSizes.length - 1 &&
209
+ // fullWidth < DEVICE_SIZES[DEVICE_SIZES.length - 1]
210
+ // ? undefined
211
+ // : size,
148
212
  desc: size + "w",
149
213
  }); }),
150
214
  sizes: "100vw",
151
215
  };
152
216
  }
153
- function isPercentage(width) {
154
- var _a;
155
- if (typeof width !== "string") {
156
- return false;
157
- }
158
- return ((_a = parseNumeric(width)) === null || _a === void 0 ? void 0 : _a.units) === "%";
159
- }
160
- function getPixelWidth(width) {
161
- if (width == null || width == "") {
217
+ function getPixelLength(length) {
218
+ if (length == null || length == "") {
162
219
  return undefined;
163
220
  }
164
- if (typeof width === "number") {
165
- return width;
221
+ if (typeof length === "number") {
222
+ return length;
166
223
  }
167
- var parsed = parseNumeric(width);
224
+ var parsed = parseNumeric(length);
168
225
  if (parsed && (!parsed.units || parsed.units === "px")) {
169
226
  return parsed.num;
170
227
  }
@@ -193,7 +250,7 @@ function getImageLoader(loader) {
193
250
  }
194
251
  var PLASMIC_IMAGE_LOADER = {
195
252
  supportsUrl: function (src) {
196
- return src.startsWith("https://img.plasmic.app");
253
+ return src.startsWith("https://img.plasmic.app") && !isSvg(src);
197
254
  },
198
255
  transformUrl: function (opts) {
199
256
  var _a;