@ossareh/typeorm
Version:
Data-Mapper ORM for TypeScript, ES7, ES6, ES5. Supports MySQL, PostgreSQL, MariaDB, SQLite, MS SQL Server, Oracle, MongoDB databases.
83 lines (81 loc) • 3.08 kB
JavaScript
"use strict";
var __read = (this && this.__read) || function (o, n) {
var m = typeof Symbol === "function" && o[Symbol.iterator];
if (!m) return o;
var i = m.call(o), r, ar = [], e;
try {
while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
}
catch (error) { e = { error: error }; }
finally {
try {
if (r && !r.done && (m = i["return"])) m.call(i);
}
finally { if (e) throw e.error; }
}
return ar;
};
var __spread = (this && this.__spread) || function () {
for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i]));
return ar;
};
Object.defineProperty(exports, "__esModule", { value: true });
/**
* Foreign key from the database stored in this class.
*/
var TableForeignKey = /** @class */ (function () {
// -------------------------------------------------------------------------
// Constructor
// -------------------------------------------------------------------------
function TableForeignKey(options) {
/**
* Column names which included by this foreign key.
*/
this.columnNames = [];
/**
* Column names which included by this foreign key.
*/
this.referencedColumnNames = [];
this.name = options.name;
this.columnNames = options.columnNames;
this.referencedColumnNames = options.referencedColumnNames;
this.referencedTableName = options.referencedTableName;
this.onDelete = options.onDelete;
this.onUpdate = options.onUpdate;
}
// -------------------------------------------------------------------------
// Public Methods
// -------------------------------------------------------------------------
/**
* Creates a new copy of this foreign key with exactly same properties.
*/
TableForeignKey.prototype.clone = function () {
return new TableForeignKey({
name: this.name,
columnNames: __spread(this.columnNames),
referencedColumnNames: __spread(this.referencedColumnNames),
referencedTableName: this.referencedTableName,
onDelete: this.onDelete,
onUpdate: this.onUpdate
});
};
// -------------------------------------------------------------------------
// Static Methods
// -------------------------------------------------------------------------
/**
* Creates a new table foreign key from the given foreign key metadata.
*/
TableForeignKey.create = function (metadata) {
return new TableForeignKey({
name: metadata.name,
columnNames: metadata.columnNames,
referencedColumnNames: metadata.referencedColumnNames,
referencedTableName: metadata.referencedTablePath,
onDelete: metadata.onDelete,
onUpdate: metadata.onUpdate
});
};
return TableForeignKey;
}());
exports.TableForeignKey = TableForeignKey;
//# sourceMappingURL=TableForeignKey.js.map