@tscircuit/schematic-viewer 0.0.2 → 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 (49) hide show
  1. package/dist/Schematic.js +1178 -137
  2. package/dist/Schematic.js.map +1 -1
  3. package/dist/index.js +1178 -137
  4. package/dist/index.js.map +1 -1
  5. package/dist/pages/_app.js +950 -8
  6. package/dist/pages/_app.js.map +1 -1
  7. package/dist/pages/index.js +1185 -138
  8. package/dist/pages/index.js.map +1 -1
  9. package/dist/pages/led-circuit-react.js +1251 -160
  10. package/dist/pages/led-circuit-react.js.map +1 -1
  11. package/dist/pages/led-circuit.js +1190 -138
  12. package/dist/pages/led-circuit.js.map +1 -1
  13. package/dist/schematic-components/MovableGrid/MovableGrid.stories.js +3062 -2
  14. package/dist/schematic-components/MovableGrid/MovableGrid.stories.js.map +1 -1
  15. package/dist/schematic-components/MovableGrid/index.js +3058 -1
  16. package/dist/schematic-components/MovableGrid/index.js.map +1 -1
  17. package/dist/schematic-components/ProjectComponent.js +1174 -136
  18. package/dist/schematic-components/ProjectComponent.js.map +1 -1
  19. package/dist/schematic-components/RenderError.js +3069 -11
  20. package/dist/schematic-components/RenderError.js.map +1 -1
  21. package/dist/schematic-components/SVGPathComponent.js +3067 -6
  22. package/dist/schematic-components/SVGPathComponent.js.map +1 -1
  23. package/dist/schematic-components/SchematicBug.js +3090 -26
  24. package/dist/schematic-components/SchematicBug.js.map +1 -1
  25. package/dist/schematic-components/SchematicComponent.js +1090 -77
  26. package/dist/schematic-components/SchematicComponent.js.map +1 -1
  27. package/dist/schematic-components/SchematicPort.js +997 -18
  28. package/dist/schematic-components/SchematicPort.js.map +1 -1
  29. package/dist/schematic-components/SchematicText.js +3059 -6
  30. package/dist/schematic-components/SchematicText.js.map +1 -1
  31. package/dist/schematic-components/SchematicTrace.js +3098 -25
  32. package/dist/schematic-components/SchematicTrace.js.map +1 -1
  33. package/dist/schematic-components/SimpleCapacitor.js +3079 -12
  34. package/dist/schematic-components/SimpleCapacitor.js.map +1 -1
  35. package/dist/schematic-components/SimpleDiode.js +3079 -12
  36. package/dist/schematic-components/SimpleDiode.js.map +1 -1
  37. package/dist/schematic-components/SimpleGround.js +3080 -13
  38. package/dist/schematic-components/SimpleGround.js.map +1 -1
  39. package/dist/schematic-components/SimpleInductor.js +3080 -13
  40. package/dist/schematic-components/SimpleInductor.js.map +1 -1
  41. package/dist/schematic-components/SimplePowerSource.js +3080 -13
  42. package/dist/schematic-components/SimplePowerSource.js.map +1 -1
  43. package/dist/schematic-components/SimpleResistor.js +3080 -13
  44. package/dist/schematic-components/SimpleResistor.js.map +1 -1
  45. package/dist/schematic-components/index.js +1175 -137
  46. package/dist/schematic-components/index.js.map +1 -1
  47. package/package.json +1 -1
  48. package/src/pages/led-circuit.tsx +8 -1
  49. package/tsconfig.json +2 -1
