This commit is contained in:
2020-12-28 19:22:51 +00:00
parent d6856de91a
commit ac9fe59347
9 changed files with 171 additions and 5 deletions

View File

@@ -121,7 +121,11 @@ namespace AyaNova.Biz
[CoreBizObject]
Memo = 60,
[CoreBizObject]
Review = 61
Review = 61,
[CoreBizObject]
ServiceRate = 62,
[CoreBizObject]
TravelRate = 63

View File

@@ -53,6 +53,10 @@ namespace AyaNova.Models
public virtual DbSet<Unit> Unit { get; set; }
public virtual DbSet<UnitModel> UnitModel { get; set; }
public virtual DbSet<Vendor> Vendor { get; set; }
public virtual DbSet<ServiceRate> ServiceRate { get; set; }
public virtual DbSet<TravelRate> TravelRate { get; set; }
//WorkOrder
public virtual DbSet<WorkOrder> WorkOrder { get; set; }
public virtual DbSet<WorkOrderItem> WorkOrderItem { get; set; }

View File

@@ -0,0 +1,64 @@
using System;
using System.Collections.Generic;
using AyaNova.Biz;
using System.ComponentModel.DataAnnotations;
using System.ComponentModel.DataAnnotations.Schema;
using Newtonsoft.Json;
namespace AyaNova.Models
{
//NOTE: Any non required field (nullable in DB) sb nullable here, i.e. decimal? not decimal,
//otherwise the server will call it an invalid record if the field isn't sent from client
public class ServiceRate : ICoreBizObjectModel
{
public long Id { get; set; }
public uint Concurrency { get; set; }
[Required]
public string Name { get; set; }
public bool Active { get; set; }
public string Notes { get; set; }
public string Wiki { get; set; }
public string CustomFields { get; set; }
public List<string> Tags { get; set; }
public string AccountNumber { get; set; }
[Required]
public decimal Cost { get; set; }
[Required]
public decimal Charge { get; set; }
public string Unit { get; set; }
public ServiceRate()
{
Tags = new List<string>();
}
[NotMapped, JsonIgnore]
public AyaType AyaType { get => AyaType.ServiceRate; }
}//eoc
}//eons
/*
CREATE TABLE [dbo].[ARATE](
[AID] [uniqueidentifier] NOT NULL,
[ACREATED] [datetime] NOT NULL,
[AMODIFIED] [datetime] NOT NULL,
[AACTIVE] [bit] NOT NULL,
[ACREATOR] [uniqueidentifier] NOT NULL,
[AMODIFIER] [uniqueidentifier] NOT NULL,
[ANAME] [nvarchar](255) NOT NULL,
[ADESCRIPTION] [nvarchar](255) NULL,//NOW NOTES
[AACCOUNTNUMBER] [nvarchar](255) NULL,
[ACOST] [decimal](19, 5) NULL,
[ACHARGE] [decimal](19, 5) NULL,
[ARATETYPE] [smallint] NOT NULL,//REMOVE SPLITTING INTO TRAVEL AND LABOR SEPERATELY
[ARATEUNITCHARGEDESCRIPTIONID] [uniqueidentifier] //TURN THIS INTO TEXT PLAIN AND SIMPLE,
[ACLIENTGROUPID] [uniqueidentifier] NULL, //TAG remove
[ACONTRACTRATE] [bit] NOT NULL,//THIS IS ONLY FOR THE UI, REMOVE IT
[AREGIONID] [uniqueidentifier] NULL,//tag, remove
*/

View File

