@plasmicpkgs/plasmic-cms 0.0.231 → 0.0.232

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.
@@ -1,4 +1,4 @@
1
- import { CanvasComponentProps, ComponentMeta } from "@plasmicapp/host/registerComponent";
1
+ import { CanvasComponentProps, CodeComponentMeta } from "@plasmicapp/host/registerComponent";
2
2
  import { GlobalContextMeta } from "@plasmicapp/host/registerGlobalContext";
3
3
  import React from "react";
4
4
  import { DatabaseConfig, QueryParams } from "./api";
@@ -17,6 +17,7 @@ interface TableContextData extends TablesContextData {
17
17
  interface RowContextData extends TableContextData {
18
18
  row?: ApiCmsRow;
19
19
  fieldMeta?: CmsFieldMeta;
20
+ data?: object;
20
21
  }
21
22
  interface CmsQueryRepeaterProps extends QueryParams, CanvasComponentProps<TableContextData> {
22
23
  children: React.ReactNode;
@@ -32,21 +33,21 @@ interface CmsQueryRepeaterProps extends QueryParams, CanvasComponentProps<TableC
32
33
  filterValue?: string;
33
34
  mode?: "rows" | "count";
34
35
  }
35
- export declare const cmsQueryRepeaterMeta: ComponentMeta<CmsQueryRepeaterProps>;
36
+ export declare const cmsQueryRepeaterMeta: CodeComponentMeta<CmsQueryRepeaterProps>;
36
37
  export declare function CmsQueryRepeater({ table, children, setControlContextData, mode, where, useDraft, orderBy, desc, limit, offset, emptyMessage, forceEmptyState, loadingMessage, forceLoadingState, noLayout, noAutoRepeat, className, filterField, filterValue, }: CmsQueryRepeaterProps): React.JSX.Element;
37
38
  interface CmsRowFieldProps extends CanvasComponentProps<RowContextData> {
38
39
  table: string;
39
- field: string;
40
+ field?: string | string[];
40
41
  className?: string;
41
42
  dateFormat?: string;
42
43
  }
43
- export declare const cmsRowFieldMeta: ComponentMeta<CmsRowFieldProps>;
44
+ export declare const cmsRowFieldMeta: CodeComponentMeta<CmsRowFieldProps>;
44
45
  export declare function CmsRowField({ className, table, field, dateFormat, setControlContextData, ...rest }: CmsRowFieldProps): React.JSX.Element | null;
45
46
  interface CmsCountProps extends CanvasComponentProps<RowContextData> {
46
47
  table: string;
47
48
  className?: string;
48
49
  }
49
- export declare const cmsCountFieldMeta: ComponentMeta<CmsCountProps>;
50
+ export declare const cmsCountFieldMeta: CodeComponentMeta<CmsCountProps>;
50
51
  export declare function CmsCount({ className, table, setControlContextData, ...rest }: CmsCountProps): React.JSX.Element | null;
51
52
  interface CmsRowLinkProps extends CanvasComponentProps<RowContextData> {
52
53
  table: string;
@@ -56,7 +57,7 @@ interface CmsRowLinkProps extends CanvasComponentProps<RowContextData> {
56
57
  prefix?: string;
57
58
  suffix?: string;
58
59
  }
59
- export declare const cmsRowLinkMeta: ComponentMeta<CmsRowLinkProps>;
60
+ export declare const cmsRowLinkMeta: CodeComponentMeta<CmsRowLinkProps>;
60
61
  export declare function CmsRowLink({ table, field, hrefProp, children, setControlContextData, prefix, suffix, }: CmsRowLinkProps): React.ReactElement | null;
61
62
  interface CmsRowImageProps extends CanvasComponentProps<RowContextData> {
62
63
  table: string;
@@ -64,7 +65,7 @@ interface CmsRowImageProps extends CanvasComponentProps<RowContextData> {
64
65
  srcProp: string;
65
66
  children: React.ReactNode;
66
67
  }
67
- export declare const cmsRowImageMeta: ComponentMeta<CmsRowImageProps>;
68
+ export declare const cmsRowImageMeta: CodeComponentMeta<CmsRowImageProps>;
68
69
  export declare function CmsRowImage({ table, field, srcProp, children, setControlContextData, }: CmsRowImageProps): React.ReactElement | null;
69
70
  interface CmsRowFieldValueProps extends CanvasComponentProps<RowContextData> {
70
71
  table: string;
@@ -72,6 +73,6 @@ interface CmsRowFieldValueProps extends CanvasComponentProps<RowContextData> {
72
73
  valueProp: string;
73
74
  children: React.ReactNode;
74
75
  }
75
- export declare const cmsRowFieldValueMeta: ComponentMeta<CmsRowFieldValueProps>;
76
+ export declare const cmsRowFieldValueMeta: CodeComponentMeta<CmsRowFieldValueProps>;
76
77
  export declare function CmsRowFieldValue({ table, field, valueProp, children, setControlContextData, ...rest }: CmsRowFieldValueProps): React.ReactElement | null;
77
78
  export {};
@@ -441,6 +441,37 @@ function _objectWithoutPropertiesLoose(source, excluded) {
441
441
  }
442
442
  return target;
443
443
  }
444
+ function _unsupportedIterableToArray(o, minLen) {
445
+ if (!o) return;
446
+ if (typeof o === "string") return _arrayLikeToArray(o, minLen);
447
+ var n = Object.prototype.toString.call(o).slice(8, -1);
448
+ if (n === "Object" && o.constructor) n = o.constructor.name;
449
+ if (n === "Map" || n === "Set") return Array.from(o);
450
+ if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen);
451
+ }
452
+ function _arrayLikeToArray(arr, len) {
453
+ if (len == null || len > arr.length) len = arr.length;
454
+ for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i];
455
+ return arr2;
456
+ }
457
+ function _createForOfIteratorHelperLoose(o, allowArrayLike) {
458
+ var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"];
459
+ if (it) return (it = it.call(o)).next.bind(it);
460
+ if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") {
461
+ if (it) o = it;
462
+ var i = 0;
463
+ return function () {
464
+ if (i >= o.length) return {
465
+ done: true
466
+ };
467
+ return {
468
+ done: false,
469
+ value: o[i++]
470
+ };
471
+ };
472
+ }
473
+ throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
474
+ }
444
475
 
