@tscircuit/schematic-viewer 0.0.1 → 0.0.3

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 (85) hide show
  1. package/dist/Schematic.d.ts +6 -0
  2. package/dist/Schematic.js +1183 -139
  3. package/dist/Schematic.js.map +1 -1
  4. package/dist/index.d.ts +1 -0
  5. package/dist/index.js +9652 -0
  6. package/dist/index.js.map +1 -0
  7. package/dist/lib/hooks/index.d.ts +1 -0
  8. package/dist/lib/hooks/use-maybe-promise.d.ts +3 -0
  9. package/dist/lib/render-context/index.d.ts +10 -0
  10. package/dist/lib/types/core.d.ts +149 -0
  11. package/dist/lib/types/index.d.ts +4 -0
  12. package/dist/lib/types/route-solver.d.ts +24 -0
  13. package/dist/lib/types/source-component.d.ts +44 -0
  14. package/dist/lib/types/util.d.ts +14 -0
  15. package/dist/lib/utils/direction-to-vec.d.ts +13 -0
  16. package/dist/lib/utils/get-svg-path-bounds.d.ts +10 -0
  17. package/dist/lib/utils/point-math.d.ts +20 -0
  18. package/dist/pages/_app.d.ts +5 -0
  19. package/dist/pages/_app.js +950 -8
  20. package/dist/pages/_app.js.map +1 -1
  21. package/dist/pages/index.d.ts +3 -0
  22. package/dist/pages/index.js +1190 -140
  23. package/dist/pages/index.js.map +1 -1
  24. package/dist/pages/led-circuit-react.d.ts +3 -0
  25. package/dist/pages/led-circuit-react.js +7595 -49
  26. package/dist/pages/led-circuit-react.js.map +1 -1
  27. package/dist/pages/led-circuit.d.ts +3 -0
  28. package/dist/pages/led-circuit.js +1195 -140
  29. package/dist/pages/led-circuit.js.map +1 -1
  30. package/dist/schematic-components/MovableGrid/MovableGrid.stories.d.ts +7 -0
  31. package/dist/schematic-components/MovableGrid/MovableGrid.stories.js +3062 -2
  32. package/dist/schematic-components/MovableGrid/MovableGrid.stories.js.map +1 -1
  33. package/dist/schematic-components/MovableGrid/index.d.ts +3 -0
  34. package/dist/schematic-components/MovableGrid/index.js +3058 -1
  35. package/dist/schematic-components/MovableGrid/index.js.map +1 -1
  36. package/dist/schematic-components/ProjectComponent.d.ts +10 -0
  37. package/dist/schematic-components/ProjectComponent.js +1174 -136
  38. package/dist/schematic-components/ProjectComponent.js.map +1 -1
  39. package/dist/schematic-components/RenderError.d.ts +6 -0
  40. package/dist/schematic-components/RenderError.js +3069 -11
  41. package/dist/schematic-components/RenderError.js.map +1 -1
  42. package/dist/schematic-components/SVGPathComponent.d.ts +19 -0
  43. package/dist/schematic-components/SVGPathComponent.js +3067 -6
  44. package/dist/schematic-components/SVGPathComponent.js.map +1 -1
  45. package/dist/schematic-components/SchematicBug.d.ts +13 -0
  46. package/dist/schematic-components/SchematicBug.js +3090 -26
  47. package/dist/schematic-components/SchematicBug.js.map +1 -1
  48. package/dist/schematic-components/SchematicComponent.d.ts +13 -0
  49. package/dist/schematic-components/SchematicComponent.js +1090 -77
  50. package/dist/schematic-components/SchematicComponent.js.map +1 -1
  51. package/dist/schematic-components/SchematicGroup.d.ts +3 -0
  52. package/dist/schematic-components/SchematicPort.d.ts +13 -0
  53. package/dist/schematic-components/SchematicPort.js +997 -18
  54. package/dist/schematic-components/SchematicPort.js.map +1 -1
  55. package/dist/schematic-components/SchematicText.d.ts +10 -0
  56. package/dist/schematic-components/SchematicText.js +3059 -6
  57. package/dist/schematic-components/SchematicText.js.map +1 -1
  58. package/dist/schematic-components/SchematicTrace.d.ts +13 -0
  59. package/dist/schematic-components/SchematicTrace.js +3098 -25
  60. package/dist/schematic-components/SchematicTrace.js.map +1 -1
  61. package/dist/schematic-components/SimpleCapacitor.d.ts +13 -0
  62. package/dist/schematic-components/SimpleCapacitor.js +3079 -12
  63. package/dist/schematic-components/SimpleCapacitor.js.map +1 -1
  64. package/dist/schematic-components/SimpleDiode.d.ts +13 -0
  65. package/dist/schematic-components/SimpleDiode.js +3079 -12
  66. package/dist/schematic-components/SimpleDiode.js.map +1 -1
  67. package/dist/schematic-components/SimpleGround.d.ts +13 -0
  68. package/dist/schematic-components/SimpleGround.js +3080 -13
  69. package/dist/schematic-components/SimpleGround.js.map +1 -1
  70. package/dist/schematic-components/SimpleInductor.d.ts +13 -0
  71. package/dist/schematic-components/SimpleInductor.js +3080 -13
  72. package/dist/schematic-components/SimpleInductor.js.map +1 -1
  73. package/dist/schematic-components/SimplePowerSource.d.ts +13 -0
  74. package/dist/schematic-components/SimplePowerSource.js +3080 -13
  75. package/dist/schematic-components/SimplePowerSource.js.map +1 -1
  76. package/dist/schematic-components/SimpleResistor.d.ts +13 -0
  77. package/dist/schematic-components/SimpleResistor.js +3080 -13
  78. package/dist/schematic-components/SimpleResistor.js.map +1 -1
  79. package/dist/schematic-components/index.d.ts +18 -0
  80. package/dist/schematic-components/index.js +1175 -137
  81. package/dist/schematic-components/index.js.map +1 -1
  82. package/package.json +1 -1
  83. package/src/index.ts +1 -0
  84. package/src/pages/led-circuit.tsx +8 -1
  85. package/tsconfig.json +2 -2
package/dist/Schematic.js CHANGED
@@ -2128,6 +2128,915 @@ var require_react = __commonJS({
2128
2128
  }
2129
2129
  });
2130
2130
 
