using System.Collections.Generic; using System.ComponentModel.DataAnnotations; using System.ComponentModel.DataAnnotations.Schema; using Newtonsoft.Json; using AyaNova.Biz; namespace AyaNova.Models { //Data transfer no child collections public class dtWorkOrder : ICoreBizObjectModel { public dtWorkOrder() { Tags = new List(); } public long Id { get; set; } public uint Concurrency { get; set; } [Required] public long Serial { get; set; } public bool Active { get; set; } public string Notes { get; set; } public string Wiki { get; set; } public string CustomFields { get; set; } public List Tags { get; set; } [NotMapped, JsonIgnore] public AyaType AyaType { get => AyaType.WorkOrder; } }//eoc /* todo: Consider adding latitude / longitude to wo, quote, pm objects can copy over from the unit or customer or set themselves and can always hide means wo could be scheduled for ad-hoc locations and serviced that way, i.e. a truck parked on the side of the highway etc */ public class WorkOrder : ICoreBizObjectModel { public WorkOrder() { Tags = new List(); //dependents Items = new List(); } public long Id { get; set; } public uint Concurrency { get; set; } [Required] public long Serial { get; set; } public bool Active { get; set; } public string Notes { get; set; } public string Wiki { get; set; } public string CustomFields { get; set; } public List Tags { get; set; } // [Required] // public long CustomerId {get;set;} //dependents public List Items { get; set; } // [NotMapped, JsonIgnore] // public string Name // { // //Used by notification processor // get // { // return this.Serial.ToString(); // } // } [NotMapped, JsonIgnore] public AyaType AyaType { get => AyaType.WorkOrder; } }//eoc }//eons /* CREATE TABLE [dbo].[AWORKORDER]( [AID] [uniqueidentifier] NOT NULL, [ACREATED] [datetime] NOT NULL, [AMODIFIED] [datetime] NOT NULL, [ACREATOR] [uniqueidentifier] NOT NULL, [AMODIFIER] [uniqueidentifier] NOT NULL, [ACLIENTID] [uniqueidentifier] NULL, [APROJECTID] [uniqueidentifier] NULL, [AINTERNALREFERENCENUMBER] [nvarchar](255) NULL, [ACUSTOMERREFERENCENUMBER] [nvarchar](255) NULL, [AONSITE] [bit] NOT NULL, [ACUSTOMERCONTACTNAME] [nvarchar](255) NULL, [AREGIONID] [uniqueidentifier] NULL, [AWORKORDERTYPE] [smallint] NULL, [AFORMLAYOUTID] [uniqueidentifier] NULL,//### DROP NOT PORTED [ASUMMARY] [nvarchar](255) NULL, [AWORKORDERCATEGORYID] [uniqueidentifier] NULL, [ACLOSED] [bit] NOT NULL, [ASERVICECOMPLETED] [bit] NOT NULL, [AFROMQUOTEID] [uniqueidentifier] NULL, [AFROMPMID] [uniqueidentifier] NULL, [ATEMPLATEDESCRIPTION] [nvarchar](255) NULL, [ATEMPLATEFRESHPRICE] [bit] NOT NULL,//?? DO NOT PORT?? CREATE TABLE [dbo].[AWORKORDERSERVICE]( [AID] [uniqueidentifier] NOT NULL, [AWORKORDERID] [uniqueidentifier] NOT NULL, [ACREATOR] [uniqueidentifier] NOT NULL, [AMODIFIER] [uniqueidentifier] NOT NULL, [ACREATED] [datetime] NOT NULL, [AMODIFIED] [datetime] NOT NULL, [AWORKORDERSTATUSID] [uniqueidentifier] NULL, [ASERVICEDATE] [datetime] NULL, [AINVOICENUMBER] [nvarchar](255) NULL, [ASERVICENUMBER] [int] IDENTITY(1,1) NOT NULL, [AQUOTEWORKORDERID] [uniqueidentifier] NULL, [ACLIENTREQUESTID] [uniqueidentifier] NULL, [APREVENTIVEMAINTENANCEID] [uniqueidentifier] NULL, [ACLOSEBYDATE] [datetime] NULL, [ASIGNATURE] [ntext] NULL, [ASIGNED] [datetime] NULL, */