@@ -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 jsx16 = jsxWithValidationDynamic;
3019
+ var jsxs3 = jsxWithValidationStatic;
3020
+ exports.Fragment = REACT_FRAGMENT_TYPE;
3021
+ exports.jsx = jsx16;
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) {
@@ -8238,8 +9147,11 @@ __export(schematic_components_exports, {
8238
9147
  module.exports = __toCommonJS(schematic_components_exports);
8239
9148
 
8240
9149
  // src/schematic-components/MovableGrid/index.tsx
9150
+ var import_jsx_runtime = __toESM(require_jsx_runtime());
8241
9151
  var MovableGrid = () => {
8242
- return <div>asd</div>;
9152
+ return /* @__PURE__ */ (0, import_jsx_runtime.jsx)("div", {
9153
+ children: `asd`
9154
+ });
8243
9155
  };
8244
9156
 
8245
9157
  // src/schematic-components/SchematicGroup.tsx
@@ -8276,6 +9188,7 @@ var get_svg_path_bounds_default = getSVGPathBounds;
8276
9188
 
8277
9189
  // src/schematic-components/SVGPathComponent.tsx
8278
9190
  var import_transformation_matrix2 = require("transformation-matrix");
9191
+ var import_jsx_runtime2 = __toESM(require_jsx_runtime());
8279
9192
  var SVGPathComponent = ({ size, center, rotation, paths }) => {
8280
9193
  const ct = useCameraTransform();
8281
9194
  const pathBounds = get_svg_path_bounds_default(paths.map((p) => p.d));
@@ -8292,36 +9205,60 @@ var SVGPathComponent = ({ size, center, rotation, paths }) => {
8292
9205
  width: Math.max(1, size.width * ct.a),
8293
9206
  height: Math.max(1, size.height * ct.d)
8294
9207
  };
8295
- return <svg style={{
8296
- position: "absolute",
8297
- transform: rotation === 0 ? "" : `rotate(${rotation}rad)`,
8298
- left: absoluteCenter.x - absoluteSize.width / 2,
8299
- top: absoluteCenter.y - absoluteSize.height / 2
8300
- }} 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>;
9208
+ return /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("svg", {
9209
+ style: {
9210
+ position: "absolute",
9211
+ transform: rotation === 0 ? "" : `rotate(${rotation}rad)`,
9212
+ left: absoluteCenter.x - absoluteSize.width / 2,
9213
+ top: absoluteCenter.y - absoluteSize.height / 2
9214
+ },
9215
+ overflow: "visible",
9216
+ width: absoluteSize.width,
9217
+ height: absoluteSize.height,
9218
+ viewBox: `${pathBounds.minX} ${pathBounds.minY} ${pathBounds.width} ${pathBounds.height}`,
9219
+ children: paths.map((p, i) => /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("path", {
9220
+ fill: "none",
9221
+ strokeWidth: 2 * (p.strokeWidth || 1),
9222
+ stroke: p.stroke || "red",
9223
+ d: p.d
9224
+ }, i))
9225
+ });
8301
9226
  };
8302
9227
  var SVGPathComponent_default = SVGPathComponent;
8303
9228
 
8304
9229
  // src/schematic-components/SimpleResistor.tsx
9230
+ var import_jsx_runtime3 = __toESM(require_jsx_runtime());
8305
9231
  var SimpleResistor = ({ component: { source, schematic } }) => {
8306
- return <SVGPathComponent_default rotation={schematic.rotation} center={schematic.center} size={schematic.size} paths={[
8307
- {
8308
- stroke: "red",
8309
- strokeWidth: 1,
8310
- 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"
8311
- }
8312
- ]} />;
9232
+ return /* @__PURE__ */ (0, import_jsx_runtime3.jsx)(SVGPathComponent_default, {
9233
+ rotation: schematic.rotation,
9234
+ center: schematic.center,
9235
+ size: schematic.size,
9236
+ paths: [
9237
+ {
9238
+ stroke: "red",
9239
+ strokeWidth: 1,
9240
+ 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"
9241
+ }
9242
+ ]
9243
+ });
8313
9244
  };
8314
9245
 
8315
9246
  // src/schematic-components/SimpleCapacitor.tsx
9247
+ var import_jsx_runtime4 = __toESM(require_jsx_runtime());
8316
9248
  var SimpleCapacitor = ({
8317
9249
  component: { source, schematic }
8318
9250
  }) => {
8319
- return <SVGPathComponent_default rotation={schematic.rotation} center={schematic.center} size={schematic.size} paths={[
8320
- { stroke: "red", strokeWidth: 1, d: "M 0 15 l 12 0" },
8321
- { stroke: "red", strokeWidth: 2, d: "M 12 0 l 0 30" },
8322
- { stroke: "red", strokeWidth: 2, d: "M 18 0 l 0 30" },
8323
- { stroke: "red", strokeWidth: 1, d: "M 18 15 l 12 0" }
8324
- ]} />;
9251
+ return /* @__PURE__ */ (0, import_jsx_runtime4.jsx)(SVGPathComponent_default, {
9252
+ rotation: schematic.rotation,
9253
+ center: schematic.center,
9254
+ size: schematic.size,
9255
+ paths: [
9256
+ { stroke: "red", strokeWidth: 1, d: "M 0 15 l 12 0" },
9257
+ { stroke: "red", strokeWidth: 2, d: "M 12 0 l 0 30" },
9258
+ { stroke: "red", strokeWidth: 2, d: "M 18 0 l 0 30" },
9259
+ { stroke: "red", strokeWidth: 1, d: "M 18 15 l 12 0" }
9260
+ ]
9261
+ });
8325
9262
  };
8326
9263
 
8327
9264
  // src/lib/hooks/use-maybe-promise.ts
@@ -8340,64 +9277,94 @@ var useMaybePromise = (promise) => {
8340
9277
 
8341
9278
  // src/schematic-components/ProjectComponent.tsx
8342
9279
  var import_builder = __toESM(require_dist());
9280
+ var import_jsx_runtime5 = __toESM(require_jsx_runtime());
8343
9281
  var ProjectComponent = ({ project: $project }) => {
8344
9282
  const project = useMaybePromise($project);
8345
9283
  if (!project)
8346
- return <span>loading</span>;
9284
+ return /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("span", {
9285
+ children: "loading"
9286
+ });
8347
9287
  const projectClass = new import_builder.ProjectClass(project);
8348
- return <>
8349
- {project.schematic_components.map((schematic_component) => <SchematicComponent key={schematic_component.schematic_component_id} component={{
8350
- source: projectClass.getSourceComponent(
8351
- schematic_component.source_component_id
8352
- ),
8353
- schematic: schematic_component
8354
- }} />)}
8355
- {project.schematic_ports.map((schematic_port) => <SchematicPort key={schematic_port.schematic_port_id} port={{
8356
- source: projectClass.getSourcePort(
8357
- schematic_port.schematic_port_id
8358
- ),
8359
- schematic: schematic_port
8360
- }} />)}
8361
- {project.schematic_traces.map((schematic_trace) => <SchematicTrace key={schematic_trace.schematic_trace_id} trace={{
8362
- source: projectClass.getSourceTrace(
8363
- schematic_trace.source_trace_id
8364
- ),
8365
- schematic: schematic_trace
8366
- }} />)}
8367
- {project.schematic_texts.map((schematic_text) => <SchematicText key={schematic_text.schematic_text_id} schematic_text={schematic_text} />)}
8368
- </>;
9288
+ return /* @__PURE__ */ (0, import_jsx_runtime5.jsxs)(import_jsx_runtime5.Fragment, {
9289
+ children: [
9290
+ project.schematic_components.map((schematic_component) => /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(SchematicComponent, {
9291
+ component: {
9292
+ source: projectClass.getSourceComponent(
9293
+ schematic_component.source_component_id
9294
+ ),
9295
+ schematic: schematic_component
9296
+ }
9297
+ }, schematic_component.schematic_component_id)),
9298
+ project.schematic_ports.map((schematic_port) => /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(SchematicPort, {
9299
+ port: {
9300
+ source: projectClass.getSourcePort(
9301
+ schematic_port.schematic_port_id
9302
+ ),
9303
+ schematic: schematic_port
9304
+ }
9305
+ }, schematic_port.schematic_port_id)),
9306
+ project.schematic_traces.map((schematic_trace) => /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(SchematicTrace, {
9307
+ trace: {
9308
+ source: projectClass.getSourceTrace(
9309
+ schematic_trace.source_trace_id
9310
+ ),
9311
+ schematic: schematic_trace
9312
+ }
9313
+ }, schematic_trace.schematic_trace_id)),
9314
+ project.schematic_texts.map((schematic_text) => /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(SchematicText, {
9315
+ schematic_text
9316
+ }, schematic_text.schematic_text_id))
9317
+ ]
9318
+ });
8369
9319
  };
8370
9320
 
8371
9321
  // src/schematic-components/SchematicComponent.tsx
9322
+ var import_jsx_runtime6 = __toESM(require_jsx_runtime());
8372
9323
  var SchematicComponent = ({ component }) => {
8373
9324
  const { source, schematic } = component;
8374
9325
  switch (source.ftype) {
8375
9326
  case "simple_resistor": {
8376
- return <SimpleResistor component={{ source, schematic }} />;
9327
+ return /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(SimpleResistor, {
9328
+ component: { source, schematic }
9329
+ });
8377
9330
  }
8378
9331
  case "simple_capacitor": {
8379
- return <SimpleCapacitor component={{ source, schematic }} />;
9332
+ return /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(SimpleCapacitor, {
9333
+ component: { source, schematic }
9334
+ });
8380
9335
  }
8381
9336
  case "simple_power_source": {
8382
- return <SimplePowerSource component={{ source, schematic }} />;
9337
+ return /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(SimplePowerSource, {
9338
+ component: { source, schematic }
9339
+ });
8383
9340
  }
8384
9341
  case "simple_ground": {
8385
- return <SimpleGround component={{ source, schematic }} />;
9342
+ return /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(SimpleGround, {
9343
+ component: { source, schematic }
9344
+ });
8386
9345
  }
8387
9346
  case "simple_inductor": {
8388
- return <SimpleInductor component={{ source, schematic }} />;
9347
+ return /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(SimpleInductor, {
9348
+ component: { source, schematic }
9349
+ });
8389
9350
  }
8390
9351
  case "simple_bug": {
8391
- return <SchematicBug component={{ source, schematic }} />;
9352
+ return /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(SchematicBug, {
9353
+ component: { source, schematic }
9354
+ });
8392
9355
  }
8393
9356
  case "simple_diode": {
8394
- return <SimpleDiode component={{ source, schematic }} />;
9357
+ return /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(SimpleDiode, {
9358
+ component: { source, schematic }
9359
+ });
8395
9360
  }
8396
9361
  default: {
8397
- return <div>
8398
- {"unknown ftype: "}
8399
- {component.source.ftype}
8400
- </div>;
9362
+ return /* @__PURE__ */ (0, import_jsx_runtime6.jsxs)("div", {
9363
+ children: [
9364
+ "unknown ftype: ",
9365
+ component.source.ftype
9366
+ ]
9367
+ });
8401
9368
  }
8402
9369
  }
8403
9370
  };
@@ -8417,24 +9384,31 @@ var directionToVec = (direction) => {
8417
9384
  };
8418
9385
 
8419
9386
  // src/schematic-components/SchematicPort.tsx
9387
+ var import_jsx_runtime7 = __toESM(require_jsx_runtime());
8420
9388
  var SchematicPort = ({ port: { source, schematic } }) => {
8421
- return <SVGPathComponent rotation={0} center={schematic.center} size={{ width: 0.2, height: 0.2 }} paths={[
8422
- {
8423
- stroke: "blue",
8424
- strokeWidth: 1,
8425
- d: "M 0 0 l 10 0 l 0 10 l -10 0 z"
8426
- },
8427
- schematic.facing_direction ? {
8428
- stroke: "blue",
8429
- strokeWidth: 0.5,
8430
- d: `M 5 5 l ${directionToVec(schematic.facing_direction).x * 7} ${directionToVec(schematic.facing_direction).y * 7}`
8431
- } : null
8432
- ].filter(Boolean)} />;
9389
+ return /* @__PURE__ */ (0, import_jsx_runtime7.jsx)(SVGPathComponent, {
9390
+ rotation: 0,
9391
+ center: schematic.center,
9392
+ size: { width: 0.2, height: 0.2 },
9393
+ paths: [
9394
+ {
9395
+ stroke: "blue",
9396
+ strokeWidth: 1,
9397
+ d: "M 0 0 l 10 0 l 0 10 l -10 0 z"
9398
+ },
9399
+ schematic.facing_direction ? {
9400
+ stroke: "blue",
9401
+ strokeWidth: 0.5,
9402
+ d: `M 5 5 l ${directionToVec(schematic.facing_direction).x * 7} ${directionToVec(schematic.facing_direction).y * 7}`
9403
+ } : null
9404
+ ].filter(Boolean)
9405
+ });
8433
9406
  };
8434
9407
 
8435
9408
  // src/schematic-components/SchematicText.tsx
8436
9409
  var import_transformation_matrix3 = require("transformation-matrix");
8437
9410
  var import_react_use_measure = __toESM(require("react-use-measure"));
9411
+ var import_jsx_runtime8 = __toESM(require_jsx_runtime());
8438
9412
  var SchematicText = ({ schematic_text }) => {
8439
9413
  const ct = useCameraTransform();
8440
9414
  const { text, position, anchor } = schematic_text;
@@ -8448,37 +9422,48 @@ var SchematicText = ({ schematic_text }) => {
8448
9422
  } else if (anchor === "right") {
8449
9423
  offset = [-bounds.width, -bounds.height / 2];
8450
9424
  }
8451
- return <div ref={boundsRef} style={{
8452
- fontFamily: "'IBM Plex Mono', monospace",
8453
- position: "absolute",
8454
- left: tPos.x + offset[0],
8455
- top: tPos.y + offset[1]
8456
- }}>{text}</div>;
9425
+ return /* @__PURE__ */ (0, import_jsx_runtime8.jsx)("div", {
9426
+ ref: boundsRef,
9427
+ style: {
9428
+ fontFamily: "'IBM Plex Mono', monospace",
9429
+ position: "absolute",
9430
+ left: tPos.x + offset[0],
9431
+ top: tPos.y + offset[1]
9432
+ },
9433
+ children: text
9434
+ });
8457
9435
  };
8458
9436
 
8459
9437
  // src/schematic-components/SchematicTrace.tsx
8460
9438
  var import_svg_path_generator = __toESM(require("svg-path-generator"));
8461
9439
 
8462
9440
  // src/schematic-components/RenderError.tsx
9441
+ var import_jsx_runtime9 = __toESM(require_jsx_runtime());
8463
9442
  var RenderError_default = ({ text }) => {
8464
- return <div style={{
8465
- position: "fixed",
8466
- backgroundColor: "red",
8467
- color: "white",
8468
- fontSize: 14,
8469
- fontFamily: "sans-serif",
8470
- padding: 5,
8471
- right: 0,
8472
- top: 0,
8473
- opacity: 0.75
8474
- }}>{text}</div>;
9443
+ return /* @__PURE__ */ (0, import_jsx_runtime9.jsx)("div", {
9444
+ style: {
9445
+ position: "fixed",
9446
+ backgroundColor: "red",
9447
+ color: "white",
9448
+ fontSize: 14,
9449
+ fontFamily: "sans-serif",
9450
+ padding: 5,
9451
+ right: 0,
9452
+ top: 0,
9453
+ opacity: 0.75
9454
+ },
9455
+ children: text
9456
+ });
8475
9457
  };
8476
9458
 
8477
9459
  // src/schematic-components/SchematicTrace.tsx
9460
+ var import_jsx_runtime10 = __toESM(require_jsx_runtime());
8478
9461
  var SchematicTrace = ({ trace: { source, schematic } }) => {
8479
9462
  const edges = schematic.edges;
8480
9463
  if (edges.length === 0) {
8481
- return <RenderError_default text="Route with 0 edges" />;
9464
+ return /* @__PURE__ */ (0, import_jsx_runtime10.jsx)(RenderError_default, {
9465
+ text: "Route with 0 edges"
9466
+ });
8482
9467
  }
8483
9468
  const path = (0, import_svg_path_generator.default)();
8484
9469
  for (let i = 0; i < edges.length; i++) {
@@ -8493,17 +9478,23 @@ var SchematicTrace = ({ trace: { source, schematic } }) => {
8493
9478
  x: pathBounds.minX + pathBounds.width / 2,
8494
9479
  y: pathBounds.minY + pathBounds.height / 2
8495
9480
  };
8496
- return <SVGPathComponent_default rotation={0} center={center} size={pathBounds} paths={[
8497
- {
8498
- stroke: "green",
8499
- strokeWidth: 0.02,
8500
- d
8501
- }
8502
- ]} />;
9481
+ return /* @__PURE__ */ (0, import_jsx_runtime10.jsx)(SVGPathComponent_default, {
9482
+ rotation: 0,
9483
+ center,
9484
+ size: pathBounds,
9485
+ paths: [
9486
+ {
9487
+ stroke: "green",
9488
+ strokeWidth: 0.02,
9489
+ d
9490
+ }
9491
+ ]
9492
+ });
8503
9493
  };
8504
9494
 
8505
9495
  // src/schematic-components/SchematicBug.tsx
8506
9496
  var import_range = __toESM(require_range());
9497
+ var import_jsx_runtime11 = __toESM(require_jsx_runtime());
8507
9498
  var SchematicBug = ({ component: { source, schematic } }) => {
8508
9499
  const ports_arrangement = schematic.port_arrangement;
8509
9500
  const port_labels = schematic.port_labels;
@@ -8511,73 +9502,102 @@ var SchematicBug = ({ component: { source, schematic } }) => {
8511
9502
  const rh = 15;
8512
9503
  const pd = 7.5;
8513
9504
  const bugh = Math.max(ports_arrangement.left_size, ports_arrangement.right_size) * rh;
8514
- return <SVGPathComponent_default rotation={schematic.rotation} center={schematic.center} size={schematic.size} paths={[
8515
- {
8516
- stroke: "red",
8517
- strokeWidth: 1,
8518
- d: `M 0 0 L ${bugw} 0 L ${bugw} ${bugh} L 0 ${bugh}Z`
8519
- },
8520
- ...(0, import_range.default)(
8521
- 0,
8522
- ports_arrangement.left_size + ports_arrangement.right_size
8523
- ).map((i) => {
8524
- const ls = ports_arrangement.left_size;
8525
- const left = i < ls;
8526
- const rowi = i % ls;
8527
- const p1 = [left ? 0 : bugw, rh / 2 + rowi * rh];
8528
- const rd = [left ? -pd : pd, 0];
8529
- return {
9505
+ return /* @__PURE__ */ (0, import_jsx_runtime11.jsx)(SVGPathComponent_default, {
9506
+ rotation: schematic.rotation,
9507
+ center: schematic.center,
9508
+ size: schematic.size,
9509
+ paths: [
9510
+ {
8530
9511
  stroke: "red",
8531
9512
  strokeWidth: 1,
8532
- d: `M ${p1.join(" ")} l ${rd.join(" ")}`
8533
- };
8534
- })
8535
- ]} />;
9513
+ d: `M 0 0 L ${bugw} 0 L ${bugw} ${bugh} L 0 ${bugh}Z`
9514
+ },
9515
+ ...(0, import_range.default)(
9516
+ 0,
9517
+ ports_arrangement.left_size + ports_arrangement.right_size
9518
+ ).map((i) => {
9519
+ const ls = ports_arrangement.left_size;
9520
+ const left = i < ls;
9521
+ const rowi = i % ls;
9522
+ const p1 = [left ? 0 : bugw, rh / 2 + rowi * rh];
9523
+ const rd = [left ? -pd : pd, 0];
9524
+ return {
9525
+ stroke: "red",
9526
+ strokeWidth: 1,
9527
+ d: `M ${p1.join(" ")} l ${rd.join(" ")}`
9528
+ };
9529
+ })
9530
+ ]
9531
+ });
8536
9532
  };
8537
9533
 
8538
9534
  // src/schematic-components/SimplePowerSource.tsx
9535
+ var import_jsx_runtime12 = __toESM(require_jsx_runtime());
8539
9536
  var SimplePowerSource = ({
8540
9537
  component: { source, schematic }
8541
9538
  }) => {
8542
- return <SVGPathComponent_default rotation={schematic.rotation} center={schematic.center} size={schematic.size} paths={[
8543
- {
8544
- stroke: "red",
8545
- strokeWidth: 1,
8546
- 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"
8547
- }
8548
- ]} />;
9539
+ return /* @__PURE__ */ (0, import_jsx_runtime12.jsx)(SVGPathComponent_default, {
9540
+ rotation: schematic.rotation,
9541
+ center: schematic.center,
9542
+ size: schematic.size,
9543
+ paths: [
9544
+ {
9545
+ stroke: "red",
9546
+ strokeWidth: 1,
9547
+ 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"
9548
+ }
9549
+ ]
9550
+ });
8549
9551
  };
8550
9552
 
8551
9553
  // src/schematic-components/SimpleGround.tsx
9554
+ var import_jsx_runtime13 = __toESM(require_jsx_runtime());
8552
9555
  var SimpleGround = ({ component: { source, schematic } }) => {
8553
- return <SVGPathComponent_default rotation={schematic.rotation} center={schematic.center} size={schematic.size} paths={[
8554
- {
8555
- stroke: "red",
8556
- strokeWidth: 0.7,
8557
- 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"
8558
- }
8559
- ]} />;
9556
+ return /* @__PURE__ */ (0, import_jsx_runtime13.jsx)(SVGPathComponent_default, {
9557
+ rotation: schematic.rotation,
9558
+ center: schematic.center,
9559
+ size: schematic.size,
9560
+ paths: [
9561
+ {
9562
+ stroke: "red",
9563
+ strokeWidth: 0.7,
9564
+ 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"
9565
+ }
9566
+ ]
9567
+ });
8560
9568
  };
8561
9569
 
8562
9570
  // src/schematic-components/SimpleInductor.tsx
9571
+ var import_jsx_runtime14 = __toESM(require_jsx_runtime());
8563
9572
  var SimpleInductor = ({ component: { source, schematic } }) => {
8564
- return <SVGPathComponent_default rotation={schematic.rotation} center={schematic.center} size={schematic.size} paths={[
8565
- {
8566
- stroke: "red",
8567
- strokeWidth: 1,
8568
- 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"
8569
- }
8570
- ]} />;
9573
+ return /* @__PURE__ */ (0, import_jsx_runtime14.jsx)(SVGPathComponent_default, {
9574
+ rotation: schematic.rotation,
9575
+ center: schematic.center,
9576
+ size: schematic.size,
9577
+ paths: [
9578
+ {
9579
+ stroke: "red",
9580
+ strokeWidth: 1,
9581
+ 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"
9582
+ }
9583
+ ]
9584
+ });
8571
9585
  };
8572
9586
 
8573
9587
  // src/schematic-components/SimpleDiode.tsx
9588
+ var import_jsx_runtime15 = __toESM(require_jsx_runtime());
8574
9589
  var SimpleDiode = ({ component: { source, schematic } }) => {
8575
- return <SVGPathComponent_default rotation={schematic.rotation} center={schematic.center} size={schematic.size} paths={[
8576
- { stroke: "red", strokeWidth: 2, d: "M 0,0 H 21" },
8577
- { stroke: "red", strokeWidth: 2, d: "M 49,0 H 59" },
8578
- { stroke: "red", strokeWidth: 2, d: "M 49,0 L 21 14 V -14 Z" },
8579
- { stroke: "red", strokeWidth: 2, d: "M 49,-14 V 14" }
8580
- ]} />;
9590
+ return /* @__PURE__ */ (0, import_jsx_runtime15.jsx)(SVGPathComponent_default, {
9591
+ rotation: schematic.rotation,
9592
+ center: schematic.center,
9593
+ size: schematic.size,
9594
+ paths: [
9595
+ { stroke: "red", strokeWidth: 2, d: "M 0,0 H 21" },
9596
+ { stroke: "red", strokeWidth: 2, d: "M 49,0 H 59" },
9597
+ { stroke: "red", strokeWidth: 2, d: "M 49,0 L 21 14 V -14 Z" },
9598
+ { stroke: "red", strokeWidth: 2, d: "M 49,-14 V 14" }
9599
+ ]
9600
+ });
8581
9601
  };
8582
9602
  // Annotate the CommonJS export names for ESM import in node:
8583
9603
  0 && (module.exports = {
@@ -8597,6 +9617,24 @@ var SimpleDiode = ({ component: { source, schematic } }) => {
8597
9617
  SimplePowerSource,
8598
9618
  SimpleResistor
8599
9619
  });
9620
+ /**
9621
+ * @license React
9622
+ * react-jsx-runtime.development.js
9623
+ *
9624
+ * Copyright (c) Facebook, Inc. and its affiliates.
9625
+ *
9626
+ * This source code is licensed under the MIT license found in the
9627
+ * LICENSE file in the root directory of this source tree.
9628
+ */
9629
+ /**
9630
+ * @license React
9631
+ * react-jsx-runtime.production.min.js
9632
+ *
9633
+ * Copyright (c) Facebook, Inc. and its affiliates.
9634
+ *
9635
+ * This source code is licensed under the MIT license found in the
9636
+ * LICENSE file in the root directory of this source tree.
9637
+ */
8600
9638
  /**
8601
9639
  * @license React
8602
9640
  * react.development.js