@ronin/compiler 0.14.6 → 0.14.7

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 (2) hide show
  1. package/dist/index.js +12 -9
  2. package/package.json +1 -1
package/dist/index.js CHANGED
@@ -557,10 +557,10 @@ var handleTo = (models, model, statementParams, queryType, dependencyStatements,
557
557
  delete toInstruction[fieldSlug];
558
558
  const associativeModelSlug = composeAssociationModelSlug(model, fieldDetails.field);
559
559
  const composeStatement = (subQueryType, value) => {
560
- const source = queryType === "add" ? { id: toInstruction.id } : withInstruction;
560
+ const source = queryType === "add" ? toInstruction : withInstruction;
561
561
  const recordDetails = { source };
562
562
  if (value) recordDetails.target = value;
563
- return compileQueryInput(
563
+ const query = compileQueryInput(
564
564
  {
565
565
  [subQueryType]: {
566
566
  [associativeModelSlug]: subQueryType === "add" ? { to: recordDetails } : { with: recordDetails }
@@ -570,19 +570,20 @@ var handleTo = (models, model, statementParams, queryType, dependencyStatements,
570
570
  [],
571
571
  { returning: false }
572
572
  ).main;
573
+ dependencyStatements.push({ ...query, after: true });
573
574
  };
574
575
  if (Array.isArray(fieldValue)) {
575
- dependencyStatements.push(composeStatement("remove"));
576
+ if (queryType === "set") composeStatement("remove");
576
577
  for (const record of fieldValue) {
577
- dependencyStatements.push(composeStatement("add", record));
578
+ composeStatement("add", record);
578
579
  }
579
580
  } else if (isObject(fieldValue)) {
580
581
  const value = fieldValue;
581
582
  for (const recordToAdd of value.containing || []) {
582
- dependencyStatements.push(composeStatement("add", recordToAdd));
583
+ composeStatement("add", recordToAdd);
583
584
  }
584
585
  for (const recordToRemove of value.notContaining || []) {
585
- dependencyStatements.push(composeStatement("remove", recordToRemove));
586
+ composeStatement("remove", recordToRemove);
586
587
  }
587
588
  }
588
589
  }
@@ -1984,19 +1985,21 @@ var Transaction = class {
1984
1985
  });
1985
1986
  const statements = [];
1986
1987
  for (const query of queries) {
1987
- const result = compileQueryInput(
1988
+ const { dependencies, main, selectedFields } = compileQueryInput(
1988
1989
  query,
1989
1990
  modelsWithPresets,
1990
1991
  options?.inlineParams ? null : [],
1991
1992
  { expandColumns: options?.expandColumns }
1992
1993
  );
1993
- const subStatements = [...result.dependencies, result.main];
1994
+ const preDependencies = dependencies.filter(({ after }) => !after);
1995
+ const postDependencies = dependencies.map(({ after, ...rest }) => after ? rest : null).filter((item) => item != null);
1996
+ const subStatements = [...preDependencies, main, ...postDependencies];
1994
1997
  this.statements.push(...subStatements);
1995
1998
  this.#internalStatements.push(
1996
1999
  ...subStatements.map((statement) => ({
1997
2000
  ...statement,
1998
2001
  query,
1999
- selectedFields: result.selectedFields
2002
+ selectedFields
2000
2003
  }))
2001
2004
  );
2002
2005
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@ronin/compiler",
3
- "version": "0.14.6",
3
+ "version": "0.14.7",
4
4
  "type": "module",
5
5
  "description": "Compiles RONIN queries to SQL statements.",
6
6
  "publishConfig": {