@coderich/autograph 0.13.56 → 0.13.58

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.
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@coderich/autograph",
3
3
  "main": "index.js",
4
- "version": "0.13.56",
4
+ "version": "0.13.58",
5
5
  "publishConfig": {
6
6
  "access": "public"
7
7
  },
@@ -74,10 +74,11 @@ module.exports = class Pipeline {
74
74
  }, { ignoreNull: false });
75
75
 
76
76
  Pipeline.define('$fk', (params) => {
77
- const { fkField, isPrimaryKey } = params.field;
77
+ const { fkField, linkTo, isPrimaryKey, generator } = params.field;
78
78
  const lookupField = isPrimaryKey ? params.field : fkField;
79
79
  const v = params.value?.[lookupField] || params.value;
80
- return Util.map(v, value => params.field.generator({ ...params, value }));
80
+ const $generator = isPrimaryKey ? generator : linkTo.fields[fkField].generator;
81
+ return Util.map(v, value => $generator({ ...params, value }));
81
82
  });
82
83
 
83
84
  //
@@ -268,6 +268,7 @@ module.exports = class Resolver {
268
268
  },
269
269
  $model: { value: model },
270
270
  $cursor: { value: doc.$cursor },
271
+ toString: { value: () => `${model}` },
271
272
  // Backwards compat
272
273
  $save: { value: (...args) => $doc.$.save(...args) },
273
274
  $lookup: {
@@ -506,7 +506,8 @@ module.exports = class Schema {
506
506
  $field.linkTo = $schema.models[$field.linkTo];
507
507
  $field.crud = Util.uvl($field.crud, $field.model?.scope, 'crud');
508
508
  $field.linkBy ??= $field.linkTo?.pkField; // This defines join logic (below) for both straight+virtual references
509
- $field.fkField ??= $field.model?.pkField; // This is the fkReference field for straight references
509
+ $field.fkField ??= $field.linkTo?.pkField; // This is the fkReference field for straight references
510
+ // $field.fkField ??= $field.model?.pkField; // This is the fkReference field for straight references
510
511
  $field.linkField = $field.isVirtual ? $model.fields[$model.pkField] : $field;
511
512
  $field.isFKReference = $field.fkField && !$field.isPrimaryKey && $field.model?.isMarkedModel && !$field.model?.isEmbedded;
512
513
  $field.isEmbedded = Boolean($field.model && !$field.isFKReference && !$field.isPrimaryKey);