@@ -0,0 +1,64 @@
using System;
using System.Collections.Generic;
using AyaNova.Biz;
using System.ComponentModel.DataAnnotations;
using System.ComponentModel.DataAnnotations.Schema;
using Newtonsoft.Json;
namespace AyaNova.Models
{
//NOTE: Any non required field (nullable in DB) sb nullable here, i.e. decimal? not decimal,
//otherwise the server will call it an invalid record if the field isn't sent from client
public class TravelRate : ICoreBizObjectModel
{
public long Id { get; set; }
public uint Concurrency { get; set; }
[Required]
public string Name { get; set; }
public bool Active { get; set; }
public string Notes { get; set; }
public string Wiki { get; set; }
public string CustomFields { get; set; }
public List<string> Tags { get; set; }
public string AccountNumber { get; set; }
[Required]
public decimal Cost { get; set; }
[Required]
public decimal Charge { get; set; }
public string Unit { get; set; }
public TravelRate()
{
Tags = new List<string>();
}
[NotMapped, JsonIgnore]
public AyaType AyaType { get => AyaType.TravelRate; }
}//eoc
}//eons
/*
CREATE TABLE [dbo].[ARATE](
[AID] [uniqueidentifier] NOT NULL,
[ACREATED] [datetime] NOT NULL,
[AMODIFIED] [datetime] NOT NULL,
[AACTIVE] [bit] NOT NULL,
[ACREATOR] [uniqueidentifier] NOT NULL,
[AMODIFIER] [uniqueidentifier] NOT NULL,
[ANAME] [nvarchar](255) NOT NULL,
[ADESCRIPTION] [nvarchar](255) NULL,//NOW NOTES
[AACCOUNTNUMBER] [nvarchar](255) NULL,
[ACOST] [decimal](19, 5) NULL,
[ACHARGE] [decimal](19, 5) NULL,
[ARATETYPE] [smallint] NOT NULL,//REMOVE SPLITTING INTO TRAVEL AND Travel SEPERATELY
[ARATEUNITCHARGEDESCRIPTIONID] [uniqueidentifier] //TURN THIS INTO TEXT PLAIN AND SIMPLE,
[ACLIENTGROUPID] [uniqueidentifier] NULL, //TAG remove
[ACONTRACTRATE] [bit] NOT NULL,//THIS IS ONLY FOR THE UI, REMOVE IT
[AREGIONID] [uniqueidentifier] NULL,//tag, remove
*/

View File

@@ -2025,5 +2025,9 @@
"Failed": "Fehlgeschlagen",
"ProcessingJob": "Serverjob verarbeiten",
"TimedOut": "Zeitüberschreitung",
"Now": "Jetzt"
"Now": "Jetzt",
"ServiceRate": "Service-Rate",
"TravelRate": "Reiserate",
"ServiceRateList": "Serviceraten",
"TravelRateList": "Reiseratenliste"
}

View File

@@ -2025,5 +2025,9 @@
"Failed": "Failed",
"ProcessingJob": "Processing server job",
"TimedOut": "Timed out",
"Now": "Now"
"Now": "Now",
"ServiceRate": "Service rate",
"TravelRate": "Travel rate",
"ServiceRateList": "Service rates",
"TravelRateList": "Travel rates"
}

View File

@@ -2025,5 +2025,9 @@
"Failed": "Fallido",
"ProcessingJob": "Procesando trabajo del servidor",
"TimedOut": "Tiempo de espera agotado",
"Now": "Ahora"
"Now": "Ahora",
"ServiceRate": "Tasa de trabajo",
"TravelRate": "Tasa de viaje",
"ServiceRateList": "Tasas laborales",
"TravelRateList": "Tarifas de viaje"
}

View File

@@ -2025,5 +2025,9 @@
"Failed": "Échec",
"ProcessingJob": "Traitement du travail du serveur",
"TimedOut": "Délai dépassé",
"Now": "Maintenant"
"Now": "Maintenant",
"ServiceRate": "Taux de service",
"TravelRate": "Tarif voyage",
"ServiceRateList": "Tarifs de service",
"TravelRateList": "Tarifs de voyage"
}

View File

@@ -565,6 +565,20 @@ $BODY$ LANGUAGE PLPGSQL STABLE");
{
LogUpdateMessage(log);
//SERVICERATE
await ExecQueryAsync("CREATE TABLE aservicerate (id BIGINT GENERATED ALWAYS AS IDENTITY PRIMARY KEY, name text not null unique, active bool, " +
"notes text, wiki text, customfields text, tags varchar(255) ARRAY, " +
"accountnumber text, unit text, cost decimal(19,4) not null default 0, charge decimal(19,4) not null default 0)");
await ExecQueryAsync("CREATE UNIQUE INDEX aservicerate_name_id_idx ON aservicerate (id, name);");
await ExecQueryAsync("CREATE INDEX aservicerate_tags ON aservicerate using GIN(tags)");
//TRAVELRATE
await ExecQueryAsync("CREATE TABLE atravelrate (id BIGINT GENERATED ALWAYS AS IDENTITY PRIMARY KEY, name text not null unique, active bool, " +
"notes text, wiki text, customfields text, tags varchar(255) ARRAY, " +
"accountnumber text, unit text, cost decimal(19,4) not null default 0, charge decimal(19,4) not null default 0)");
await ExecQueryAsync("CREATE UNIQUE INDEX atravelrate_name_id_idx ON atravelrate (id, name);");
await ExecQueryAsync("CREATE INDEX atravelrate_tags ON atravelrate using GIN(tags)");
//MEMO
await ExecQueryAsync("CREATE TABLE amemo (id BIGINT GENERATED ALWAYS AS IDENTITY PRIMARY KEY, name text not null, " +
"notes text, wiki text, customfields text, tags varchar(255) ARRAY, " +