@plasmicapp/react-web 0.2.82 → 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 +16 -0
  2. package/dist/react-web.cjs.development.js +81 -28
  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 +81 -28
  7. package/dist/react-web.esm.js.map +1 -1
  8. package/dist/render/PlasmicImg/index.d.ts +16 -0
  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 +16 -0
  27. package/skinny/dist/render/PlasmicImg/index.js +66 -19
  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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"}
@@ -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,16 +11,18 @@ 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"]);
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
15
  var _a = typeof src === "string" || !src
16
16
  ? { fullWidth: undefined, fullHeight: undefined }
17
17
  : src, fullWidth = _a.fullWidth, fullHeight = _a.fullHeight;
18
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
  }
23
+ if (isSvg(srcStr) && (displayHeight == null || displayHeight === "auto") && (displayWidth == null || displayWidth === "auto")) {
24
+ displayWidth = "100%";
25
+ }
24
26
  if (fullWidth &&
25
27
  fullHeight &&
26
28
  (!displayWidth || displayWidth === "auto") &&
@@ -31,14 +33,61 @@ var PlasmicImg = React__default.forwardRef(function PlasmicImg(props, ref) {
31
33
  // generate better markup!
32
34
  displayWidth = (getPixelLength(displayHeight) * fullWidth) / fullHeight;
33
35
  }
34
- var _b = getWidths(displayWidth, fullWidth), sizes = _b.sizes, widthDescs = _b.widthDescs;
36
+ var _b = getWidths(displayWidth, fullWidth, { minWidth: displayMinWidth }), sizes = _b.sizes, widthDescs = _b.widthDescs;
35
37
  var imageLoader = getImageLoader(loader);
36
38
  var spacerSvg = "<svg width=\"" + fullWidth + "\" height=\"" + fullHeight + "\" xmlns=\"http://www.w3.org/2000/svg\" version=\"1.1\"/>";
37
39
  var spacerSvgBase64 = typeof window === "undefined"
38
40
  ? Buffer.from(spacerSvg).toString("base64")
39
41
  : window.btoa(spacerSvg);
40
- 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 }) },
41
- 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 }),
42
91
  makePicture({
43
92
  imageLoader: imageLoader,
44
93
  widthDescs: widthDescs,
@@ -83,7 +132,10 @@ function makePicture(opts) {
83
132
  }) + " " + wd.desc;
84
133
  })
85
134
  .join(", ")
86
- : undefined, sizes: imageLoader ? sizes : undefined, style: __assign(__assign({}, (style ? pick(style, "objectFit", "objectPosition") : {})), { width: 0, height: 0 }) }))));
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"));
87
139
  }
88
140
  function getClosestPresetSize(width, fullWidth) {
89
141
  var _a;
@@ -108,18 +160,20 @@ function getClosestPresetSize(width, fullWidth) {
108
160
  /**
109
161
  * Computes the appropriate srcSet and sizes to use
110
162
  */
111
- function getWidths(width, fullWidth) {
163
+ function getWidths(width, fullWidth, extra) {
164
+ var minWidth = extra === null || extra === void 0 ? void 0 : extra.minWidth;
112
165
  var pixelWidth = getPixelLength(width);
113
- if (pixelWidth != null) {
166
+ var pixelMinWidth = getPixelLength(minWidth);
167
+ if (pixelWidth != null && (!minWidth || pixelMinWidth != null)) {
114
168
  // If there's an exact width, then we just need to display it at 1x and 2x density
115
169
  return {
116
170
  widthDescs: [
117
171
  {
118
- width: getClosestPresetSize(pixelWidth, fullWidth),
172
+ width: getClosestPresetSize(Math.max(pixelWidth, pixelMinWidth !== null && pixelMinWidth !== void 0 ? pixelMinWidth : 0), fullWidth),
119
173
  desc: "1x",
120
174
  },
121
175
  {
122
- width: getClosestPresetSize(pixelWidth * 2, fullWidth),
176
+ width: getClosestPresetSize(Math.max(pixelWidth, pixelMinWidth !== null && pixelMinWidth !== void 0 ? pixelMinWidth : 0) * 2, fullWidth),
123
177
  desc: "2x",
124
178
  },
125
179
  ],
@@ -160,13 +214,6 @@ function getWidths(width, fullWidth) {
160
214
  sizes: "100vw",
161
215
  };
162
216
  }
163
- function isPercentage(width) {
164
- var _a;
165
- if (typeof width !== "string") {
166
- return false;
167
- }
168
- return ((_a = parseNumeric(width)) === null || _a === void 0 ? void 0 : _a.units) === "%";
169
- }
170
217
  function getPixelLength(length) {
171
218
  if (length == null || length == "") {
172
219
  return undefined;
@@ -203,7 +250,7 @@ function getImageLoader(loader) {
203
250
  }
204
251
  var PLASMIC_IMAGE_LOADER = {
205
252
  supportsUrl: function (src) {
206
- return src.startsWith("https://img.plasmic.app");
253
+ return src.startsWith("https://img.plasmic.app") && !isSvg(src);
207
254
  },
208
255
  transformUrl: function (opts) {
209
256
  var _a;