2131
+ // node_modules/react/cjs/react-jsx-runtime.production.min.js
2132
+ var require_react_jsx_runtime_production_min = __commonJS({
2133
+ "node_modules/react/cjs/react-jsx-runtime.production.min.js"(exports) {
2134
+ "use strict";
2135
+ var f = require_react();
2136
+ var k = Symbol.for("react.element");
2137
+ var l = Symbol.for("react.fragment");
2138
+ var m = Object.prototype.hasOwnProperty;
2139
+ var n = f.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner;
2140
+ var p = { key: true, ref: true, __self: true, __source: true };
2141
+ function q(c, a, g) {
2142
+ var b, d = {}, e = null, h = null;
2143
+ void 0 !== g && (e = "" + g);
2144
+ void 0 !== a.key && (e = "" + a.key);
2145
+ void 0 !== a.ref && (h = a.ref);
2146
+ for (b in a)
2147
+ m.call(a, b) && !p.hasOwnProperty(b) && (d[b] = a[b]);
2148
+ if (c && c.defaultProps)
2149
+ for (b in a = c.defaultProps, a)
2150
+ void 0 === d[b] && (d[b] = a[b]);
2151
+ return { $$typeof: k, type: c, key: e, ref: h, props: d, _owner: n.current };
2152
+ }
2153
+ exports.Fragment = l;
2154
+ exports.jsx = q;
2155
+ exports.jsxs = q;
2156
+ }
2157
+ });
2158
+
2159
+ // node_modules/react/cjs/react-jsx-runtime.development.js
2160
+ var require_react_jsx_runtime_development = __commonJS({
2161
+ "node_modules/react/cjs/react-jsx-runtime.development.js"(exports) {
2162
+ "use strict";
2163
+ if (process.env.NODE_ENV !== "production") {
2164
+ (function() {
2165
+ "use strict";
2166
+ var React = require_react();
2167
+ var REACT_ELEMENT_TYPE = Symbol.for("react.element");
2168
+ var REACT_PORTAL_TYPE = Symbol.for("react.portal");
2169
+ var REACT_FRAGMENT_TYPE = Symbol.for("react.fragment");
2170
+ var REACT_STRICT_MODE_TYPE = Symbol.for("react.strict_mode");
2171
+ var REACT_PROFILER_TYPE = Symbol.for("react.profiler");
2172
+ var REACT_PROVIDER_TYPE = Symbol.for("react.provider");
2173
+ var REACT_CONTEXT_TYPE = Symbol.for("react.context");
2174
+ var REACT_FORWARD_REF_TYPE = Symbol.for("react.forward_ref");
2175
+ var REACT_SUSPENSE_TYPE = Symbol.for("react.suspense");
2176
+ var REACT_SUSPENSE_LIST_TYPE = Symbol.for("react.suspense_list");
2177
+ var REACT_MEMO_TYPE = Symbol.for("react.memo");
2178
+ var REACT_LAZY_TYPE = Symbol.for("react.lazy");
2179
+ var REACT_OFFSCREEN_TYPE = Symbol.for("react.offscreen");
2180
+ var MAYBE_ITERATOR_SYMBOL = Symbol.iterator;
2181
+ var FAUX_ITERATOR_SYMBOL = "@@iterator";
2182
+ function getIteratorFn(maybeIterable) {
2183
+ if (maybeIterable === null || typeof maybeIterable !== "object") {
2184
+ return null;
2185
+ }
2186
+ var maybeIterator = MAYBE_ITERATOR_SYMBOL && maybeIterable[MAYBE_ITERATOR_SYMBOL] || maybeIterable[FAUX_ITERATOR_SYMBOL];
2187
+ if (typeof maybeIterator === "function") {
2188
+ return maybeIterator;
2189
+ }
2190
+ return null;
2191
+ }
2192
+ var ReactSharedInternals = React.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED;
2193
+ function error(format) {
2194
+ {
2195
+ {
2196
+ for (var _len2 = arguments.length, args = new Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++) {
2197
+ args[_key2 - 1] = arguments[_key2];
2198
+ }
2199
+ printWarning("error", format, args);
2200
+ }
2201
+ }
2202
+ }
2203
+ function printWarning(level, format, args) {
2204
+ {
2205
+ var ReactDebugCurrentFrame2 = ReactSharedInternals.ReactDebugCurrentFrame;
2206
+ var stack = ReactDebugCurrentFrame2.getStackAddendum();
2207
+ if (stack !== "") {
2208
+ format += "%s";
2209
+ args = args.concat([stack]);
2210
+ }
2211
+ var argsWithFormat = args.map(function(item) {
2212
+ return String(item);
2213
+ });
2214
+ argsWithFormat.unshift("Warning: " + format);
2215
+ Function.prototype.apply.call(console[level], console, argsWithFormat);
2216
+ }
2217
+ }
2218
+ var enableScopeAPI = false;
2219
+ var enableCacheElement = false;
2220
+ var enableTransitionTracing = false;
2221
+ var enableLegacyHidden = false;
2222
+ var enableDebugTracing = false;
2223
+ var REACT_MODULE_REFERENCE;
2224
+ {
2225
+ REACT_MODULE_REFERENCE = Symbol.for("react.module.reference");
2226
+ }
2227
+ function isValidElementType(type) {
2228
+ if (typeof type === "string" || typeof type === "function") {
2229
+ return true;
2230
+ }
2231
+ if (type === REACT_FRAGMENT_TYPE || type === REACT_PROFILER_TYPE || enableDebugTracing || type === REACT_STRICT_MODE_TYPE || type === REACT_SUSPENSE_TYPE || type === REACT_SUSPENSE_LIST_TYPE || enableLegacyHidden || type === REACT_OFFSCREEN_TYPE || enableScopeAPI || enableCacheElement || enableTransitionTracing) {
2232
+ return true;
2233
+ }
2234
+ if (typeof type === "object" && type !== null) {
2235
+ if (type.$$typeof === REACT_LAZY_TYPE || type.$$typeof === REACT_MEMO_TYPE || type.$$typeof === REACT_PROVIDER_TYPE || type.$$typeof === REACT_CONTEXT_TYPE || type.$$typeof === REACT_FORWARD_REF_TYPE || type.$$typeof === REACT_MODULE_REFERENCE || type.getModuleId !== void 0) {
2236
+ return true;
2237
+ }
2238
+ }
2239
+ return false;
2240
+ }
2241
+ function getWrappedName(outerType, innerType, wrapperName) {
2242
+ var displayName = outerType.displayName;
2243
+ if (displayName) {
2244
+ return displayName;
2245
+ }
2246
+ var functionName = innerType.displayName || innerType.name || "";
2247
+ return functionName !== "" ? wrapperName + "(" + functionName + ")" : wrapperName;
2248
+ }
2249
+ function getContextName(type) {
2250
+ return type.displayName || "Context";
2251
+ }
2252
+ function getComponentNameFromType(type) {
2253
+ if (type == null) {
2254
+ return null;
2255
+ }
2256
+ {
2257
+ if (typeof type.tag === "number") {
2258
+ error("Received an unexpected object in getComponentNameFromType(). This is likely a bug in React. Please file an issue.");
2259
+ }
2260
+ }
2261
+ if (typeof type === "function") {
2262
+ return type.displayName || type.name || null;
2263
+ }
2264
+ if (typeof type === "string") {
2265
+ return type;
2266
+ }
2267
+ switch (type) {
2268
+ case REACT_FRAGMENT_TYPE:
2269
+ return "Fragment";
2270
+ case REACT_PORTAL_TYPE:
2271
+ return "Portal";
2272
+ case REACT_PROFILER_TYPE:
2273
+ return "Profiler";
2274
+ case REACT_STRICT_MODE_TYPE:
2275
+ return "StrictMode";
2276
+ case REACT_SUSPENSE_TYPE:
2277
+ return "Suspense";
2278
+ case REACT_SUSPENSE_LIST_TYPE:
2279
+ return "SuspenseList";
2280
+ }
2281
+ if (typeof type === "object") {
2282
+ switch (type.$$typeof) {
2283
+ case REACT_CONTEXT_TYPE:
2284
+ var context = type;
2285
+ return getContextName(context) + ".Consumer";
2286
+ case REACT_PROVIDER_TYPE:
2287
+ var provider = type;
2288
+ return getContextName(provider._context) + ".Provider";
2289
+ case REACT_FORWARD_REF_TYPE:
2290
+ return getWrappedName(type, type.render, "ForwardRef");
2291
+ case REACT_MEMO_TYPE:
2292
+ var outerName = type.displayName || null;
2293
+ if (outerName !== null) {
2294
+ return outerName;
2295
+ }
2296
+ return getComponentNameFromType(type.type) || "Memo";
2297
+ case REACT_LAZY_TYPE: {
2298
+ var lazyComponent = type;
2299
+ var payload = lazyComponent._payload;
2300
+ var init = lazyComponent._init;
2301
+ try {
2302
+ return getComponentNameFromType(init(payload));
2303
+ } catch (x) {
2304
+ return null;
2305
+ }
2306
+ }
2307
+ }
2308
+ }
2309
+ return null;
2310
+ }
2311
+ var assign = Object.assign;
2312
+ var disabledDepth = 0;
2313
+ var prevLog;
2314
+ var prevInfo;
2315
+ var prevWarn;
2316
+ var prevError;
2317
+ var prevGroup;
2318
+ var prevGroupCollapsed;
2319
+ var prevGroupEnd;
2320
+ function disabledLog() {
2321
+ }
2322
+ disabledLog.__reactDisabledLog = true;
2323
+ function disableLogs() {
2324
+ {
2325
+ if (disabledDepth === 0) {
2326
+ prevLog = console.log;
2327
+ prevInfo = console.info;
2328
+ prevWarn = console.warn;
2329
+ prevError = console.error;
2330
+ prevGroup = console.group;
2331
+ prevGroupCollapsed = console.groupCollapsed;
2332
+ prevGroupEnd = console.groupEnd;
2333
+ var props = {
2334
+ configurable: true,
2335
+ enumerable: true,
2336
+ value: disabledLog,
2337
+ writable: true
2338
+ };
2339
+ Object.defineProperties(console, {
2340
+ info: props,
2341
+ log: props,
2342
+ warn: props,
2343
+ error: props,
2344
+ group: props,
2345
+ groupCollapsed: props,
2346
+ groupEnd: props
2347
+ });
2348
+ }
2349
+ disabledDepth++;
2350
+ }
2351
+ }
2352
+ function reenableLogs() {
2353
+ {
2354
+ disabledDepth--;
2355
+ if (disabledDepth === 0) {
2356
+ var props = {
2357
+ configurable: true,
2358
+ enumerable: true,
2359
+ writable: true
2360
+ };
2361
+ Object.defineProperties(console, {
2362
+ log: assign({}, props, {
2363
+ value: prevLog
2364
+ }),
2365
+ info: assign({}, props, {
2366
+ value: prevInfo
2367
+ }),
2368
+ warn: assign({}, props, {
2369
+ value: prevWarn
2370
+ }),
2371
+ error: assign({}, props, {
2372
+ value: prevError
2373
+ }),
2374
+ group: assign({}, props, {
2375
+ value: prevGroup
2376
+ }),
2377
+ groupCollapsed: assign({}, props, {
2378
+ value: prevGroupCollapsed
2379
+ }),
2380
+ groupEnd: assign({}, props, {
2381
+ value: prevGroupEnd
2382
+ })
2383
+ });
2384
+ }
2385
+ if (disabledDepth < 0) {
2386
+ error("disabledDepth fell below zero. This is a bug in React. Please file an issue.");
2387
+ }
2388
+ }
2389
+ }
2390
+ var ReactCurrentDispatcher = ReactSharedInternals.ReactCurrentDispatcher;
2391
+ var prefix;
2392
+ function describeBuiltInComponentFrame(name, source, ownerFn) {
2393
+ {
2394
+ if (prefix === void 0) {
2395
+ try {
2396
+ throw Error();
2397
+ } catch (x) {
2398
+ var match = x.stack.trim().match(/\n( *(at )?)/);
2399
+ prefix = match && match[1] || "";
2400
+ }
2401
+ }
2402
+ return "\n" + prefix + name;
2403
+ }
2404
+ }
2405
+ var reentry = false;
2406
+ var componentFrameCache;
2407
+ {
2408
+ var PossiblyWeakMap = typeof WeakMap === "function" ? WeakMap : Map;
2409
+ componentFrameCache = new PossiblyWeakMap();
2410
+ }
2411
+ function describeNativeComponentFrame(fn, construct) {
2412
+ if (!fn || reentry) {
2413
+ return "";
2414
+ }
2415
+ {
2416
+ var frame = componentFrameCache.get(fn);
2417
+ if (frame !== void 0) {
2418
+ return frame;
2419
+ }
2420
+ }
2421
+ var control;
2422
+ reentry = true;
2423
+ var previousPrepareStackTrace = Error.prepareStackTrace;
2424
+ Error.prepareStackTrace = void 0;
2425
+ var previousDispatcher;
2426
+ {
2427
+ previousDispatcher = ReactCurrentDispatcher.current;
2428
+ ReactCurrentDispatcher.current = null;
2429
+ disableLogs();
2430
+ }
2431
+ try {
2432
+ if (construct) {
2433
+ var Fake = function() {
2434
+ throw Error();
2435
+ };
2436
+ Object.defineProperty(Fake.prototype, "props", {
2437
+ set: function() {
2438
+ throw Error();
2439
+ }
2440
+ });
2441
+ if (typeof Reflect === "object" && Reflect.construct) {
2442
+ try {
2443
+ Reflect.construct(Fake, []);
2444
+ } catch (x) {
2445
+ control = x;
2446
+ }
2447
+ Reflect.construct(fn, [], Fake);
2448
+ } else {
2449
+ try {
2450
+ Fake.call();
2451
+ } catch (x) {
2452
+ control = x;
2453
+ }
2454
+ fn.call(Fake.prototype);
2455
+ }
2456
+ } else {
2457
+ try {
2458
+ throw Error();
2459
+ } catch (x) {
2460
+ control = x;
2461
+ }
2462
+ fn();
2463
+ }
2464
+ } catch (sample) {
2465
+ if (sample && control && typeof sample.stack === "string") {
2466
+ var sampleLines = sample.stack.split("\n");
2467
+ var controlLines = control.stack.split("\n");
2468
+ var s = sampleLines.length - 1;
2469
+ var c = controlLines.length - 1;
2470
+ while (s >= 1 && c >= 0 && sampleLines[s] !== controlLines[c]) {
2471
+ c--;
2472
+ }
2473
+ for (; s >= 1 && c >= 0; s--, c--) {
2474
+ if (sampleLines[s] !== controlLines[c]) {
2475
+ if (s !== 1 || c !== 1) {
2476
+ do {
2477
+ s--;
2478
+ c--;
2479
+ if (c < 0 || sampleLines[s] !== controlLines[c]) {
2480
+ var _frame = "\n" + sampleLines[s].replace(" at new ", " at ");
2481
+ if (fn.displayName && _frame.includes("<anonymous>")) {
2482
+ _frame = _frame.replace("<anonymous>", fn.displayName);
2483
+ }
2484
+ {
2485
+ if (typeof fn === "function") {
2486
+ componentFrameCache.set(fn, _frame);
2487
+ }
2488
+ }
2489
+ return _frame;
2490
+ }
2491
+ } while (s >= 1 && c >= 0);
2492
+ }
2493
+ break;
2494
+ }
2495
+ }
2496
+ }
2497
+ } finally {
2498
+ reentry = false;
2499
+ {
2500
+ ReactCurrentDispatcher.current = previousDispatcher;
2501
+ reenableLogs();
2502
+ }
2503
+ Error.prepareStackTrace = previousPrepareStackTrace;
2504
+ }
2505
+ var name = fn ? fn.displayName || fn.name : "";
2506
+ var syntheticFrame = name ? describeBuiltInComponentFrame(name) : "";
2507
+ {
2508
+ if (typeof fn === "function") {
2509
+ componentFrameCache.set(fn, syntheticFrame);
2510
+ }
2511
+ }
2512
+ return syntheticFrame;
2513
+ }
2514
+ function describeFunctionComponentFrame(fn, source, ownerFn) {
2515
+ {
2516
+ return describeNativeComponentFrame(fn, false);
2517
+ }
2518
+ }
2519
+ function shouldConstruct(Component) {
2520
+ var prototype = Component.prototype;
2521
+ return !!(prototype && prototype.isReactComponent);
2522
+ }
2523
+ function describeUnknownElementTypeFrameInDEV(type, source, ownerFn) {
2524
+ if (type == null) {
2525
+ return "";
2526
+ }
2527
+ if (typeof type === "function") {
2528
+ {
2529
+ return describeNativeComponentFrame(type, shouldConstruct(type));
2530
+ }
2531
+ }
2532
+ if (typeof type === "string") {
2533
+ return describeBuiltInComponentFrame(type);
2534
+ }
2535
+ switch (type) {
2536
+ case REACT_SUSPENSE_TYPE:
2537
+ return describeBuiltInComponentFrame("Suspense");
2538
+ case REACT_SUSPENSE_LIST_TYPE:
2539
+ return describeBuiltInComponentFrame("SuspenseList");
2540
+ }
2541
+ if (typeof type === "object") {
2542
+ switch (type.$$typeof) {
2543
+ case REACT_FORWARD_REF_TYPE:
2544
+ return describeFunctionComponentFrame(type.render);
2545
+ case REACT_MEMO_TYPE:
2546
+ return describeUnknownElementTypeFrameInDEV(type.type, source, ownerFn);
2547
+ case REACT_LAZY_TYPE: {
2548
+ var lazyComponent = type;
2549
+ var payload = lazyComponent._payload;
2550
+ var init = lazyComponent._init;
2551
+ try {
2552
+ return describeUnknownElementTypeFrameInDEV(init(payload), source, ownerFn);
2553
+ } catch (x) {
2554
+ }
2555
+ }
2556
+ }
2557
+ }
2558
+ return "";
2559
+ }
2560
+ var hasOwnProperty = Object.prototype.hasOwnProperty;
2561
+ var loggedTypeFailures = {};
2562
+ var ReactDebugCurrentFrame = ReactSharedInternals.ReactDebugCurrentFrame;
2563
+ function setCurrentlyValidatingElement(element) {
2564
+ {
2565
+ if (element) {
2566
+ var owner = element._owner;
2567
+ var stack = describeUnknownElementTypeFrameInDEV(element.type, element._source, owner ? owner.type : null);
2568
+ ReactDebugCurrentFrame.setExtraStackFrame(stack);
2569
+ } else {
2570
+ ReactDebugCurrentFrame.setExtraStackFrame(null);
2571
+ }
2572
+ }
2573
+ }
2574
+ function checkPropTypes(typeSpecs, values, location, componentName, element) {
2575
+ {
2576
+ var has = Function.call.bind(hasOwnProperty);
2577
+ for (var typeSpecName in typeSpecs) {
2578
+ if (has(typeSpecs, typeSpecName)) {
2579
+ var error$1 = void 0;
2580
+ try {
2581
+ if (typeof typeSpecs[typeSpecName] !== "function") {
2582
+ var err = Error((componentName || "React class") + ": " + location + " type `" + typeSpecName + "` is invalid; it must be a function, usually from the `prop-types` package, but received `" + typeof typeSpecs[typeSpecName] + "`.This often happens because of typos such as `PropTypes.function` instead of `PropTypes.func`.");
2583
+ err.name = "Invariant Violation";
2584
+ throw err;
2585
+ }
2586
+ error$1 = typeSpecs[typeSpecName](values, typeSpecName, componentName, location, null, "SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED");
2587
+ } catch (ex) {
2588
+ error$1 = ex;
2589
+ }
2590
+ if (error$1 && !(error$1 instanceof Error)) {
2591
+ setCurrentlyValidatingElement(element);
2592
+ error("%s: type specification of %s `%s` is invalid; the type checker function must return `null` or an `Error` but returned a %s. You may have forgotten to pass an argument to the type checker creator (arrayOf, instanceOf, objectOf, oneOf, oneOfType, and shape all require an argument).", componentName || "React class", location, typeSpecName, typeof error$1);
2593
+ setCurrentlyValidatingElement(null);
2594
+ }
2595
+ if (error$1 instanceof Error && !(error$1.message in loggedTypeFailures)) {
2596
+ loggedTypeFailures[error$1.message] = true;
2597
+ setCurrentlyValidatingElement(element);
2598
+ error("Failed %s type: %s", location, error$1.message);
2599
+ setCurrentlyValidatingElement(null);
2600
+ }
2601
+ }
2602
+ }
2603
+ }
2604
+ }
2605
+ var isArrayImpl = Array.isArray;
2606
+ function isArray(a) {
2607
+ return isArrayImpl(a);
2608
+ }
2609
+ function typeName(value) {
2610
+ {
2611
+ var hasToStringTag = typeof Symbol === "function" && Symbol.toStringTag;
2612
+ var type = hasToStringTag && value[Symbol.toStringTag] || value.constructor.name || "Object";
2613
+ return type;
2614
+ }
2615
+ }
2616
+ function willCoercionThrow(value) {
2617
+ {
2618
+ try {
2619
+ testStringCoercion(value);
2620
+ return false;
2621
+ } catch (e) {
2622
+ return true;
2623
+ }
2624
+ }
2625
+ }
2626
+ function testStringCoercion(value) {
2627
+ return "" + value;
2628
+ }
2629
+ function checkKeyStringCoercion(value) {
2630
+ {
2631
+ if (willCoercionThrow(value)) {
2632
+ error("The provided key is an unsupported type %s. This value must be coerced to a string before before using it here.", typeName(value));
2633
+ return testStringCoercion(value);
2634
+ }
2635
+ }
2636
+ }
2637
+ var ReactCurrentOwner = ReactSharedInternals.ReactCurrentOwner;
2638
+ var RESERVED_PROPS = {
2639
+ key: true,
2640
+ ref: true,
2641
+ __self: true,
2642
+ __source: true
2643
+ };
2644
+ var specialPropKeyWarningShown;
2645
+ var specialPropRefWarningShown;
2646
+ var didWarnAboutStringRefs;
2647
+ {
2648
+ didWarnAboutStringRefs = {};
2649
+ }
2650
+ function hasValidRef(config) {
2651
+ {
2652
+ if (hasOwnProperty.call(config, "ref")) {
2653
+ var getter = Object.getOwnPropertyDescriptor(config, "ref").get;
2654
+ if (getter && getter.isReactWarning) {
2655
+ return false;
2656
+ }
2657
+ }
2658
+ }
2659
+ return config.ref !== void 0;
2660
+ }
2661
+ function hasValidKey(config) {
2662
+ {
2663
+ if (hasOwnProperty.call(config, "key")) {
2664
+ var getter = Object.getOwnPropertyDescriptor(config, "key").get;
2665
+ if (getter && getter.isReactWarning) {
2666
+ return false;
2667
+ }
2668
+ }
2669
+ }
2670
+ return config.key !== void 0;
2671
+ }
2672
+ function warnIfStringRefCannotBeAutoConverted(config, self2) {
2673
+ {
2674
+ if (typeof config.ref === "string" && ReactCurrentOwner.current && self2 && ReactCurrentOwner.current.stateNode !== self2) {
2675
+ var componentName = getComponentNameFromType(ReactCurrentOwner.current.type);
2676
+ if (!didWarnAboutStringRefs[componentName]) {
2677
+ error('Component "%s" contains the string ref "%s". Support for string refs will be removed in a future major release. This case cannot be automatically converted to an arrow function. We ask you to manually fix this case by using useRef() or createRef() instead. Learn more about using refs safely here: https://reactjs.org/link/strict-mode-string-ref', getComponentNameFromType(ReactCurrentOwner.current.type), config.ref);
2678
+ didWarnAboutStringRefs[componentName] = true;
2679
+ }
2680
+ }
2681
+ }
2682
+ }
2683
+ function defineKeyPropWarningGetter(props, displayName) {
2684
+ {
2685
+ var warnAboutAccessingKey = function() {
2686
+ if (!specialPropKeyWarningShown) {
2687
+ specialPropKeyWarningShown = true;
2688
+ error("%s: `key` is not a prop. Trying to access it will result in `undefined` being returned. If you need to access the same value within the child component, you should pass it as a different prop. (https://reactjs.org/link/special-props)", displayName);
2689
+ }
2690
+ };
2691
+ warnAboutAccessingKey.isReactWarning = true;
2692
+ Object.defineProperty(props, "key", {
2693
+ get: warnAboutAccessingKey,
2694
+ configurable: true
2695
+ });
2696
+ }
2697
+ }
2698
+ function defineRefPropWarningGetter(props, displayName) {
2699
+ {
2700
+ var warnAboutAccessingRef = function() {
2701
+ if (!specialPropRefWarningShown) {
2702
+ specialPropRefWarningShown = true;
2703
+ error("%s: `ref` is not a prop. Trying to access it will result in `undefined` being returned. If you need to access the same value within the child component, you should pass it as a different prop. (https://reactjs.org/link/special-props)", displayName);
2704
+ }
2705
+ };
2706
+ warnAboutAccessingRef.isReactWarning = true;
2707
+ Object.defineProperty(props, "ref", {
2708
+ get: warnAboutAccessingRef,
2709
+ configurable: true
2710
+ });
2711
+ }
2712
+ }
2713
+ var ReactElement = function(type, key, ref, self2, source, owner, props) {
2714
+ var element = {
2715
+ $$typeof: REACT_ELEMENT_TYPE,
2716
+ type,
2717
+ key,
2718
+ ref,
2719
+ props,
2720
+ _owner: owner
2721
+ };
2722
+ {
2723
+ element._store = {};
2724
+ Object.defineProperty(element._store, "validated", {
2725
+ configurable: false,
2726
+ enumerable: false,
2727
+ writable: true,
2728
+ value: false
2729
+ });
2730
+ Object.defineProperty(element, "_self", {
2731
+ configurable: false,
2732
+ enumerable: false,
2733
+ writable: false,
2734
+ value: self2
2735
+ });
2736
+ Object.defineProperty(element, "_source", {
2737
+ configurable: false,
2738
+ enumerable: false,
2739
+ writable: false,
2740
+ value: source
2741
+ });
2742
+ if (Object.freeze) {
2743
+ Object.freeze(element.props);
2744
+ Object.freeze(element);
2745
+ }
2746
+ }
2747
+ return element;
2748
+ };
2749
+ function jsxDEV(type, config, maybeKey, source, self2) {
2750
+ {
2751
+ var propName;
2752
+ var props = {};
2753
+ var key = null;
2754
+ var ref = null;
2755
+ if (maybeKey !== void 0) {
2756
+ {
2757
+ checkKeyStringCoercion(maybeKey);
2758
+ }
2759
+ key = "" + maybeKey;
2760
+ }
2761
+ if (hasValidKey(config)) {
2762
+ {
2763
+ checkKeyStringCoercion(config.key);
2764
+ }
2765
+ key = "" + config.key;
2766
+ }
2767
+ if (hasValidRef(config)) {
2768
+ ref = config.ref;
2769
+ warnIfStringRefCannotBeAutoConverted(config, self2);
2770
+ }
2771
+ for (propName in config) {
2772
+ if (hasOwnProperty.call(config, propName) && !RESERVED_PROPS.hasOwnProperty(propName)) {
2773
+ props[propName] = config[propName];
2774
+ }
2775
+ }
2776
+ if (type && type.defaultProps) {
2777
+ var defaultProps = type.defaultProps;
2778
+ for (propName in defaultProps) {
2779
+ if (props[propName] === void 0) {
2780
+ props[propName] = defaultProps[propName];
2781
+ }
2782
+ }
2783
+ }
2784
+ if (key || ref) {
2785
+ var displayName = typeof type === "function" ? type.displayName || type.name || "Unknown" : type;
2786
+ if (key) {
2787
+ defineKeyPropWarningGetter(props, displayName);
2788
+ }
2789
+ if (ref) {
2790
+ defineRefPropWarningGetter(props, displayName);
2791
+ }
2792
+ }
2793
+ return ReactElement(type, key, ref, self2, source, ReactCurrentOwner.current, props);
2794
+ }
2795
+ }
2796
+ var ReactCurrentOwner$1 = ReactSharedInternals.ReactCurrentOwner;
2797
+ var ReactDebugCurrentFrame$1 = ReactSharedInternals.ReactDebugCurrentFrame;
2798
+ function setCurrentlyValidatingElement$1(element) {
2799
+ {
2800
+ if (element) {
2801
+ var owner = element._owner;
2802
+ var stack = describeUnknownElementTypeFrameInDEV(element.type, element._source, owner ? owner.type : null);
2803
+ ReactDebugCurrentFrame$1.setExtraStackFrame(stack);
2804
+ } else {
2805
+ ReactDebugCurrentFrame$1.setExtraStackFrame(null);
2806
+ }
2807
+ }
2808
+ }
2809
+ var propTypesMisspellWarningShown;
2810
+ {
2811
+ propTypesMisspellWarningShown = false;
2812
+ }
2813
+ function isValidElement(object) {
2814
+ {
2815
+ return typeof object === "object" && object !== null && object.$$typeof === REACT_ELEMENT_TYPE;
2816
+ }
2817
+ }
2818
+ function getDeclarationErrorAddendum() {
2819
+ {
2820
+ if (ReactCurrentOwner$1.current) {
2821
+ var name = getComponentNameFromType(ReactCurrentOwner$1.current.type);
2822
+ if (name) {
2823
+ return "\n\nCheck the render method of `" + name + "`.";
2824
+ }
2825
+ }
2826
+ return "";
2827
+ }
2828
+ }
2829
+ function getSourceInfoErrorAddendum(source) {
2830
+ {
2831
+ if (source !== void 0) {
2832
+ var fileName = source.fileName.replace(/^.*[\\\/]/, "");
2833
+ var lineNumber = source.lineNumber;
2834
+ return "\n\nCheck your code at " + fileName + ":" + lineNumber + ".";
2835
+ }
2836
+ return "";
2837
+ }
2838
+ }
2839
+ var ownerHasKeyUseWarning = {};
2840
+ function getCurrentComponentErrorInfo(parentType) {
2841
+ {
2842
+ var info = getDeclarationErrorAddendum();
2843
+ if (!info) {
2844
+ var parentName = typeof parentType === "string" ? parentType : parentType.displayName || parentType.name;
2845
+ if (parentName) {
2846
+ info = "\n\nCheck the top-level render call using <" + parentName + ">.";
2847
+ }
2848
+ }
2849
+ return info;
2850
+ }
2851
+ }
2852
+ function validateExplicitKey(element, parentType) {
2853
+ {
2854
+ if (!element._store || element._store.validated || element.key != null) {
2855
+ return;
2856
+ }
2857
+ element._store.validated = true;
2858
+ var currentComponentErrorInfo = getCurrentComponentErrorInfo(parentType);
2859
+ if (ownerHasKeyUseWarning[currentComponentErrorInfo]) {
2860
+ return;
2861
+ }
2862
+ ownerHasKeyUseWarning[currentComponentErrorInfo] = true;
2863
+ var childOwner = "";
2864
+ if (element && element._owner && element._owner !== ReactCurrentOwner$1.current) {
2865
+ childOwner = " It was passed a child from " + getComponentNameFromType(element._owner.type) + ".";
2866
+ }
2867
+ setCurrentlyValidatingElement$1(element);
2868
+ error('Each child in a list should have a unique "key" prop.%s%s See https://reactjs.org/link/warning-keys for more information.', currentComponentErrorInfo, childOwner);
2869
+ setCurrentlyValidatingElement$1(null);
2870
+ }
2871
+ }
2872
+ function validateChildKeys(node, parentType) {
2873
+ {
2874
+ if (typeof node !== "object") {
2875
+ return;
2876
+ }
2877
+ if (isArray(node)) {
2878
+ for (var i = 0; i < node.length; i++) {
2879
+ var child = node[i];
2880
+ if (isValidElement(child)) {
2881
+ validateExplicitKey(child, parentType);
2882
+ }
2883
+ }
2884
+ } else if (isValidElement(node)) {
2885
+ if (node._store) {
2886
+ node._store.validated = true;
2887
+ }
2888
+ } else if (node) {
2889
+ var iteratorFn = getIteratorFn(node);
2890
+ if (typeof iteratorFn === "function") {
2891
+ if (iteratorFn !== node.entries) {
2892
+ var iterator = iteratorFn.call(node);
2893
+ var step;
2894
+ while (!(step = iterator.next()).done) {
2895
+ if (isValidElement(step.value)) {
2896
+ validateExplicitKey(step.value, parentType);
2897
+ }
2898
+ }
2899
+ }
2900
+ }
2901
+ }
2902
+ }
2903
+ }
2904
+ function validatePropTypes(element) {
2905
+ {
2906
+ var type = element.type;
2907
+ if (type === null || type === void 0 || typeof type === "string") {
2908
+ return;
2909
+ }
2910
+ var propTypes;
2911
+ if (typeof type === "function") {
2912
+ propTypes = type.propTypes;
2913
+ } else if (typeof type === "object" && (type.$$typeof === REACT_FORWARD_REF_TYPE || type.$$typeof === REACT_MEMO_TYPE)) {
2914
+ propTypes = type.propTypes;
2915
+ } else {
2916
+ return;
2917
+ }
2918
+ if (propTypes) {
2919
+ var name = getComponentNameFromType(type);
2920
+ checkPropTypes(propTypes, element.props, "prop", name, element);
2921
+ } else if (type.PropTypes !== void 0 && !propTypesMisspellWarningShown) {
2922
+ propTypesMisspellWarningShown = true;
2923
+ var _name = getComponentNameFromType(type);
2924
+ error("Component %s declared `PropTypes` instead of `propTypes`. Did you misspell the property assignment?", _name || "Unknown");
2925
+ }
2926
+ if (typeof type.getDefaultProps === "function" && !type.getDefaultProps.isReactClassApproved) {
2927
+ error("getDefaultProps is only used on classic React.createClass definitions. Use a static property named `defaultProps` instead.");
2928
+ }
2929
+ }
2930
+ }
2931
+ function validateFragmentProps(fragment) {
2932
+ {
2933
+ var keys = Object.keys(fragment.props);
2934
+ for (var i = 0; i < keys.length; i++) {
2935
+ var key = keys[i];
2936
+ if (key !== "children" && key !== "key") {
2937
+ setCurrentlyValidatingElement$1(fragment);
2938
+ error("Invalid prop `%s` supplied to `React.Fragment`. React.Fragment can only have `key` and `children` props.", key);
2939
+ setCurrentlyValidatingElement$1(null);
2940
+ break;
2941
+ }
2942
+ }
2943
+ if (fragment.ref !== null) {
2944
+ setCurrentlyValidatingElement$1(fragment);
2945
+ error("Invalid attribute `ref` supplied to `React.Fragment`.");
2946
+ setCurrentlyValidatingElement$1(null);
2947
+ }
2948
+ }
2949
+ }
2950
+ function jsxWithValidation(type, props, key, isStaticChildren, source, self2) {
2951
+ {
2952
+ var validType = isValidElementType(type);
2953
+ if (!validType) {
2954
+ var info = "";
2955
+ if (type === void 0 || typeof type === "object" && type !== null && Object.keys(type).length === 0) {
2956
+ info += " You likely forgot to export your component from the file it's defined in, or you might have mixed up default and named imports.";
2957
+ }
2958
+ var sourceInfo = getSourceInfoErrorAddendum(source);
2959
+ if (sourceInfo) {
2960
+ info += sourceInfo;
2961
+ } else {
2962
+ info += getDeclarationErrorAddendum();
2963
+ }
2964
+ var typeString;
2965
+ if (type === null) {
2966
+ typeString = "null";
2967
+ } else if (isArray(type)) {
2968
+ typeString = "array";
2969
+ } else if (type !== void 0 && type.$$typeof === REACT_ELEMENT_TYPE) {
2970
+ typeString = "<" + (getComponentNameFromType(type.type) || "Unknown") + " />";
2971
+ info = " Did you accidentally export a JSX literal instead of a component?";
2972
+ } else {
2973
+ typeString = typeof type;
2974
+ }
2975
+ error("React.jsx: type is invalid -- expected a string (for built-in components) or a class/function (for composite components) but got: %s.%s", typeString, info);
2976
+ }
2977
+ var element = jsxDEV(type, props, key, source, self2);
2978
+ if (element == null) {
2979
+ return element;
2980
+ }
2981
+ if (validType) {
2982
+ var children = props.children;
2983
+ if (children !== void 0) {
2984
+ if (isStaticChildren) {
2985
+ if (isArray(children)) {
2986
+ for (var i = 0; i < children.length; i++) {
2987
+ validateChildKeys(children[i], type);
2988
+ }
2989
+ if (Object.freeze) {
2990
+ Object.freeze(children);
2991
+ }
2992
+ } else {
2993
+ error("React.jsx: Static children should always be an array. You are likely explicitly calling React.jsxs or React.jsxDEV. Use the Babel transform instead.");
2994
+ }
2995
+ } else {
2996
+ validateChildKeys(children, type);
2997
+ }
2998
+ }
2999
+ }
3000
+ if (type === REACT_FRAGMENT_TYPE) {
3001
+ validateFragmentProps(element);
3002
+ } else {
3003
+ validatePropTypes(element);
3004
+ }
3005
+ return element;
3006
+ }
3007
+ }
3008
+ function jsxWithValidationStatic(type, props, key) {
3009
+ {
3010
+ return jsxWithValidation(type, props, key, true);
3011
+ }
3012
+ }
3013
+ function jsxWithValidationDynamic(type, props, key) {
3014
+ {
3015
+ return jsxWithValidation(type, props, key, false);
3016
+ }
3017
+ }
3018
+ var jsx17 = jsxWithValidationDynamic;
3019
+ var jsxs3 = jsxWithValidationStatic;
3020
+ exports.Fragment = REACT_FRAGMENT_TYPE;
3021
+ exports.jsx = jsx17;
3022
+ exports.jsxs = jsxs3;
3023
+ })();
3024
+ }
3025
+ }
3026
+ });
3027
+
3028
+ // node_modules/react/jsx-runtime.js
3029
+ var require_jsx_runtime = __commonJS({
3030
+ "node_modules/react/jsx-runtime.js"(exports, module2) {
3031
+ "use strict";
3032
+ if (process.env.NODE_ENV === "production") {
3033
+ module2.exports = require_react_jsx_runtime_production_min();
3034
+ } else {
3035
+ module2.exports = require_react_jsx_runtime_development();
3036
+ }
3037
+ }
3038
+ });
3039
+
2131
3040
  // node_modules/lodash._objecttypes/index.js
