@valbuild/react 0.93.0 → 0.94.0

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.
@@ -292,13 +292,15 @@ function stegaEncode(input, opts) {
292
292
  }
293
293
  if (VAL_EXTENSION in sourceOrSelector) {
294
294
  if (sourceOrSelector[VAL_EXTENSION] === "file" && typeof sourceOrSelector[FILE_REF_PROP] === "string") {
295
- var fileSelector = Internal.convertFileSource(sourceOrSelector);
295
+ var source = recOpts !== null && recOpts !== void 0 && recOpts.schema && opts.getModule ? augmentWithReferencedModuleMetadata(sourceOrSelector, recOpts.schema, opts.getModule) : sourceOrSelector;
296
+ var fileSelector = Internal.convertFileSource(source);
296
297
  var url = fileSelector.url;
297
298
  return _objectSpread2(_objectSpread2({}, fileSelector), {}, {
298
299
  url: rec(url, recOpts)
299
300
  });
300
301
  } else if (sourceOrSelector[VAL_EXTENSION] === "remote") {
301
- var remoteSelector = Internal.convertFileSource(sourceOrSelector);
302
+ var _source = recOpts !== null && recOpts !== void 0 && recOpts.schema && opts.getModule ? augmentWithReferencedModuleMetadata(sourceOrSelector, recOpts.schema, opts.getModule) : sourceOrSelector;
303
+ var remoteSelector = Internal.convertFileSource(_source);
302
304
  var _url = remoteSelector.url;
303
305
  return _objectSpread2(_objectSpread2({}, remoteSelector), {}, {
304
306
  url: rec(_url, recOpts)
@@ -381,6 +383,64 @@ function isRichTextSchema(schema) {
381
383
  function isObjectSchema(schema) {
382
384
  return (schema === null || schema === void 0 ? void 0 : schema.type) === "object";
383
385
  }
386
+ function isFileSchema(schema) {
387
+ return (schema === null || schema === void 0 ? void 0 : schema.type) === "file";
388
+ }
389
+ function isImageSchema(schema) {
390
+ return (schema === null || schema === void 0 ? void 0 : schema.type) === "image";
391
+ }
392
+ function augmentWithReferencedModuleMetadata(source, schema, getModule) {
393
+ if (source.metadata || !(isFileSchema(schema) || isImageSchema(schema)) || !schema.referencedModule) {
394
+ return source;
395
+ }
396
+ var moduleSource = getModule(schema.referencedModule);
397
+ if (!moduleSource || _typeof(moduleSource) !== "object" || Array.isArray(moduleSource)) {
398
+ return source;
399
+ }
400
+ var ref = source[FILE_REF_PROP];
401
+ // For local files the ref is the file path directly; for remote refs we
402
+ // need to extract the file path from the remote URL.
403
+ var fileRef = ref in moduleSource ? ref : null;
404
+ if (!fileRef) {
405
+ var splitResult = Internal.remote.splitRemoteRef(ref);
406
+ if (splitResult.status === "success" && splitResult.filePath in moduleSource) {
407
+ fileRef = splitResult.filePath;
408
+ }
409
+ }
410
+ if (!fileRef) {
411
+ return source;
412
+ }
413
+ return _objectSpread2(_objectSpread2({}, source), {}, {
414
+ metadata: moduleSource[fileRef]
415
+ });
416
+ }
417
+ function collectReferencedModulesFromSchema(schema, acc) {
418
+ if (isFileSchema(schema) || isImageSchema(schema)) {
419
+ if (schema.referencedModule) {
420
+ acc.add(schema.referencedModule);
421
+ }
422
+ } else if (schema.type === "object") {
423
+ for (var _i2 = 0, _Object$values = Object.values(schema.items); _i2 < _Object$values.length; _i2++) {
424
+ var v = _Object$values[_i2];
425
+ collectReferencedModulesFromSchema(v, acc);
426
+ }
427
+ } else if (schema.type === "array" || schema.type === "record") {
428
+ collectReferencedModulesFromSchema(schema.item, acc);
429
+ } else if (schema.type === "union") {
430
+ var _iterator = _createForOfIteratorHelper(schema.items),
431
+ _step;
432
+ try {
433
+ for (_iterator.s(); !(_step = _iterator.n()).done;) {
434
+ var item = _step.value;
435
+ collectReferencedModulesFromSchema(item, acc);
436
+ }
437
+ } catch (err) {
438
+ _iterator.e(err);
439
+ } finally {
440
+ _iterator.f();
441
+ }
442
+ }
443
+ }
384
444
  function stegaClean(source) {
385
445
  return vercelStegaSplit(source).cleaned;
386
446
  }
@@ -394,6 +454,13 @@ function getModuleIds(input) {
394
454
  var selectorPath = Internal.getValPath(sourceOrSelector);
395
455
  if (selectorPath) {
396
456
  modules.add(selectorPath);
457
+ var schema = Internal.getSchema(sourceOrSelector);
458
+ if (schema) {
459
+ var serialized = schema["executeSerialize"]();
460
+ if (serialized) {
461
+ collectReferencedModulesFromSchema(serialized, modules);
462
+ }
463
+ }
397
464
  return;
398
465
  }
399
466
  if (VAL_EXTENSION in sourceOrSelector) {
@@ -411,8 +478,8 @@ function getModuleIds(input) {
411
478
  return;
412
479
  }
413
480
  if (!Array.isArray(sourceOrSelector)) {
414
- for (var _i2 = 0, _Object$entries = Object.entries(sourceOrSelector); _i2 < _Object$entries.length; _i2++) {
415
- var _Object$entries$_i = _slicedToArray(_Object$entries[_i2], 2),
481
+ for (var _i3 = 0, _Object$entries = Object.entries(sourceOrSelector); _i3 < _Object$entries.length; _i3++) {
482
+ var _Object$entries$_i = _slicedToArray(_Object$entries[_i3], 2),
416
483
  value = _Object$entries$_i[1];
417
484
  rec(value);
418
485
  }
@@ -292,13 +292,15 @@ function stegaEncode(input, opts) {
292
292
  }
293
293
  if (VAL_EXTENSION in sourceOrSelector) {
294
294
  if (sourceOrSelector[VAL_EXTENSION] === "file" && typeof sourceOrSelector[FILE_REF_PROP] === "string") {
295
- var fileSelector = Internal.convertFileSource(sourceOrSelector);
295
+ var source = recOpts !== null && recOpts !== void 0 && recOpts.schema && opts.getModule ? augmentWithReferencedModuleMetadata(sourceOrSelector, recOpts.schema, opts.getModule) : sourceOrSelector;
296
+ var fileSelector = Internal.convertFileSource(source);
296
297
  var url = fileSelector.url;
297
298
  return _objectSpread2(_objectSpread2({}, fileSelector), {}, {
298
299
  url: rec(url, recOpts)
299
300
  });
300
301
  } else if (sourceOrSelector[VAL_EXTENSION] === "remote") {
301
- var remoteSelector = Internal.convertFileSource(sourceOrSelector);
302
+ var _source = recOpts !== null && recOpts !== void 0 && recOpts.schema && opts.getModule ? augmentWithReferencedModuleMetadata(sourceOrSelector, recOpts.schema, opts.getModule) : sourceOrSelector;
303
+ var remoteSelector = Internal.convertFileSource(_source);
302
304
  var _url = remoteSelector.url;
303
305
  return _objectSpread2(_objectSpread2({}, remoteSelector), {}, {
304
306
  url: rec(_url, recOpts)
@@ -381,6 +383,64 @@ function isRichTextSchema(schema) {
381
383
  function isObjectSchema(schema) {
382
384
  return (schema === null || schema === void 0 ? void 0 : schema.type) === "object";
383
385
  }
386
+ function isFileSchema(schema) {
387
+ return (schema === null || schema === void 0 ? void 0 : schema.type) === "file";
388
+ }
389
+ function isImageSchema(schema) {
390
+ return (schema === null || schema === void 0 ? void 0 : schema.type) === "image";
391
+ }
392
+ function augmentWithReferencedModuleMetadata(source, schema, getModule) {
393
+ if (source.metadata || !(isFileSchema(schema) || isImageSchema(schema)) || !schema.referencedModule) {
394
+ return source;
395
+ }
396
+ var moduleSource = getModule(schema.referencedModule);
397
+ if (!moduleSource || _typeof(moduleSource) !== "object" || Array.isArray(moduleSource)) {
398
+ return source;
399
+ }
400
+ var ref = source[FILE_REF_PROP];
401
+ // For local files the ref is the file path directly; for remote refs we
402
+ // need to extract the file path from the remote URL.
403
+ var fileRef = ref in moduleSource ? ref : null;
404
+ if (!fileRef) {
405
+ var splitResult = Internal.remote.splitRemoteRef(ref);
406
+ if (splitResult.status === "success" && splitResult.filePath in moduleSource) {
407
+ fileRef = splitResult.filePath;
408
+ }
409
+ }
410
+ if (!fileRef) {
411
+ return source;
412
+ }
413
+ return _objectSpread2(_objectSpread2({}, source), {}, {
414
+ metadata: moduleSource[fileRef]
415
+ });
416
+ }
417
+ function collectReferencedModulesFromSchema(schema, acc) {
418
+ if (isFileSchema(schema) || isImageSchema(schema)) {
419
+ if (schema.referencedModule) {
420
+ acc.add(schema.referencedModule);
421
+ }
422
+ } else if (schema.type === "object") {
423
+ for (var _i2 = 0, _Object$values = Object.values(schema.items); _i2 < _Object$values.length; _i2++) {
424
+ var v = _Object$values[_i2];
425
+ collectReferencedModulesFromSchema(v, acc);
426
+ }
427
+ } else if (schema.type === "array" || schema.type === "record") {
428
+ collectReferencedModulesFromSchema(schema.item, acc);
429
+ } else if (schema.type === "union") {
430
+ var _iterator = _createForOfIteratorHelper(schema.items),
431
+ _step;
432
+ try {
433
+ for (_iterator.s(); !(_step = _iterator.n()).done;) {
434
+ var item = _step.value;
435
+ collectReferencedModulesFromSchema(item, acc);
436
+ }
437
+ } catch (err) {
438
+ _iterator.e(err);
439
+ } finally {
440
+ _iterator.f();
441
+ }
442
+ }
443
+ }
384
444
  function stegaClean(source) {
385
445
  return vercelStegaSplit(source).cleaned;
386
446
  }
@@ -394,6 +454,13 @@ function getModuleIds(input) {
394
454
  var selectorPath = Internal.getValPath(sourceOrSelector);
395
455
  if (selectorPath) {
396
456
  modules.add(selectorPath);
457
+ var schema = Internal.getSchema(sourceOrSelector);
458
+ if (schema) {
459
+ var serialized = schema["executeSerialize"]();
460
+ if (serialized) {
461
+ collectReferencedModulesFromSchema(serialized, modules);
462
+ }
463
+ }
397
464
  return;
398
465
  }
399
466
  if (VAL_EXTENSION in sourceOrSelector) {
@@ -411,8 +478,8 @@ function getModuleIds(input) {
411
478
  return;
412
479
  }
413
480
  if (!Array.isArray(sourceOrSelector)) {
414
- for (var _i2 = 0, _Object$entries = Object.entries(sourceOrSelector); _i2 < _Object$entries.length; _i2++) {
415
- var _Object$entries$_i = _slicedToArray(_Object$entries[_i2], 2),
481
+ for (var _i3 = 0, _Object$entries = Object.entries(sourceOrSelector); _i3 < _Object$entries.length; _i3++) {
482
+ var _Object$entries$_i = _slicedToArray(_Object$entries[_i3], 2),
416
483
  value = _Object$entries$_i[1];
417
484
  rec(value);
418
485
  }
@@ -294,13 +294,15 @@ function stegaEncode(input, opts) {
294
294
  }
295
295
  if (core.VAL_EXTENSION in sourceOrSelector) {
296
296
  if (sourceOrSelector[core.VAL_EXTENSION] === "file" && typeof sourceOrSelector[core.FILE_REF_PROP] === "string") {
297
- var fileSelector = core.Internal.convertFileSource(sourceOrSelector);
297
+ var source = recOpts !== null && recOpts !== void 0 && recOpts.schema && opts.getModule ? augmentWithReferencedModuleMetadata(sourceOrSelector, recOpts.schema, opts.getModule) : sourceOrSelector;
298
+ var fileSelector = core.Internal.convertFileSource(source);
298
299
  var url = fileSelector.url;
299
300
  return _objectSpread2(_objectSpread2({}, fileSelector), {}, {
300
301
  url: rec(url, recOpts)
301
302
  });
302
303
  } else if (sourceOrSelector[core.VAL_EXTENSION] === "remote") {
303
- var remoteSelector = core.Internal.convertFileSource(sourceOrSelector);
304
+ var _source = recOpts !== null && recOpts !== void 0 && recOpts.schema && opts.getModule ? augmentWithReferencedModuleMetadata(sourceOrSelector, recOpts.schema, opts.getModule) : sourceOrSelector;
305
+ var remoteSelector = core.Internal.convertFileSource(_source);
304
306
  var _url = remoteSelector.url;
305
307
  return _objectSpread2(_objectSpread2({}, remoteSelector), {}, {
306
308
  url: rec(_url, recOpts)
@@ -383,6 +385,64 @@ function isRichTextSchema(schema) {
383
385
  function isObjectSchema(schema) {
384
386
  return (schema === null || schema === void 0 ? void 0 : schema.type) === "object";
385
387
  }
388
+ function isFileSchema(schema) {
389
+ return (schema === null || schema === void 0 ? void 0 : schema.type) === "file";
390
+ }
391
+ function isImageSchema(schema) {
392
+ return (schema === null || schema === void 0 ? void 0 : schema.type) === "image";
393
+ }
394
+ function augmentWithReferencedModuleMetadata(source, schema, getModule) {
395
+ if (source.metadata || !(isFileSchema(schema) || isImageSchema(schema)) || !schema.referencedModule) {
396
+ return source;
397
+ }
398
+ var moduleSource = getModule(schema.referencedModule);
399
+ if (!moduleSource || slicedToArray._typeof(moduleSource) !== "object" || Array.isArray(moduleSource)) {
400
+ return source;
401
+ }
402
+ var ref = source[core.FILE_REF_PROP];
403
+ // For local files the ref is the file path directly; for remote refs we
404
+ // need to extract the file path from the remote URL.
405
+ var fileRef = ref in moduleSource ? ref : null;
406
+ if (!fileRef) {
407
+ var splitResult = core.Internal.remote.splitRemoteRef(ref);
408
+ if (splitResult.status === "success" && splitResult.filePath in moduleSource) {
409
+ fileRef = splitResult.filePath;
410
+ }
411
+ }
412
+ if (!fileRef) {
413
+ return source;
414
+ }
415
+ return _objectSpread2(_objectSpread2({}, source), {}, {
416
+ metadata: moduleSource[fileRef]
417
+ });
418
+ }
419
+ function collectReferencedModulesFromSchema(schema, acc) {
420
+ if (isFileSchema(schema) || isImageSchema(schema)) {
421
+ if (schema.referencedModule) {
422
+ acc.add(schema.referencedModule);
423
+ }
424
+ } else if (schema.type === "object") {
425
+ for (var _i2 = 0, _Object$values = Object.values(schema.items); _i2 < _Object$values.length; _i2++) {
426
+ var v = _Object$values[_i2];
427
+ collectReferencedModulesFromSchema(v, acc);
428
+ }
429
+ } else if (schema.type === "array" || schema.type === "record") {
430
+ collectReferencedModulesFromSchema(schema.item, acc);
431
+ } else if (schema.type === "union") {
432
+ var _iterator = _createForOfIteratorHelper(schema.items),
433
+ _step;
434
+ try {
435
+ for (_iterator.s(); !(_step = _iterator.n()).done;) {
436
+ var item = _step.value;
437
+ collectReferencedModulesFromSchema(item, acc);
438
+ }
439
+ } catch (err) {
440
+ _iterator.e(err);
441
+ } finally {
442
+ _iterator.f();
443
+ }
444
+ }
445
+ }
386
446
  function stegaClean(source) {
387
447
  return stega.vercelStegaSplit(source).cleaned;
388
448
  }
@@ -396,6 +456,13 @@ function getModuleIds(input) {
396
456
  var selectorPath = core.Internal.getValPath(sourceOrSelector);
397
457
  if (selectorPath) {
398
458
  modules.add(selectorPath);
459
+ var schema = core.Internal.getSchema(sourceOrSelector);
460
+ if (schema) {
461
+ var serialized = schema["executeSerialize"]();
462
+ if (serialized) {
463
+ collectReferencedModulesFromSchema(serialized, modules);
464
+ }
465
+ }
399
466
  return;
400
467
  }
401
468
  if (core.VAL_EXTENSION in sourceOrSelector) {
@@ -413,8 +480,8 @@ function getModuleIds(input) {
413
480
  return;
414
481
  }
415
482
  if (!Array.isArray(sourceOrSelector)) {
416
- for (var _i2 = 0, _Object$entries = Object.entries(sourceOrSelector); _i2 < _Object$entries.length; _i2++) {
417
- var _Object$entries$_i = slicedToArray._slicedToArray(_Object$entries[_i2], 2),
483
+ for (var _i3 = 0, _Object$entries = Object.entries(sourceOrSelector); _i3 < _Object$entries.length; _i3++) {
484
+ var _Object$entries$_i = slicedToArray._slicedToArray(_Object$entries[_i3], 2),
418
485
  value = _Object$entries$_i[1];
419
486
  rec(value);
420
487
  }
@@ -292,13 +292,15 @@ function stegaEncode(input, opts) {
292
292
  }
293
293
  if (VAL_EXTENSION in sourceOrSelector) {
294
294
  if (sourceOrSelector[VAL_EXTENSION] === "file" && typeof sourceOrSelector[FILE_REF_PROP] === "string") {
295
- var fileSelector = Internal.convertFileSource(sourceOrSelector);
295
+ var source = recOpts !== null && recOpts !== void 0 && recOpts.schema && opts.getModule ? augmentWithReferencedModuleMetadata(sourceOrSelector, recOpts.schema, opts.getModule) : sourceOrSelector;
296
+ var fileSelector = Internal.convertFileSource(source);
296
297
  var url = fileSelector.url;
297
298
  return _objectSpread2(_objectSpread2({}, fileSelector), {}, {
298
299
  url: rec(url, recOpts)
299
300
  });
300
301
  } else if (sourceOrSelector[VAL_EXTENSION] === "remote") {
301
- var remoteSelector = Internal.convertFileSource(sourceOrSelector);
302
+ var _source = recOpts !== null && recOpts !== void 0 && recOpts.schema && opts.getModule ? augmentWithReferencedModuleMetadata(sourceOrSelector, recOpts.schema, opts.getModule) : sourceOrSelector;
303
+ var remoteSelector = Internal.convertFileSource(_source);
302
304
  var _url = remoteSelector.url;
303
305
  return _objectSpread2(_objectSpread2({}, remoteSelector), {}, {
304
306
  url: rec(_url, recOpts)
@@ -381,6 +383,64 @@ function isRichTextSchema(schema) {
381
383
  function isObjectSchema(schema) {
382
384
  return (schema === null || schema === void 0 ? void 0 : schema.type) === "object";
383
385
  }
386
+ function isFileSchema(schema) {
387
+ return (schema === null || schema === void 0 ? void 0 : schema.type) === "file";
388
+ }
389
+ function isImageSchema(schema) {
390
+ return (schema === null || schema === void 0 ? void 0 : schema.type) === "image";
391
+ }
392
+ function augmentWithReferencedModuleMetadata(source, schema, getModule) {
393
+ if (source.metadata || !(isFileSchema(schema) || isImageSchema(schema)) || !schema.referencedModule) {
394
+ return source;
395
+ }
396
+ var moduleSource = getModule(schema.referencedModule);
397
+ if (!moduleSource || _typeof(moduleSource) !== "object" || Array.isArray(moduleSource)) {
398
+ return source;
399
+ }
400
+ var ref = source[FILE_REF_PROP];
401
+ // For local files the ref is the file path directly; for remote refs we
402
+ // need to extract the file path from the remote URL.
403
+ var fileRef = ref in moduleSource ? ref : null;
404
+ if (!fileRef) {
405
+ var splitResult = Internal.remote.splitRemoteRef(ref);
406
+ if (splitResult.status === "success" && splitResult.filePath in moduleSource) {
407
+ fileRef = splitResult.filePath;
408
+ }
409
+ }
410
+ if (!fileRef) {
411
+ return source;
412
+ }
413
+ return _objectSpread2(_objectSpread2({}, source), {}, {
414
+ metadata: moduleSource[fileRef]
415
+ });
416
+ }
417
+ function collectReferencedModulesFromSchema(schema, acc) {
418
+ if (isFileSchema(schema) || isImageSchema(schema)) {
419
+ if (schema.referencedModule) {
420
+ acc.add(schema.referencedModule);
421
+ }
422
+ } else if (schema.type === "object") {
423
+ for (var _i2 = 0, _Object$values = Object.values(schema.items); _i2 < _Object$values.length; _i2++) {
424
+ var v = _Object$values[_i2];
425
+ collectReferencedModulesFromSchema(v, acc);
426
+ }
427
+ } else if (schema.type === "array" || schema.type === "record") {
428
+ collectReferencedModulesFromSchema(schema.item, acc);
429
+ } else if (schema.type === "union") {
430
+ var _iterator = _createForOfIteratorHelper(schema.items),
431
+ _step;
432
+ try {
433
+ for (_iterator.s(); !(_step = _iterator.n()).done;) {
434
+ var item = _step.value;
435
+ collectReferencedModulesFromSchema(item, acc);
436
+ }
437
+ } catch (err) {
438
+ _iterator.e(err);
439
+ } finally {
440
+ _iterator.f();
441
+ }
442
+ }
443
+ }
384
444
  function stegaClean(source) {
385
445
  return vercelStegaSplit(source).cleaned;
386
446
  }
@@ -394,6 +454,13 @@ function getModuleIds(input) {
394
454
  var selectorPath = Internal.getValPath(sourceOrSelector);
395
455
  if (selectorPath) {
396
456
  modules.add(selectorPath);
457
+ var schema = Internal.getSchema(sourceOrSelector);
458
+ if (schema) {
459
+ var serialized = schema["executeSerialize"]();
460
+ if (serialized) {
461
+ collectReferencedModulesFromSchema(serialized, modules);
462
+ }
463
+ }
397
464
  return;
398
465
  }
399
466
  if (VAL_EXTENSION in sourceOrSelector) {
@@ -411,8 +478,8 @@ function getModuleIds(input) {
411
478
  return;
412
479
  }
413
480
  if (!Array.isArray(sourceOrSelector)) {
414
- for (var _i2 = 0, _Object$entries = Object.entries(sourceOrSelector); _i2 < _Object$entries.length; _i2++) {
415
- var _Object$entries$_i = _slicedToArray(_Object$entries[_i2], 2),
481
+ for (var _i3 = 0, _Object$entries = Object.entries(sourceOrSelector); _i3 < _Object$entries.length; _i3++) {
482
+ var _Object$entries$_i = _slicedToArray(_Object$entries[_i3], 2),
416
483
  value = _Object$entries$_i[1];
417
484
  rec(value);
418
485
  }
@@ -294,13 +294,15 @@ function stegaEncode(input, opts) {
294
294
  }
295
295
  if (core.VAL_EXTENSION in sourceOrSelector) {
296
296
  if (sourceOrSelector[core.VAL_EXTENSION] === "file" && typeof sourceOrSelector[core.FILE_REF_PROP] === "string") {
297
- var fileSelector = core.Internal.convertFileSource(sourceOrSelector);
297
+ var source = recOpts !== null && recOpts !== void 0 && recOpts.schema && opts.getModule ? augmentWithReferencedModuleMetadata(sourceOrSelector, recOpts.schema, opts.getModule) : sourceOrSelector;
298
+ var fileSelector = core.Internal.convertFileSource(source);
298
299
  var url = fileSelector.url;
299
300
  return _objectSpread2(_objectSpread2({}, fileSelector), {}, {
300
301
  url: rec(url, recOpts)
301
302
  });
302
303
  } else if (sourceOrSelector[core.VAL_EXTENSION] === "remote") {
303
- var remoteSelector = core.Internal.convertFileSource(sourceOrSelector);
304
+ var _source = recOpts !== null && recOpts !== void 0 && recOpts.schema && opts.getModule ? augmentWithReferencedModuleMetadata(sourceOrSelector, recOpts.schema, opts.getModule) : sourceOrSelector;
305
+ var remoteSelector = core.Internal.convertFileSource(_source);
304
306
  var _url = remoteSelector.url;
305
307
  return _objectSpread2(_objectSpread2({}, remoteSelector), {}, {
306
308
  url: rec(_url, recOpts)
@@ -383,6 +385,64 @@ function isRichTextSchema(schema) {
383
385
  function isObjectSchema(schema) {
384
386
  return (schema === null || schema === void 0 ? void 0 : schema.type) === "object";
385
387
  }
388
+ function isFileSchema(schema) {
389
+ return (schema === null || schema === void 0 ? void 0 : schema.type) === "file";
390
+ }
391
+ function isImageSchema(schema) {
392
+ return (schema === null || schema === void 0 ? void 0 : schema.type) === "image";
393
+ }
394
+ function augmentWithReferencedModuleMetadata(source, schema, getModule) {
395
+ if (source.metadata || !(isFileSchema(schema) || isImageSchema(schema)) || !schema.referencedModule) {
396
+ return source;
397
+ }
398
+ var moduleSource = getModule(schema.referencedModule);
399
+ if (!moduleSource || slicedToArray._typeof(moduleSource) !== "object" || Array.isArray(moduleSource)) {
400
+ return source;
401
+ }
402
+ var ref = source[core.FILE_REF_PROP];
403
+ // For local files the ref is the file path directly; for remote refs we
404
+ // need to extract the file path from the remote URL.
405
+ var fileRef = ref in moduleSource ? ref : null;
406
+ if (!fileRef) {
407
+ var splitResult = core.Internal.remote.splitRemoteRef(ref);
408
+ if (splitResult.status === "success" && splitResult.filePath in moduleSource) {
409
+ fileRef = splitResult.filePath;
410
+ }
411
+ }
412
+ if (!fileRef) {
413
+ return source;
414
+ }
415
+ return _objectSpread2(_objectSpread2({}, source), {}, {
416
+ metadata: moduleSource[fileRef]
417
+ });
418
+ }
419
+ function collectReferencedModulesFromSchema(schema, acc) {
420
+ if (isFileSchema(schema) || isImageSchema(schema)) {
421
+ if (schema.referencedModule) {
422
+ acc.add(schema.referencedModule);
423
+ }
424
+ } else if (schema.type === "object") {
425
+ for (var _i2 = 0, _Object$values = Object.values(schema.items); _i2 < _Object$values.length; _i2++) {
426
+ var v = _Object$values[_i2];
427
+ collectReferencedModulesFromSchema(v, acc);
428
+ }
429
+ } else if (schema.type === "array" || schema.type === "record") {
430
+ collectReferencedModulesFromSchema(schema.item, acc);
431
+ } else if (schema.type === "union") {
432
+ var _iterator = _createForOfIteratorHelper(schema.items),
433
+ _step;
434
+ try {
435
+ for (_iterator.s(); !(_step = _iterator.n()).done;) {
436
+ var item = _step.value;
437
+ collectReferencedModulesFromSchema(item, acc);
438
+ }
439
+ } catch (err) {
440
+ _iterator.e(err);
441
+ } finally {
442
+ _iterator.f();
443
+ }
444
+ }
445
+ }
386
446
  function stegaClean(source) {
387
447
  return stega.vercelStegaSplit(source).cleaned;
388
448
  }
@@ -396,6 +456,13 @@ function getModuleIds(input) {
396
456
  var selectorPath = core.Internal.getValPath(sourceOrSelector);
397
457
  if (selectorPath) {
398
458
  modules.add(selectorPath);
459
+ var schema = core.Internal.getSchema(sourceOrSelector);
460
+ if (schema) {
461
+ var serialized = schema["executeSerialize"]();
462
+ if (serialized) {
463
+ collectReferencedModulesFromSchema(serialized, modules);
464
+ }
465
+ }
399
466
  return;
400
467
  }
401
468
  if (core.VAL_EXTENSION in sourceOrSelector) {
@@ -413,8 +480,8 @@ function getModuleIds(input) {
413
480
  return;
414
481
  }
415
482
  if (!Array.isArray(sourceOrSelector)) {
416
- for (var _i2 = 0, _Object$entries = Object.entries(sourceOrSelector); _i2 < _Object$entries.length; _i2++) {
417
- var _Object$entries$_i = slicedToArray._slicedToArray(_Object$entries[_i2], 2),
483
+ for (var _i3 = 0, _Object$entries = Object.entries(sourceOrSelector); _i3 < _Object$entries.length; _i3++) {
484
+ var _Object$entries$_i = slicedToArray._slicedToArray(_Object$entries[_i3], 2),
418
485
  value = _Object$entries$_i[1];
419
486
  rec(value);
420
487
  }
@@ -1,4 +1,4 @@
1
- import { d as _objectSpread2, r as raw, c as attrs, e as _toConsumableArray } from '../../dist/raw-d86c2721.browser.esm.js';
1
+ import { d as _objectSpread2, r as raw, c as attrs, e as _toConsumableArray } from '../../dist/raw-f81b3458.browser.esm.js';
2
2
  import React from 'react';
3
3
  import { jsx } from 'react/jsx-runtime';
4
4
  import '../../dist/slicedToArray-9cce0d9f.browser.esm.js';
@@ -2,7 +2,7 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- var raw = require('../../dist/raw-8632c70b.cjs.dev.js');
5
+ var raw = require('../../dist/raw-8092b516.cjs.dev.js');
6
6
  var React = require('react');
7
7
  var ReactJSXRuntime = require('react/jsx-runtime');
8
8
  require('../../dist/slicedToArray-e9e8e991.cjs.dev.js');
@@ -2,7 +2,7 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- var raw = require('../../dist/raw-30090bf4.cjs.prod.js');
5
+ var raw = require('../../dist/raw-ff4c049d.cjs.prod.js');
6
6
  var React = require('react');
7
7
  var ReactJSXRuntime = require('react/jsx-runtime');
8
8
  require('../../dist/slicedToArray-86004d59.cjs.prod.js');
@@ -1,4 +1,4 @@
1
- import { d as _objectSpread2, r as raw, c as attrs, e as _toConsumableArray } from '../../dist/raw-4e13e7bb.esm.js';
1
+ import { d as _objectSpread2, r as raw, c as attrs, e as _toConsumableArray } from '../../dist/raw-0faf5cab.esm.js';
2
2
  import React from 'react';
3
3
  import { jsx } from 'react/jsx-runtime';
4
4
  import '../../dist/slicedToArray-0c0a3b4a.esm.js';
@@ -1,4 +1,4 @@
1
- import { d as _objectSpread2, r as raw, c as attrs, e as _toConsumableArray } from '../../dist/raw-e3c9e04a.worker.esm.js';
1
+ import { d as _objectSpread2, r as raw, c as attrs, e as _toConsumableArray } from '../../dist/raw-0dce4c18.worker.esm.js';
2
2
  import React from 'react';
3
3
  import { jsx } from 'react/jsx-runtime';
4
4
  import '../../dist/slicedToArray-7d0170b6.worker.esm.js';
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@valbuild/react",
3
- "version": "0.93.0",
3
+ "version": "0.94.0",
4
4
  "private": false,
5
5
  "description": "Val - React internal helpers",
6
6
  "repository": {
@@ -11,9 +11,9 @@
11
11
  "dependencies": {
12
12
  "@vercel/stega": "^0.1.0",
13
13
  "base64-arraybuffer": "^1.0.2",
14
- "@valbuild/core": "0.93.0",
15
- "@valbuild/shared": "0.93.0",
16
- "@valbuild/ui": "0.93.0"
14
+ "@valbuild/core": "0.94.0",
15
+ "@valbuild/shared": "0.94.0",
16
+ "@valbuild/ui": "0.94.0"
17
17
  },
18
18
  "devDependencies": {
19
19
  "@testing-library/react": "^14.0.0",
@@ -1,6 +1,6 @@
1
1
  import { a as _typeof, _ as _slicedToArray } from '../../dist/slicedToArray-9cce0d9f.browser.esm.js';
2
- import { s as stegaDecodeStrings, _ as _createForOfIteratorHelper } from '../../dist/raw-d86c2721.browser.esm.js';
3
- export { c as attrs, g as getModuleIds, r as raw, b as stegaClean, s as stegaDecodeStrings, a as stegaEncode } from '../../dist/raw-d86c2721.browser.esm.js';
2
+ import { s as stegaDecodeStrings, _ as _createForOfIteratorHelper } from '../../dist/raw-f81b3458.browser.esm.js';
3
+ export { c as attrs, g as getModuleIds, r as raw, b as stegaClean, s as stegaDecodeStrings, a as stegaEncode } from '../../dist/raw-f81b3458.browser.esm.js';
4
4
  import ReactJSXRuntime__default from 'react/jsx-runtime';
5
5
  import jsxRuntimeDev__default from 'react/jsx-dev-runtime';
6
6
  import React from 'react';
@@ -50,7 +50,7 @@ var addValPathIfFound = function addValPathIfFound(type, props) {
50
50
  } finally {
51
51
  _iterator.f();
52
52
  }
53
- if (isIntrinsicElement(type)) {
53
+ if (isIntrinsicElement(type) && !Object.isFrozen(container)) {
54
54
  // clean values before adding them to the props
55
55
  // we cannot do this
56
56
  var cleanValue = vercelStegaSplit(value).cleaned;
@@ -3,7 +3,7 @@
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
5
  var slicedToArray = require('../../dist/slicedToArray-e9e8e991.cjs.dev.js');
6
- var raw = require('../../dist/raw-8632c70b.cjs.dev.js');
6
+ var raw = require('../../dist/raw-8092b516.cjs.dev.js');
7
7
  var ReactJSXRuntime = require('react/jsx-runtime');
8
8
  var jsxRuntimeDev = require('react/jsx-dev-runtime');
9
9
  var React = require('react');
@@ -59,7 +59,7 @@ var addValPathIfFound = function addValPathIfFound(type, props) {
59
59
  } finally {
60
60
  _iterator.f();
61
61
  }
62
- if (isIntrinsicElement(type)) {
62
+ if (isIntrinsicElement(type) && !Object.isFrozen(container)) {
63
63
  // clean values before adding them to the props
64
64
  // we cannot do this
65
65
  var cleanValue = stega.vercelStegaSplit(value).cleaned;
@@ -3,7 +3,7 @@
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
5
  var slicedToArray = require('../../dist/slicedToArray-86004d59.cjs.prod.js');
6
- var raw = require('../../dist/raw-30090bf4.cjs.prod.js');
6
+ var raw = require('../../dist/raw-ff4c049d.cjs.prod.js');
7
7
  var ReactJSXRuntime = require('react/jsx-runtime');
8
8
  var jsxRuntimeDev = require('react/jsx-dev-runtime');
9
9
  var React = require('react');
@@ -59,7 +59,7 @@ var addValPathIfFound = function addValPathIfFound(type, props) {
59
59
  } finally {
60
60
  _iterator.f();
61
61
  }
62
- if (isIntrinsicElement(type)) {
62
+ if (isIntrinsicElement(type) && !Object.isFrozen(container)) {
63
63
  // clean values before adding them to the props
64
64
  // we cannot do this
65
65
  var cleanValue = stega.vercelStegaSplit(value).cleaned;
@@ -1,6 +1,6 @@
1
1
  import { a as _typeof, _ as _slicedToArray } from '../../dist/slicedToArray-0c0a3b4a.esm.js';
2
- import { s as stegaDecodeStrings, _ as _createForOfIteratorHelper } from '../../dist/raw-4e13e7bb.esm.js';
3
- export { c as attrs, g as getModuleIds, r as raw, b as stegaClean, s as stegaDecodeStrings, a as stegaEncode } from '../../dist/raw-4e13e7bb.esm.js';
2
+ import { s as stegaDecodeStrings, _ as _createForOfIteratorHelper } from '../../dist/raw-0faf5cab.esm.js';
3
+ export { c as attrs, g as getModuleIds, r as raw, b as stegaClean, s as stegaDecodeStrings, a as stegaEncode } from '../../dist/raw-0faf5cab.esm.js';
4
4
  import ReactJSXRuntime__default from 'react/jsx-runtime';
5
5
  import jsxRuntimeDev__default from 'react/jsx-dev-runtime';
6
6
  import React from 'react';
@@ -50,7 +50,7 @@ var addValPathIfFound = function addValPathIfFound(type, props) {
50
50
  } finally {
51
51
  _iterator.f();
52
52
  }
53
- if (isIntrinsicElement(type)) {
53
+ if (isIntrinsicElement(type) && !Object.isFrozen(container)) {
54
54
  // clean values before adding them to the props
55
55
  // we cannot do this
56
56
  var cleanValue = vercelStegaSplit(value).cleaned;
@@ -1,6 +1,6 @@
1
1
  import { a as _typeof, _ as _slicedToArray } from '../../dist/slicedToArray-7d0170b6.worker.esm.js';
2
- import { s as stegaDecodeStrings, _ as _createForOfIteratorHelper } from '../../dist/raw-e3c9e04a.worker.esm.js';
3
- export { c as attrs, g as getModuleIds, r as raw, b as stegaClean, s as stegaDecodeStrings, a as stegaEncode } from '../../dist/raw-e3c9e04a.worker.esm.js';
2
+ import { s as stegaDecodeStrings, _ as _createForOfIteratorHelper } from '../../dist/raw-0dce4c18.worker.esm.js';
3
+ export { c as attrs, g as getModuleIds, r as raw, b as stegaClean, s as stegaDecodeStrings, a as stegaEncode } from '../../dist/raw-0dce4c18.worker.esm.js';
4
4
  import ReactJSXRuntime__default from 'react/jsx-runtime';
5
5
  import jsxRuntimeDev__default from 'react/jsx-dev-runtime';
6
6
  import React from 'react';
@@ -50,7 +50,7 @@ var addValPathIfFound = function addValPathIfFound(type, props) {
50
50
  } finally {
51
51
  _iterator.f();
52
52
  }
53
- if (isIntrinsicElement(type)) {
53
+ if (isIntrinsicElement(type) && !Object.isFrozen(container)) {
54
54
  // clean values before adding them to the props
55
55
  // we cannot do this
56
56
  var cleanValue = vercelStegaSplit(value).cleaned;