445
476
  function queryParamsToApi(params) {
446
477
  return {
@@ -801,6 +832,26 @@ function mkTableOptions(tables) {
801
832
  };
802
833
  });
803
834
  }
835
+ function addNestedFieldOptions(fields, prefix) {
836
+ if (prefix === void 0) {
837
+ prefix = "";
838
+ }
839
+ var options = [];
840
+ fields.forEach(function (field) {
841
+ var fieldPath = prefix + field.identifier;
842
+ if (field.type !== "object") {
843
+ options.push({
844
+ value: fieldPath,
845
+ label: field.name || fieldPath
846
+ });
847
+ }
848
+ if (field.type === "object" && field.fields) {
849
+ var nestedOptions = addNestedFieldOptions(field.fields, fieldPath + ".");
850
+ options.push.apply(options, nestedOptions);
851
+ }
852
+ });
853
+ return options;
854
+ }
804
855
  function mkFieldOptions(tables, tableIdentifier, types) {
805
856
  if (!tables) {
806
857
  return [];
@@ -817,12 +868,7 @@ function mkFieldOptions(tables, tableIdentifier, types) {
817
868
  return types.includes(f.type);
818
869
  });
819
870
  }
820
- var options = fields.map(function (f) {
821
- return {
822
- value: f.identifier,
823
- label: f.name || f.identifier
824
- };
825
- });
871
+ var options = addNestedFieldOptions(fields);
826
872
  if (!options.some(function (option) {
827
873
  return option.value === "_id";
828
874
  })) {
@@ -1018,7 +1064,7 @@ var cmsQueryRepeaterMeta = {
1018
1064
  options: function options(_ref4, ctx) {
1019
1065
  var _ctx$table;
1020
1066
  var table = _ref4.table;
1021
- return mkFieldOptions(ctx == null ? void 0 : ctx.tables, (_ctx$table = ctx == null ? void 0 : ctx.table) != null ? _ctx$table : table, ["number", "boolean", "text", "long-text", "ref"]);
1067
+ return mkFieldOptions(ctx == null ? void 0 : ctx.tables, (_ctx$table = ctx == null ? void 0 : ctx.table) != null ? _ctx$table : table, ["number", "boolean", "text", "long-text", "ref", "object"]);
1022
1068
  }
1023
1069
  },
1024
1070
  filterValue: {
@@ -1251,24 +1297,19 @@ var cmsRowFieldMeta = {
1251
1297
  }
1252
1298
  },
1253
1299
  field: {
1254
- type: "choice",
1255
- displayName: "Field",
1256
- description: "Field (from model schema) to use.",
1257
- options: function options(_ref7, ctx) {
1258
- var _ctx$table2;
1259
- var table = _ref7.table;
1260
- return mkFieldOptions(ctx == null ? void 0 : ctx.tables, (_ctx$table2 = ctx == null ? void 0 : ctx.table) != null ? _ctx$table2 : table, ["number", "boolean", "text", "long-text", "date-time", "rich-text", "image", "file"]);
1300
+ type: "dataSelector",
1301
+ data: function data(_, ctx) {
1302
+ var _ctx$data;
1303
+ return (_ctx$data = ctx == null ? void 0 : ctx.data) != null ? _ctx$data : {};
1261
1304
  },
1262
- defaultValueHint: function defaultValueHint(_, ctx) {
1263
- var _ctx$fieldMeta, _ctx$fieldMeta2;
1264
- return (ctx == null || (_ctx$fieldMeta = ctx.fieldMeta) == null ? void 0 : _ctx$fieldMeta.name) || (ctx == null || (_ctx$fieldMeta2 = ctx.fieldMeta) == null ? void 0 : _ctx$fieldMeta2.identifier);
1265
- }
1305
+ displayName: "Field",
1306
+ description: "Field to be displayed."
1266
1307
  },
1267
1308
  dateFormat: {
1268
1309
  type: "choice",
1269
1310
  displayName: "Date Format",
1270
- hidden: function hidden(_ref8, ctx) {
1271
- var field = _ref8.field;
1311
+ hidden: function hidden(_ref7, ctx) {
1312
+ var field = _ref7.field;
1272
1313
  if (!ctx) {
1273
1314
  return true;
1274
1315
  }
@@ -1334,14 +1375,13 @@ var cmsRowFieldMeta = {
1334
1375
  objectFit: "cover"
1335
1376
  }
1336
1377
  };
1337
- function CmsRowField(_ref9) {
1338
- var _res$row$data;
1339
- var className = _ref9.className,
1340
- table = _ref9.table,
1341
- field = _ref9.field,
1342
- dateFormat = _ref9.dateFormat,
1343
- setControlContextData = _ref9.setControlContextData,
1344
- rest = _objectWithoutPropertiesLoose(_ref9, _excluded);
1378
+ function CmsRowField(_ref8) {
1379
+ var className = _ref8.className,
1380
+ table = _ref8.table,
1381
+ field = _ref8.field,
1382
+ dateFormat = _ref8.dateFormat,
1383
+ setControlContextData = _ref8.setControlContextData,
1384
+ rest = _objectWithoutPropertiesLoose(_ref8, _excluded);
1345
1385
  var tables = useTablesWithDataLoaded("rows");
1346
1386
  var res = useRow(tables, table);
1347
1387
  var unknown = React.createElement("div", Object.assign({
@@ -1353,14 +1393,16 @@ function CmsRowField(_ref9) {
1353
1393
  field: field,
1354
1394
  typeFilters: ["text", "long-text", "rich-text"]
1355
1395
  }) : undefined;
1396
+ var filteredFields = res && tables ? filterFieldsByType(res.table, tables, ["number", "boolean", "text", "long-text", "date-time", "rich-text", "image", "file", "object"]) : undefined;
1356
1397
  if (tables) {
1357
1398
  // TODO: Only include table if __plasmic_cms_row_{table} exists.
1358
1399
  setControlContextData == null || setControlContextData(_extends({
1359
1400
  tables: tables
1360
- }, res && res.row ? {
1401
+ }, res && res.row && res.row.data ? {
1361
1402
  table: res.table,
1362
1403
  row: res.row,
1363
- fieldMeta: fieldMeta
1404
+ fieldMeta: fieldMeta,
1405
+ data: extractFields(res.row.data, filteredFields)
1364
1406
  } : {}));
1365
1407
  }
1366
1408
  if (!res) {
@@ -1374,11 +1416,30 @@ function CmsRowField(_ref9) {
1374
1416
  if (!fieldMeta) {
1375
1417
  return unknown;
1376
1418
  }
1377
- var data = (_res$row$data = res.row.data) == null ? void 0 : _res$row$data[fieldMeta.identifier];
1419
+ if (!field) {
1420
+ return React.createElement("div", null, "Please specify a valid path or select a field.");
1421
+ }
1422
+ var data = res.row.data;
1423
+ if (data !== null && typeof data !== 'string' && fieldMeta.path) {
1424
+ var pathParts = fieldMeta.path.split(".");
1425
+ for (var _iterator = _createForOfIteratorHelperLoose(pathParts), _step; !(_step = _iterator()).done;) {
1426
+ var part = _step.value;
1427
+ if (data && typeof data === 'object' && data.hasOwnProperty(part)) {
1428
+ data = data[part];
1429
+ } else {
1430
+ data = null;
1431
+ break;
1432
+ }
1433
+ }
1434
+ } else if (data !== null) {
1435
+ data = data[fieldMeta.identifier];
1436
+ } else {
1437
+ data = null;
1438
+ }
1378
1439
  if (!data) {
1379
1440
  return null;
1380
1441
  }
1381
- if (fieldMeta.type === "date-time" && dateFormat) {
1442
+ if (fieldMeta.type === "date-time" && dateFormat && typeof data === 'string') {
1382
1443
  data = dayjs(data).format(dateFormat);
1383
1444
  }
1384
1445
  return data ? renderValue(data, fieldMeta.type, _extends({
@@ -1409,10 +1470,10 @@ var cmsCountFieldMeta = {
1409
1470
  }
1410
1471
  }
1411
1472
  };
1412
- function CmsCount(_ref10) {
1413
- var className = _ref10.className,
1414
- table = _ref10.table,
1415
- rest = _objectWithoutPropertiesLoose(_ref10, _excluded2);
1473
+ function CmsCount(_ref9) {
1474
+ var className = _ref9.className,
1475
+ table = _ref9.table,
1476
+ rest = _objectWithoutPropertiesLoose(_ref9, _excluded2);
1416
1477
  var tables = useTablesWithDataLoaded("count");
1417
1478
  var res = useCount(tables, table);
1418
1479
  var unknown = React.createElement("div", Object.assign({
@@ -1440,12 +1501,84 @@ function deriveInferredTableField(opts) {
1440
1501
  var schema = tables == null || (_tables$find = tables.find(function (t) {
1441
1502
  return t.identifier === table;
1442
1503
  })) == null ? void 0 : _tables$find.schema;
1443
- var fieldMeta = field ? schema == null ? void 0 : schema.fields.find(function (f) {
1444
- return f.identifier === field;
1445
- }) : schema == null ? void 0 : schema.fields.find(function (f) {
1446
- return (typeFilters != null ? typeFilters : DEFAULT_TYPE_FILTERS).includes(f.type);
1504
+ function findFieldInSchema(schema, fieldIdentifier) {
1505
+ return schema == null ? void 0 : schema.fields.find(function (f) {
1506
+ return f.identifier === fieldIdentifier;
1507
+ });
1508
+ }
1509
+ if (Array.isArray(field)) {
1510
+ if (field.length === 1) {
1511
+ return findFieldInSchema(schema, field[0]);
1512
+ } else if (field.length === 2) {
1513
+ var topLevelField = findFieldInSchema(schema, field[0]);
1514
+ if (topLevelField && topLevelField.type === "object" && topLevelField.fields) {
1515
+ var nestedField = topLevelField == null ? void 0 : topLevelField.fields.find(function (f) {
1516
+ return f.identifier === field[1];
1517
+ });
1518
+ return nestedField ? _extends({}, nestedField, {
1519
+ path: field[0] + "." + field[1]
1520
+ }) : undefined;
1521
+ }
1522
+ }
1523
+ } else if (typeof field === "string") {
1524
+ return findFieldInSchema(schema, field);
1525
+ } else {
1526
+ return schema == null ? void 0 : schema.fields.find(function (f) {
1527
+ return (typeFilters != null ? typeFilters : DEFAULT_TYPE_FILTERS).includes(f.type);
1528
+ });
1529
+ }
1530
+ }
1531
+ function filterFieldsByType(table, tables, types) {
1532
+ var _tables$find2;
1533
+ if (!table || !tables) return undefined;
1534
+ var schema = (_tables$find2 = tables.find(function (t) {
1535
+ return t.identifier === table;
1536
+ })) == null ? void 0 : _tables$find2.schema;
1537
+ if (!schema || !schema.fields) return [];
1538
+ var filteredFields = [];
1539
+ for (var _iterator2 = _createForOfIteratorHelperLoose(schema.fields), _step2; !(_step2 = _iterator2()).done;) {
1540
+ var field = _step2.value;
1541
+ if (types.includes(field.type)) {
1542
+ var modifiedField = deepClone(field);
1543
+ if (field.type === "object" && field.fields) {
1544
+ modifiedField.fields = field.fields.filter(function (f) {
1545
+ return types.includes(f.type);
1546
+ });
1547
+ }
1548
+ filteredFields.push(modifiedField);
1549
+ }
1550
+ }
1551
+ return filteredFields;
1552
+ }
1553
+ function extractFields(data, schema) {
1554
+ var result = {};
1555
+ schema.forEach(function (field) {
1556
+ var fieldName = field.identifier;
1557
+ var fieldType = field.type;
1558
+ if (fieldType === "object" && data[fieldName] && field.fields) {
1559
+ result[fieldName] = extractFields(_extends({}, data[fieldName]), field.fields || []);
1560
+ } else if (data[fieldName] !== undefined) {
1561
+ result[fieldName] = data[fieldName];
1562
+ }
1447
1563
  });
1448
- return fieldMeta;
1564
+ return result;
1565
+ }
1566
+ function deepClone(obj) {
1567
+ if (obj === null || typeof obj !== "object") {
1568
+ return obj;
1569
+ }
1570
+ if (Array.isArray(obj)) {
1571
+ return obj.map(function (item) {
1572
+ return deepClone(item);
1573
+ });
1574
+ }
1575
+ var clonedObj = {};
1576
+ for (var key in obj) {
1577
+ if (Object.prototype.hasOwnProperty.call(obj, key)) {
1578
+ clonedObj[key] = deepClone(obj[key]);
1579
+ }
1580
+ }
1581
+ return clonedObj;
1449
1582
  }
1450
1583
  function assertNever(_) {
1451
1584
  throw new Error("unexpected branch taken");
@@ -1457,6 +1590,7 @@ function renderValue(value, type, props) {
1457
1590
  case "text":
1458
1591
  case "long-text":
1459
1592
  case "date-time":
1593
+ case "object":
1460
1594
  case "ref":
1461
1595
  return React.createElement("div", Object.assign({}, props), value);
1462
1596
  case "rich-text":
@@ -1523,14 +1657,14 @@ var cmsRowLinkMeta = {
1523
1657
  type: "choice",
1524
1658
  displayName: "Field",
1525
1659
  description: "Field (from model schema) to use.",
1526
- options: function options(_ref11, ctx) {
1527
- var _ctx$table3;
1528
- var table = _ref11.table;
1529
- return mkFieldOptions(ctx == null ? void 0 : ctx.tables, (_ctx$table3 = ctx == null ? void 0 : ctx.table) != null ? _ctx$table3 : table);
1660
+ options: function options(_ref10, ctx) {
1661
+ var _ctx$table2;
1662
+ var table = _ref10.table;
1663
+ return mkFieldOptions(ctx == null ? void 0 : ctx.tables, (_ctx$table2 = ctx == null ? void 0 : ctx.table) != null ? _ctx$table2 : table);
1530
1664
  },
1531
1665
  defaultValueHint: function defaultValueHint(_, ctx) {
1532
- var _ctx$fieldMeta3, _ctx$fieldMeta4;
1533
- return (ctx == null || (_ctx$fieldMeta3 = ctx.fieldMeta) == null ? void 0 : _ctx$fieldMeta3.name) || (ctx == null || (_ctx$fieldMeta4 = ctx.fieldMeta) == null ? void 0 : _ctx$fieldMeta4.identifier);
1666
+ var _ctx$fieldMeta, _ctx$fieldMeta2;
1667
+ return (ctx == null || (_ctx$fieldMeta = ctx.fieldMeta) == null ? void 0 : _ctx$fieldMeta.name) || (ctx == null || (_ctx$fieldMeta2 = ctx.fieldMeta) == null ? void 0 : _ctx$fieldMeta2.identifier);
1534
1668
  }
1535
1669
  },
1536
1670
  hrefProp: {
@@ -1544,8 +1678,8 @@ var cmsRowLinkMeta = {
1544
1678
  displayName: "Optional prefix",
1545
1679
  description: "Prefix to prepend to prop value.",
1546
1680
  hidden: function hidden(_, ctx) {
1547
- var _ctx$fieldMeta5;
1548
- return (ctx == null || (_ctx$fieldMeta5 = ctx.fieldMeta) == null ? void 0 : _ctx$fieldMeta5.type) === "file";
1681
+ var _ctx$fieldMeta3;
1682
+ return (ctx == null || (_ctx$fieldMeta3 = ctx.fieldMeta) == null ? void 0 : _ctx$fieldMeta3.type) === "file";
1549
1683
  }
1550
1684
  },
1551
1685
  suffix: {
@@ -1553,21 +1687,21 @@ var cmsRowLinkMeta = {
1553
1687
  displayName: "Optional suffix",
1554
1688
  description: "Suffix to append to prop value.",
1555
1689
  hidden: function hidden(_, ctx) {
1556
- var _ctx$fieldMeta6;
1557
- return (ctx == null || (_ctx$fieldMeta6 = ctx.fieldMeta) == null ? void 0 : _ctx$fieldMeta6.type) === "file";
1690
+ var _ctx$fieldMeta4;
1691
+ return (ctx == null || (_ctx$fieldMeta4 = ctx.fieldMeta) == null ? void 0 : _ctx$fieldMeta4.type) === "file";
1558
1692
  }
1559
1693
  }
1560
1694
  }
1561
1695
  };
1562
- function CmsRowLink(_ref12) {
1563
- var _res$row$data2;
1564
- var table = _ref12.table,
1565
- field = _ref12.field,
1566
- hrefProp = _ref12.hrefProp,
1567
- children = _ref12.children,
1568
- setControlContextData = _ref12.setControlContextData,
1569
- prefix = _ref12.prefix,
1570
- suffix = _ref12.suffix;
1696
+ function CmsRowLink(_ref11) {
1697
+ var _res$row$data;
1698
+ var table = _ref11.table,
1699
+ field = _ref11.field,
1700
+ hrefProp = _ref11.hrefProp,
1701
+ children = _ref11.children,
1702
+ setControlContextData = _ref11.setControlContextData,
1703
+ prefix = _ref11.prefix,
1704
+ suffix = _ref11.suffix;
1571
1705
  var tables = useTablesWithDataLoaded("rows");
1572
1706
  var res = useRow(tables, table);
1573
1707
  if (!res || !res.row) {
@@ -1594,7 +1728,7 @@ function CmsRowLink(_ref12) {
1594
1728
  if (!children) {
1595
1729
  return null;
1596
1730
  }
1597
- var value = ((_res$row$data2 = res.row.data) == null ? void 0 : _res$row$data2[fieldMeta.identifier]) || "";
1731
+ var value = ((_res$row$data = res.row.data) == null ? void 0 : _res$row$data[fieldMeta.identifier]) || "";
1598
1732
  var childrenWithProps = React.Children.map(children, function (child) {
1599
1733
  if (React.isValidElement(child)) {
1600
1734
  var _React$cloneElement;
@@ -1637,14 +1771,14 @@ var cmsRowImageMeta = {
1637
1771
  type: "choice",
1638
1772
  displayName: "Field",
1639
1773
  description: "Field (from model schema) to use.",
1640
- options: function options(_ref13, ctx) {
1641
- var _ctx$table4;
1642
- var table = _ref13.table;
1643
- return mkFieldOptions(ctx == null ? void 0 : ctx.tables, (_ctx$table4 = ctx == null ? void 0 : ctx.table) != null ? _ctx$table4 : table, ["image"]);
1774
+ options: function options(_ref12, ctx) {
1775
+ var _ctx$table3;
1776
+ var table = _ref12.table;
1777
+ return mkFieldOptions(ctx == null ? void 0 : ctx.tables, (_ctx$table3 = ctx == null ? void 0 : ctx.table) != null ? _ctx$table3 : table, ["image"]);
1644
1778
  },
1645
1779
  defaultValueHint: function defaultValueHint(_, ctx) {
1646
- var _ctx$fieldMeta7, _ctx$fieldMeta8;
1647
- return (ctx == null || (_ctx$fieldMeta7 = ctx.fieldMeta) == null ? void 0 : _ctx$fieldMeta7.name) || (ctx == null || (_ctx$fieldMeta8 = ctx.fieldMeta) == null ? void 0 : _ctx$fieldMeta8.identifier);
1780
+ var _ctx$fieldMeta5, _ctx$fieldMeta6;
1781
+ return (ctx == null || (_ctx$fieldMeta5 = ctx.fieldMeta) == null ? void 0 : _ctx$fieldMeta5.name) || (ctx == null || (_ctx$fieldMeta6 = ctx.fieldMeta) == null ? void 0 : _ctx$fieldMeta6.identifier);
1648
1782
  }
1649
1783
  },
1650
1784
  srcProp: {
@@ -1655,13 +1789,13 @@ var cmsRowImageMeta = {
1655
1789
  }
1656
1790
  }
1657
1791
  };
1658
- function CmsRowImage(_ref14) {
1659
- var _res$row$data3;
1660
- var table = _ref14.table,
1661
- field = _ref14.field,
1662
- srcProp = _ref14.srcProp,
1663
- children = _ref14.children,
1664
- setControlContextData = _ref14.setControlContextData;
1792
+ function CmsRowImage(_ref13) {
1793
+ var _res$row$data2;
1794
+ var table = _ref13.table,
1795
+ field = _ref13.field,
1796
+ srcProp = _ref13.srcProp,
1797
+ children = _ref13.children,
1798
+ setControlContextData = _ref13.setControlContextData;
1665
1799
  var tables = useTablesWithDataLoaded("rows");
1666
1800
  var res = useRow(tables, table);
1667
1801
  if (!res || !res.row) {
@@ -1685,7 +1819,7 @@ function CmsRowImage(_ref14) {
1685
1819
  if (!fieldMeta) {
1686
1820
  return React.createElement(React.Fragment, null, children);
1687
1821
  }
1688
- var value = ((_res$row$data3 = res.row.data) == null ? void 0 : _res$row$data3[fieldMeta.identifier]) || "";
1822
+ var value = ((_res$row$data2 = res.row.data) == null ? void 0 : _res$row$data2[fieldMeta.identifier]) || "";
1689
1823
  var childrenWithProps = React.Children.map(children, function (child) {
1690
1824
  if (React.isValidElement(child) && value) {
1691
1825
  var _React$cloneElement3;
@@ -1732,14 +1866,14 @@ var cmsRowFieldValueMeta = {
1732
1866
  type: "choice",
1733
1867
  displayName: "Field",
1734
1868
  description: "Field (from model schema) to use.",
1735
- options: function options(_ref15, ctx) {
1736
- var _ctx$table5;
1737
- var table = _ref15.table;
1738
- return mkFieldOptions(ctx == null ? void 0 : ctx.tables, (_ctx$table5 = ctx == null ? void 0 : ctx.table) != null ? _ctx$table5 : table);
1869
+ options: function options(_ref14, ctx) {
1870
+ var _ctx$table4;
1871
+ var table = _ref14.table;
1872
+ return mkFieldOptions(ctx == null ? void 0 : ctx.tables, (_ctx$table4 = ctx == null ? void 0 : ctx.table) != null ? _ctx$table4 : table);
1739
1873
  },
1740
1874
  defaultValueHint: function defaultValueHint(_, ctx) {
1741
- var _ctx$fieldMeta9, _ctx$fieldMeta10;
1742
- return (ctx == null || (_ctx$fieldMeta9 = ctx.fieldMeta) == null ? void 0 : _ctx$fieldMeta9.name) || (ctx == null || (_ctx$fieldMeta10 = ctx.fieldMeta) == null ? void 0 : _ctx$fieldMeta10.identifier);
1875
+ var _ctx$fieldMeta7, _ctx$fieldMeta8;
1876
+ return (ctx == null || (_ctx$fieldMeta7 = ctx.fieldMeta) == null ? void 0 : _ctx$fieldMeta7.name) || (ctx == null || (_ctx$fieldMeta8 = ctx.fieldMeta) == null ? void 0 : _ctx$fieldMeta8.identifier);
1743
1877
  }
1744
1878
  },
1745
1879
  valueProp: {
@@ -1750,14 +1884,14 @@ var cmsRowFieldValueMeta = {
1750
1884
  }
1751
1885
  }
1752
1886
  };
1753
- function CmsRowFieldValue(_ref16) {
1754
- var _res$row$data4;
1755
- var table = _ref16.table,
1756
- field = _ref16.field,
1757
- valueProp = _ref16.valueProp,
1758
- children = _ref16.children,
1759
- setControlContextData = _ref16.setControlContextData,
1760
- rest = _objectWithoutPropertiesLoose(_ref16, _excluded3);
1887
+ function CmsRowFieldValue(_ref15) {
1888
+ var _res$row$data3;
1889
+ var table = _ref15.table,
1890
+ field = _ref15.field,
1891
+ valueProp = _ref15.valueProp,
1892
+ children = _ref15.children,
1893
+ setControlContextData = _ref15.setControlContextData,
1894
+ rest = _objectWithoutPropertiesLoose(_ref15, _excluded3);
1761
1895
  var tables = useTablesWithDataLoaded("rows");
1762
1896
  var res = useRow(tables, table);
1763
1897
  if (!res || !res.row) {
@@ -1781,7 +1915,7 @@ function CmsRowFieldValue(_ref16) {
1781
1915
  if (!fieldMeta) {
1782
1916
  return React.createElement(React.Fragment, null, children);
1783
1917
  }
1784
- var value = ((_res$row$data4 = res.row.data) == null ? void 0 : _res$row$data4[fieldMeta.identifier]) || "";
1918
+ var value = ((_res$row$data3 = res.row.data) == null ? void 0 : _res$row$data3[fieldMeta.identifier]) || "";
1785
1919
  var childrenWithProps = React.Children.map(children, function (child) {
1786
1920
  if (React.isValidElement(child)) {
1787
1921
  var _extends2;