Modified schemas.
This commit is contained in:
parent
7f17f5f205
commit
5dd4d9275b
44
src/database/schemas/inventory/purchaseorder.schema.js
Normal file
44
src/database/schemas/inventory/purchaseorder.schema.js
Normal file
@ -0,0 +1,44 @@
|
|||||||
|
import mongoose from 'mongoose';
|
||||||
|
import { generateId } from '../../utils.js';
|
||||||
|
const { Schema } = mongoose;
|
||||||
|
|
||||||
|
const purchaseOrderSchema = new Schema(
|
||||||
|
{
|
||||||
|
_reference: { type: String, default: () => generateId()() },
|
||||||
|
value: { type: Number, required: true },
|
||||||
|
unit: { type: String, required: true },
|
||||||
|
parent: {
|
||||||
|
type: Schema.Types.ObjectId,
|
||||||
|
refPath: 'parentType',
|
||||||
|
required: true,
|
||||||
|
},
|
||||||
|
parentType: {
|
||||||
|
type: String,
|
||||||
|
required: true,
|
||||||
|
enum: ['filamentStock', 'partStock', 'productStock'], // Add other models as needed
|
||||||
|
},
|
||||||
|
owner: {
|
||||||
|
type: Schema.Types.ObjectId,
|
||||||
|
refPath: 'ownerType',
|
||||||
|
required: true,
|
||||||
|
},
|
||||||
|
ownerType: {
|
||||||
|
type: String,
|
||||||
|
required: true,
|
||||||
|
enum: ['user', 'subJob', 'stockAudit'],
|
||||||
|
},
|
||||||
|
timestamp: { type: Date, default: Date.now },
|
||||||
|
},
|
||||||
|
{ timestamps: true }
|
||||||
|
);
|
||||||
|
|
||||||
|
// Add virtual id getter
|
||||||
|
purchaseOrderSchema.virtual('id').get(function () {
|
||||||
|
return this._id;
|
||||||
|
});
|
||||||
|
|
||||||
|
// Configure JSON serialization to include virtuals
|
||||||
|
purchaseOrderSchema.set('toJSON', { virtuals: true });
|
||||||
|
|
||||||
|
// Create and export the model
|
||||||
|
export const purchaseOrderModel = mongoose.model('purchaseOrder', purchaseOrderSchema);
|
||||||
44
src/database/schemas/inventory/stockevent.schema copy.js
Normal file
44
src/database/schemas/inventory/stockevent.schema copy.js
Normal file
@ -0,0 +1,44 @@
|
|||||||
|
import mongoose from 'mongoose';
|
||||||
|
import { generateId } from '../../utils.js';
|
||||||
|
const { Schema } = mongoose;
|
||||||
|
|
||||||
|
const stockEventSchema = new Schema(
|
||||||
|
{
|
||||||
|
_reference: { type: String, default: () => generateId()() },
|
||||||
|
value: { type: Number, required: true },
|
||||||
|
unit: { type: String, required: true },
|
||||||
|
parent: {
|
||||||
|
type: Schema.Types.ObjectId,
|
||||||
|
refPath: 'parentType',
|
||||||
|
required: true,
|
||||||
|
},
|
||||||
|
parentType: {
|
||||||
|
type: String,
|
||||||
|
required: true,
|
||||||
|
enum: ['filamentStock', 'partStock', 'productStock'], // Add other models as needed
|
||||||
|
},
|
||||||
|
owner: {
|
||||||
|
type: Schema.Types.ObjectId,
|
||||||
|
refPath: 'ownerType',
|
||||||
|
required: true,
|
||||||
|
},
|
||||||
|
ownerType: {
|
||||||
|
type: String,
|
||||||
|
required: true,
|
||||||
|
enum: ['user', 'subJob', 'stockAudit'],
|
||||||
|
},
|
||||||
|
timestamp: { type: Date, default: Date.now },
|
||||||
|
},
|
||||||
|
{ timestamps: true }
|
||||||
|
);
|
||||||
|
|
||||||
|
// Add virtual id getter
|
||||||
|
stockEventSchema.virtual('id').get(function () {
|
||||||
|
return this._id;
|
||||||
|
});
|
||||||
|
|
||||||
|
// Configure JSON serialization to include virtuals
|
||||||
|
stockEventSchema.set('toJSON', { virtuals: true });
|
||||||
|
|
||||||
|
// Create and export the model
|
||||||
|
export const stockEventModel = mongoose.model('stockEvent', stockEventSchema);
|
||||||
@ -32,6 +32,7 @@ const documentPrinterSchema = new Schema(
|
|||||||
},
|
},
|
||||||
connectedAt: { type: Date, default: null },
|
connectedAt: { type: Date, default: null },
|
||||||
host: { type: Schema.Types.ObjectId, ref: 'host', required: true },
|
host: { type: Schema.Types.ObjectId, ref: 'host', required: true },
|
||||||
|
vendor: { type: Schema.Types.ObjectId, ref: 'vendor', required: false },
|
||||||
queue: [{ type: Schema.Types.ObjectId, ref: 'documentJob', required: false }],
|
queue: [{ type: Schema.Types.ObjectId, ref: 'documentJob', required: false }],
|
||||||
},
|
},
|
||||||
{ timestamps: true }
|
{ timestamps: true }
|
||||||
|
|||||||
@ -12,8 +12,8 @@ const jobSchema = new mongoose.Schema(
|
|||||||
printers: [{ type: Schema.Types.ObjectId, ref: 'printer', required: false }],
|
printers: [{ type: Schema.Types.ObjectId, ref: 'printer', required: false }],
|
||||||
createdAt: { required: true, type: Date },
|
createdAt: { required: true, type: Date },
|
||||||
updatedAt: { required: true, type: Date },
|
updatedAt: { required: true, type: Date },
|
||||||
startedAt: { required: false, type: Date },
|
startedAt: { required: false, type: Date, default: null },
|
||||||
finishedAt: { required: false, type: Date },
|
finishedAt: { required: false, type: Date, default: null },
|
||||||
gcodeFile: {
|
gcodeFile: {
|
||||||
type: Schema.Types.ObjectId,
|
type: Schema.Types.ObjectId,
|
||||||
ref: 'gcodeFile',
|
ref: 'gcodeFile',
|
||||||
|
|||||||
@ -39,8 +39,8 @@ const subJobSchema = new mongoose.Schema({
|
|||||||
type: Date,
|
type: Date,
|
||||||
default: Date.now,
|
default: Date.now,
|
||||||
},
|
},
|
||||||
startedAt: { required: false, type: Date },
|
startedAt: { required: false, type: Date, default: null },
|
||||||
finishedAt: { required: false, type: Date },
|
finishedAt: { required: false, type: Date, default: null },
|
||||||
});
|
});
|
||||||
|
|
||||||
subJobSchema.virtual('id').get(function () {
|
subJobSchema.virtual('id').get(function () {
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user