2132
3041
  var require_lodash = __commonJS({
2133
3042
  "node_modules/lodash._objecttypes/index.js"(exports, module2) {
@@ -8224,6 +9133,9 @@ __export(Schematic_exports, {
8224
9133
  module.exports = __toCommonJS(Schematic_exports);
8225
9134
  var import_react2 = __toESM(require_react());
8226
9135
 
9136
+ // src/schematic-components/MovableGrid/index.tsx
9137
+ var import_jsx_runtime = __toESM(require_jsx_runtime());
9138
+
8227
9139
  // src/lib/render-context/index.ts
8228
9140
  var import_zustand = __toESM(require("zustand"));
8229
9141
  var import_transformation_matrix = require("transformation-matrix");
@@ -8253,6 +9165,7 @@ var get_svg_path_bounds_default = getSVGPathBounds;
8253
9165
 
8254
9166
  // src/schematic-components/SVGPathComponent.tsx
8255
9167
  var import_transformation_matrix2 = require("transformation-matrix");
9168
+ var import_jsx_runtime2 = __toESM(require_jsx_runtime());
8256
9169
  var SVGPathComponent = ({ size, center, rotation, paths }) => {
8257
9170
  const ct = useCameraTransform();
8258
9171
  const pathBounds = get_svg_path_bounds_default(paths.map((p) => p.d));
@@ -8269,36 +9182,60 @@ var SVGPathComponent = ({ size, center, rotation, paths }) => {
8269
9182
  width: Math.max(1, size.width * ct.a),
8270
9183
  height: Math.max(1, size.height * ct.d)
8271
9184
  };
8272
- return <svg style={{
8273
- position: "absolute",
8274
- transform: rotation === 0 ? "" : `rotate(${rotation}rad)`,
8275
- left: absoluteCenter.x - absoluteSize.width / 2,
8276
- top: absoluteCenter.y - absoluteSize.height / 2
8277
- }} overflow="visible" width={absoluteSize.width} height={absoluteSize.height} viewBox={`${pathBounds.minX} ${pathBounds.minY} ${pathBounds.width} ${pathBounds.height}`}>{paths.map((p, i) => <path key={i} fill="none" strokeWidth={2 * (p.strokeWidth || 1)} stroke={p.stroke || "red"} d={p.d} />)}</svg>;
9185
+ return /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("svg", {
9186
+ style: {
9187
+ position: "absolute",
9188
+ transform: rotation === 0 ? "" : `rotate(${rotation}rad)`,
9189
+ left: absoluteCenter.x - absoluteSize.width / 2,
9190
+ top: absoluteCenter.y - absoluteSize.height / 2
9191
+ },
9192
+ overflow: "visible",
9193
+ width: absoluteSize.width,
9194
+ height: absoluteSize.height,
9195
+ viewBox: `${pathBounds.minX} ${pathBounds.minY} ${pathBounds.width} ${pathBounds.height}`,
9196
+ children: paths.map((p, i) => /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("path", {
9197
+ fill: "none",
9198
+ strokeWidth: 2 * (p.strokeWidth || 1),
9199
+ stroke: p.stroke || "red",
9200
+ d: p.d
9201
+ }, i))
9202
+ });
8278
9203
  };
8279
9204
  var SVGPathComponent_default = SVGPathComponent;
8280
9205
 
8281
9206
  // src/schematic-components/SimpleResistor.tsx
9207
+ var import_jsx_runtime3 = __toESM(require_jsx_runtime());
8282
9208
  var SimpleResistor = ({ component: { source, schematic } }) => {
8283
- return <SVGPathComponent_default rotation={schematic.rotation} center={schematic.center} size={schematic.size} paths={[
8284
- {
8285
- stroke: "red",
8286
- strokeWidth: 1,
8287
- d: "M 0 15 l 10 0 l 0 -6 l 20 0 l 0 12 l -20 0 l 0 -6 m 20 0 l 10 0"
8288
- }
8289
- ]} />;
9209
+ return /* @__PURE__ */ (0, import_jsx_runtime3.jsx)(SVGPathComponent_default, {
9210
+ rotation: schematic.rotation,
9211
+ center: schematic.center,
9212
+ size: schematic.size,
9213
+ paths: [
9214
+ {
9215
+ stroke: "red",
9216
+ strokeWidth: 1,
9217
+ d: "M 0 15 l 10 0 l 0 -6 l 20 0 l 0 12 l -20 0 l 0 -6 m 20 0 l 10 0"
9218
+ }
9219
+ ]
9220
+ });
8290
9221
  };
8291
9222
 
8292
9223
  // src/schematic-components/SimpleCapacitor.tsx
9224
+ var import_jsx_runtime4 = __toESM(require_jsx_runtime());
8293
9225
  var SimpleCapacitor = ({
8294
9226
  component: { source, schematic }
8295
9227
  }) => {
8296
- return <SVGPathComponent_default rotation={schematic.rotation} center={schematic.center} size={schematic.size} paths={[
8297
- { stroke: "red", strokeWidth: 1, d: "M 0 15 l 12 0" },
8298
- { stroke: "red", strokeWidth: 2, d: "M 12 0 l 0 30" },
8299
- { stroke: "red", strokeWidth: 2, d: "M 18 0 l 0 30" },
8300
- { stroke: "red", strokeWidth: 1, d: "M 18 15 l 12 0" }
8301
- ]} />;
9228
+ return /* @__PURE__ */ (0, import_jsx_runtime4.jsx)(SVGPathComponent_default, {
9229
+ rotation: schematic.rotation,
9230
+ center: schematic.center,
9231
+ size: schematic.size,
9232
+ paths: [
9233
+ { stroke: "red", strokeWidth: 1, d: "M 0 15 l 12 0" },
9234
+ { stroke: "red", strokeWidth: 2, d: "M 12 0 l 0 30" },
9235
+ { stroke: "red", strokeWidth: 2, d: "M 18 0 l 0 30" },
9236
+ { stroke: "red", strokeWidth: 1, d: "M 18 15 l 12 0" }
9237
+ ]
9238
+ });
8302
9239
  };
8303
9240
 
8304
9241
  // src/lib/hooks/use-maybe-promise.ts
@@ -8317,64 +9254,94 @@ var useMaybePromise = (promise) => {
8317
9254
 
8318
9255
  // src/schematic-components/ProjectComponent.tsx
8319
9256
  var import_builder = __toESM(require_dist());
9257
+ var import_jsx_runtime5 = __toESM(require_jsx_runtime());
8320
9258
  var ProjectComponent = ({ project: $project }) => {
8321
9259
  const project = useMaybePromise($project);
8322
9260
  if (!project)
8323
- return <span>loading</span>;
9261
+ return /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("span", {
9262
+ children: "loading"
9263
+ });
8324
9264
  const projectClass = new import_builder.ProjectClass(project);
8325
- return <>
8326
- {project.schematic_components.map((schematic_component) => <SchematicComponent key={schematic_component.schematic_component_id} component={{
8327
- source: projectClass.getSourceComponent(
8328
- schematic_component.source_component_id
8329
- ),
8330
- schematic: schematic_component
8331
- }} />)}
8332
- {project.schematic_ports.map((schematic_port) => <SchematicPort key={schematic_port.schematic_port_id} port={{
8333
- source: projectClass.getSourcePort(
8334
- schematic_port.schematic_port_id
8335
- ),
8336
- schematic: schematic_port
8337
- }} />)}
8338
- {project.schematic_traces.map((schematic_trace) => <SchematicTrace key={schematic_trace.schematic_trace_id} trace={{
8339
- source: projectClass.getSourceTrace(
8340
- schematic_trace.source_trace_id
8341
- ),
8342
- schematic: schematic_trace
8343
- }} />)}
8344
- {project.schematic_texts.map((schematic_text) => <SchematicText key={schematic_text.schematic_text_id} schematic_text={schematic_text} />)}
8345
- </>;
9265
+ return /* @__PURE__ */ (0, import_jsx_runtime5.jsxs)(import_jsx_runtime5.Fragment, {
9266
+ children: [
9267
+ project.schematic_components.map((schematic_component) => /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(SchematicComponent, {
9268
+ component: {
9269
+ source: projectClass.getSourceComponent(
9270
+ schematic_component.source_component_id
9271
+ ),
9272
+ schematic: schematic_component
9273
+ }
9274
+ }, schematic_component.schematic_component_id)),
9275
+ project.schematic_ports.map((schematic_port) => /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(SchematicPort, {
9276
+ port: {
9277
+ source: projectClass.getSourcePort(
9278
+ schematic_port.schematic_port_id
9279
+ ),
9280
+ schematic: schematic_port
9281
+ }
9282
+ }, schematic_port.schematic_port_id)),
9283
+ project.schematic_traces.map((schematic_trace) => /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(SchematicTrace, {
9284
+ trace: {
9285
+ source: projectClass.getSourceTrace(
9286
+ schematic_trace.source_trace_id
9287
+ ),
9288
+ schematic: schematic_trace
9289
+ }
9290
+ }, schematic_trace.schematic_trace_id)),
9291
+ project.schematic_texts.map((schematic_text) => /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(SchematicText, {
9292
+ schematic_text
9293
+ }, schematic_text.schematic_text_id))
9294
+ ]
9295
+ });
8346
9296
  };
8347
9297
 
8348
9298
  // src/schematic-components/SchematicComponent.tsx
9299
+ var import_jsx_runtime6 = __toESM(require_jsx_runtime());
8349
9300
  var SchematicComponent = ({ component }) => {
8350
9301
  const { source, schematic } = component;
8351
9302
  switch (source.ftype) {
8352
9303
  case "simple_resistor": {
8353
- return <SimpleResistor component={{ source, schematic }} />;
9304
+ return /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(SimpleResistor, {
9305
+ component: { source, schematic }
9306
+ });
8354
9307
  }
8355
9308
  case "simple_capacitor": {
8356
- return <SimpleCapacitor component={{ source, schematic }} />;
9309
+ return /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(SimpleCapacitor, {
9310
+ component: { source, schematic }
9311
+ });
8357
9312
  }
8358
9313
  case "simple_power_source": {
8359
- return <SimplePowerSource component={{ source, schematic }} />;
9314
+ return /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(SimplePowerSource, {
9315
+ component: { source, schematic }
9316
+ });
8360
9317
  }
8361
9318
  case "simple_ground": {
8362
- return <SimpleGround component={{ source, schematic }} />;
9319
+ return /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(SimpleGround, {
9320
+ component: { source, schematic }
9321
+ });
8363
9322
  }
8364
9323
  case "simple_inductor": {
8365
- return <SimpleInductor component={{ source, schematic }} />;
9324
+ return /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(SimpleInductor, {
9325
+ component: { source, schematic }
9326
+ });
8366
9327
  }
8367
9328
  case "simple_bug": {
8368
- return <SchematicBug component={{ source, schematic }} />;
9329
+ return /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(SchematicBug, {
9330
+ component: { source, schematic }
9331
+ });
8369
9332
  }
8370
9333
  case "simple_diode": {
8371
- return <SimpleDiode component={{ source, schematic }} />;
9334
+ return /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(SimpleDiode, {
9335
+ component: { source, schematic }
9336
+ });
8372
9337
  }
8373
9338
  default: {
8374
- return <div>
8375
- {"unknown ftype: "}
8376
- {component.source.ftype}
8377
- </div>;
9339
+ return /* @__PURE__ */ (0, import_jsx_runtime6.jsxs)("div", {
9340
+ children: [
9341
+ "unknown ftype: ",
9342
+ component.source.ftype
9343
+ ]
9344
+ });
8378
9345
  }
8379
9346
  }
8380
9347
  };
@@ -8394,24 +9361,31 @@ var directionToVec = (direction) => {
8394
9361
  };
8395
9362
 
8396
9363
  // src/schematic-components/SchematicPort.tsx
9364
+ var import_jsx_runtime7 = __toESM(require_jsx_runtime());
8397
9365
  var SchematicPort = ({ port: { source, schematic } }) => {
8398
- return <SVGPathComponent rotation={0} center={schematic.center} size={{ width: 0.2, height: 0.2 }} paths={[
8399
- {
8400
- stroke: "blue",
8401
- strokeWidth: 1,
8402
- d: "M 0 0 l 10 0 l 0 10 l -10 0 z"
8403
- },
8404
- schematic.facing_direction ? {
8405
- stroke: "blue",
8406
- strokeWidth: 0.5,
8407
- d: `M 5 5 l ${directionToVec(schematic.facing_direction).x * 7} ${directionToVec(schematic.facing_direction).y * 7}`
8408
- } : null
8409
- ].filter(Boolean)} />;
9366
+ return /* @__PURE__ */ (0, import_jsx_runtime7.jsx)(SVGPathComponent, {
9367
+ rotation: 0,
9368
+ center: schematic.center,
9369
+ size: { width: 0.2, height: 0.2 },
9370
+ paths: [
9371
+ {
9372
+ stroke: "blue",
9373
+ strokeWidth: 1,
9374
+ d: "M 0 0 l 10 0 l 0 10 l -10 0 z"
9375
+ },
9376
+ schematic.facing_direction ? {
9377
+ stroke: "blue",
9378
+ strokeWidth: 0.5,
9379
+ d: `M 5 5 l ${directionToVec(schematic.facing_direction).x * 7} ${directionToVec(schematic.facing_direction).y * 7}`
9380
+ } : null
9381
+ ].filter(Boolean)
9382
+ });
8410
9383
  };
8411
9384
 
8412
9385
  // src/schematic-components/SchematicText.tsx
8413
9386
  var import_transformation_matrix3 = require("transformation-matrix");
8414
9387
  var import_react_use_measure = __toESM(require("react-use-measure"));
9388
+ var import_jsx_runtime8 = __toESM(require_jsx_runtime());
8415
9389
  var SchematicText = ({ schematic_text }) => {
8416
9390
  const ct = useCameraTransform();
8417
9391
  const { text, position, anchor } = schematic_text;
@@ -8425,37 +9399,48 @@ var SchematicText = ({ schematic_text }) => {
8425
9399
  } else if (anchor === "right") {
8426
9400
  offset = [-bounds.width, -bounds.height / 2];
8427
9401
  }
8428
- return <div ref={boundsRef} style={{
8429
- fontFamily: "'IBM Plex Mono', monospace",
8430
- position: "absolute",
8431
- left: tPos.x + offset[0],
8432
- top: tPos.y + offset[1]
8433
- }}>{text}</div>;
9402
+ return /* @__PURE__ */ (0, import_jsx_runtime8.jsx)("div", {
9403
+ ref: boundsRef,
9404
+ style: {
9405
+ fontFamily: "'IBM Plex Mono', monospace",
9406
+ position: "absolute",
9407
+ left: tPos.x + offset[0],
9408
+ top: tPos.y + offset[1]
9409
+ },
9410
+ children: text
9411
+ });
8434
9412
  };
8435
9413
 
8436
9414
  // src/schematic-components/SchematicTrace.tsx
8437
9415
  var import_svg_path_generator = __toESM(require("svg-path-generator"));
8438
9416
 
8439
9417
  // src/schematic-components/RenderError.tsx
9418
+ var import_jsx_runtime9 = __toESM(require_jsx_runtime());
8440
9419
  var RenderError_default = ({ text }) => {
8441
- return <div style={{
8442
- position: "fixed",
8443
- backgroundColor: "red",
8444
- color: "white",
8445
- fontSize: 14,
8446
- fontFamily: "sans-serif",
8447
- padding: 5,
8448
- right: 0,
8449
- top: 0,
8450
- opacity: 0.75
8451
- }}>{text}</div>;
9420
+ return /* @__PURE__ */ (0, import_jsx_runtime9.jsx)("div", {
9421
+ style: {
9422
+ position: "fixed",
9423
+ backgroundColor: "red",
9424
+ color: "white",
9425
+ fontSize: 14,
9426
+ fontFamily: "sans-serif",
9427
+ padding: 5,
9428
+ right: 0,
9429
+ top: 0,
9430
+ opacity: 0.75
9431
+ },
9432
+ children: text
9433
+ });
8452
9434
  };
8453
9435
 
8454
9436
  // src/schematic-components/SchematicTrace.tsx
9437
+ var import_jsx_runtime10 = __toESM(require_jsx_runtime());
8455
9438
  var SchematicTrace = ({ trace: { source, schematic } }) => {
8456
9439
  const edges = schematic.edges;
8457
9440
  if (edges.length === 0) {
8458
- return <RenderError_default text="Route with 0 edges" />;
9441
+ return /* @__PURE__ */ (0, import_jsx_runtime10.jsx)(RenderError_default, {
9442
+ text: "Route with 0 edges"
9443
+ });
8459
9444
  }
8460
9445
  const path = (0, import_svg_path_generator.default)();
8461
9446
  for (let i = 0; i < edges.length; i++) {
@@ -8470,17 +9455,23 @@ var SchematicTrace = ({ trace: { source, schematic } }) => {
8470
9455
  x: pathBounds.minX + pathBounds.width / 2,
8471
9456
  y: pathBounds.minY + pathBounds.height / 2
8472
9457
  };
8473
- return <SVGPathComponent_default rotation={0} center={center} size={pathBounds} paths={[
8474
- {
8475
- stroke: "green",
8476
- strokeWidth: 0.02,
8477
- d
8478
- }
8479
- ]} />;
9458
+ return /* @__PURE__ */ (0, import_jsx_runtime10.jsx)(SVGPathComponent_default, {
9459
+ rotation: 0,
9460
+ center,
9461
+ size: pathBounds,
9462
+ paths: [
9463
+ {
9464
+ stroke: "green",
9465
+ strokeWidth: 0.02,
9466
+ d
9467
+ }
9468
+ ]
9469
+ });
8480
9470
  };
8481
9471
 
8482
9472
  // src/schematic-components/SchematicBug.tsx
8483
9473
  var import_range = __toESM(require_range());
9474
+ var import_jsx_runtime11 = __toESM(require_jsx_runtime());
8484
9475
  var SchematicBug = ({ component: { source, schematic } }) => {
8485
9476
  const ports_arrangement = schematic.port_arrangement;
8486
9477
  const port_labels = schematic.port_labels;
@@ -8488,78 +9479,108 @@ var SchematicBug = ({ component: { source, schematic } }) => {
8488
9479
  const rh = 15;
8489
9480
  const pd = 7.5;
8490
9481
  const bugh = Math.max(ports_arrangement.left_size, ports_arrangement.right_size) * rh;
8491
- return <SVGPathComponent_default rotation={schematic.rotation} center={schematic.center} size={schematic.size} paths={[
8492
- {
8493
- stroke: "red",
8494
- strokeWidth: 1,
8495
- d: `M 0 0 L ${bugw} 0 L ${bugw} ${bugh} L 0 ${bugh}Z`
8496
- },
8497
- ...(0, import_range.default)(
8498
- 0,
8499
- ports_arrangement.left_size + ports_arrangement.right_size
8500
- ).map((i) => {
8501
- const ls = ports_arrangement.left_size;
8502
- const left = i < ls;
8503
- const rowi = i % ls;
8504
- const p1 = [left ? 0 : bugw, rh / 2 + rowi * rh];
8505
- const rd = [left ? -pd : pd, 0];
8506
- return {
9482
+ return /* @__PURE__ */ (0, import_jsx_runtime11.jsx)(SVGPathComponent_default, {
9483
+ rotation: schematic.rotation,
9484
+ center: schematic.center,
9485
+ size: schematic.size,
9486
+ paths: [
9487
+ {
8507
9488
  stroke: "red",
8508
9489
  strokeWidth: 1,
8509
- d: `M ${p1.join(" ")} l ${rd.join(" ")}`
8510
- };
8511
- })
8512
- ]} />;
9490
+ d: `M 0 0 L ${bugw} 0 L ${bugw} ${bugh} L 0 ${bugh}Z`
9491
+ },
9492
+ ...(0, import_range.default)(
9493
+ 0,
9494
+ ports_arrangement.left_size + ports_arrangement.right_size
9495
+ ).map((i) => {
9496
+ const ls = ports_arrangement.left_size;
9497
+ const left = i < ls;
9498
+ const rowi = i % ls;
9499
+ const p1 = [left ? 0 : bugw, rh / 2 + rowi * rh];
9500
+ const rd = [left ? -pd : pd, 0];
9501
+ return {
9502
+ stroke: "red",
9503
+ strokeWidth: 1,
9504
+ d: `M ${p1.join(" ")} l ${rd.join(" ")}`
9505
+ };
9506
+ })
9507
+ ]
9508
+ });
8513
9509
  };
8514
9510
 
8515
9511
  // src/schematic-components/SimplePowerSource.tsx
9512
+ var import_jsx_runtime12 = __toESM(require_jsx_runtime());
8516
9513
  var SimplePowerSource = ({
8517
9514
  component: { source, schematic }
8518
9515
  }) => {
8519
- return <SVGPathComponent_default rotation={schematic.rotation} center={schematic.center} size={schematic.size} paths={[
8520
- {
8521
- stroke: "red",
8522
- strokeWidth: 1,
8523
- d: "M 0 -17 L 0 -3 M -8 3 L 8 3 M 0 17 L 0 3 M -12 -3 L 12 -3"
8524
- }
8525
- ]} />;
9516
+ return /* @__PURE__ */ (0, import_jsx_runtime12.jsx)(SVGPathComponent_default, {
9517
+ rotation: schematic.rotation,
9518
+ center: schematic.center,
9519
+ size: schematic.size,
9520
+ paths: [
9521
+ {
9522
+ stroke: "red",
9523
+ strokeWidth: 1,
9524
+ d: "M 0 -17 L 0 -3 M -8 3 L 8 3 M 0 17 L 0 3 M -12 -3 L 12 -3"
9525
+ }
9526
+ ]
9527
+ });
8526
9528
  };
8527
9529
 
8528
9530
  // src/schematic-components/SimpleGround.tsx
9531
+ var import_jsx_runtime13 = __toESM(require_jsx_runtime());
8529
9532
  var SimpleGround = ({ component: { source, schematic } }) => {
8530
- return <SVGPathComponent_default rotation={schematic.rotation} center={schematic.center} size={schematic.size} paths={[
8531
- {
8532
- stroke: "red",
8533
- strokeWidth: 0.7,
8534
- d: "M -3 3 L 3 3 M -6 0 L 6 0 M -9 -3 L 9 -3 M 0 -3 L 0 -12"
8535
- }
8536
- ]} />;
9533
+ return /* @__PURE__ */ (0, import_jsx_runtime13.jsx)(SVGPathComponent_default, {
9534
+ rotation: schematic.rotation,
9535
+ center: schematic.center,
9536
+ size: schematic.size,
9537
+ paths: [
9538
+ {
9539
+ stroke: "red",
9540
+ strokeWidth: 0.7,
9541
+ d: "M -3 3 L 3 3 M -6 0 L 6 0 M -9 -3 L 9 -3 M 0 -3 L 0 -12"
9542
+ }
9543
+ ]
9544
+ });
8537
9545
  };
8538
9546
 
8539
9547
  // src/schematic-components/SimpleInductor.tsx
9548
+ var import_jsx_runtime14 = __toESM(require_jsx_runtime());
8540
9549
  var SimpleInductor = ({ component: { source, schematic } }) => {
8541
- return <SVGPathComponent_default rotation={schematic.rotation} center={schematic.center} size={schematic.size} paths={[
8542
- {
8543
- stroke: "red",
8544
- strokeWidth: 1,
8545
- d: "m 371,710.41665 h -14 c -0.0421,-16.39898 -14.02104,-16.39898 -14,0 -0.021,-16.399 -14.04182,-16.34072 -14,0 -2.6e-4,-16.45722 -14.04236,-16.45722 -14,0 2.8e-4,-16.3407 -13.97896,-16.39898 -14,0 -0.0421,-16.39898 -13.91338,-16.39898 -13.91338,0 H 273"
8546
- }
8547
- ]} />;
9550
+ return /* @__PURE__ */ (0, import_jsx_runtime14.jsx)(SVGPathComponent_default, {
9551
+ rotation: schematic.rotation,
9552
+ center: schematic.center,
9553
+ size: schematic.size,
9554
+ paths: [
9555
+ {
9556
+ stroke: "red",
9557
+ strokeWidth: 1,
9558
+ d: "m 371,710.41665 h -14 c -0.0421,-16.39898 -14.02104,-16.39898 -14,0 -0.021,-16.399 -14.04182,-16.34072 -14,0 -2.6e-4,-16.45722 -14.04236,-16.45722 -14,0 2.8e-4,-16.3407 -13.97896,-16.39898 -14,0 -0.0421,-16.39898 -13.91338,-16.39898 -13.91338,0 H 273"
9559
+ }
9560
+ ]
9561
+ });
8548
9562
  };
8549
9563
 
8550
9564
  // src/schematic-components/SimpleDiode.tsx
9565
+ var import_jsx_runtime15 = __toESM(require_jsx_runtime());
8551
9566
  var SimpleDiode = ({ component: { source, schematic } }) => {
8552
- return <SVGPathComponent_default rotation={schematic.rotation} center={schematic.center} size={schematic.size} paths={[
8553
- { stroke: "red", strokeWidth: 2, d: "M 0,0 H 21" },
8554
- { stroke: "red", strokeWidth: 2, d: "M 49,0 H 59" },
8555
- { stroke: "red", strokeWidth: 2, d: "M 49,0 L 21 14 V -14 Z" },
8556
- { stroke: "red", strokeWidth: 2, d: "M 49,-14 V 14" }
8557
- ]} />;
9567
+ return /* @__PURE__ */ (0, import_jsx_runtime15.jsx)(SVGPathComponent_default, {
9568
+ rotation: schematic.rotation,
9569
+ center: schematic.center,
9570
+ size: schematic.size,
9571
+ paths: [
9572
+ { stroke: "red", strokeWidth: 2, d: "M 0,0 H 21" },
9573
+ { stroke: "red", strokeWidth: 2, d: "M 49,0 H 59" },
9574
+ { stroke: "red", strokeWidth: 2, d: "M 49,0 L 21 14 V -14 Z" },
9575
+ { stroke: "red", strokeWidth: 2, d: "M 49,-14 V 14" }
9576
+ ]
9577
+ });
8558
9578
  };
8559
9579
 
8560
9580
  // src/Schematic.tsx
8561
9581
  var import_builder2 = __toESM(require_dist());
8562
9582
  var import_react_fiber = require("@tscircuit/react-fiber");
9583
+ var import_jsx_runtime16 = __toESM(require_jsx_runtime());
8563
9584
  var Schematic = ({
8564
9585
  children,
8565
9586
  elements: initialElements = []
@@ -8567,24 +9588,47 @@ var Schematic = ({
8567
9588
  const [elements, setElements] = (0, import_react2.useState)(initialElements);
8568
9589
  const [project, setProject] = (0, import_react2.useState)(null);
8569
9590
  (0, import_react2.useEffect)(() => {
8570
- if (initialElements) {
8571
- setProject((0, import_builder2.createProjectFromElements)(elements));
9591
+ if (initialElements.length > 0) {
9592
+ setProject((0, import_builder2.createProjectFromElements)(initialElements));
8572
9593
  return;
8573
9594
  }
8574
9595
  const projectBuilder = (0, import_builder2.createProjectBuilder)();
8575
9596
  (0, import_react_fiber.createRoot)().render(children, projectBuilder).then(async (elements2) => {
8576
9597
  setElements(elements2);
8577
9598
  setProject((0, import_builder2.createProjectFromElements)(elements2));
9599
+ }).catch((e) => {
9600
+ console.error("ERROR RENDERING CIRCUIT");
9601
+ throw e;
8578
9602
  });
8579
9603
  }, [children]);
8580
9604
  if (elements.length === 0)
8581
9605
  return null;
8582
- return <ProjectComponent project={project} />;
9606
+ return /* @__PURE__ */ (0, import_jsx_runtime16.jsx)(ProjectComponent, {
9607
+ project
9608
+ });
8583
9609
  };
8584
9610
  // Annotate the CommonJS export names for ESM import in node:
8585
9611
  0 && (module.exports = {
8586
9612
  Schematic
8587
9613
  });
9614
+ /**
9615
+ * @license React
9616
+ * react-jsx-runtime.development.js
9617
+ *
9618
+ * Copyright (c) Facebook, Inc. and its affiliates.
9619
+ *
9620
+ * This source code is licensed under the MIT license found in the
9621
+ * LICENSE file in the root directory of this source tree.
9622
+ */
9623
+ /**
9624
+ * @license React
9625
+ * react-jsx-runtime.production.min.js
9626
+ *
9627
+ * Copyright (c) Facebook, Inc. and its affiliates.
9628
+ *
9629
+ * This source code is licensed under the MIT license found in the
9630
+ * LICENSE file in the root directory of this source tree.
9631
+ */
8588
9632
  /**
8589
9633
  * @license React
8590
9634
  * react.development.js