IO-223 Begin ARMS Integration
This commit is contained in:
796
server/data/arms.js
Normal file
796
server/data/arms.js
Normal file
@@ -0,0 +1,796 @@
|
||||
const path = require("path");
|
||||
const queries = require("../graphql-client/queries");
|
||||
const Dinero = require("dinero.js");
|
||||
const moment = require("moment");
|
||||
var builder = require("xmlbuilder2");
|
||||
const _ = require("lodash");
|
||||
const logger = require("../utils/logger");
|
||||
require("dotenv").config({
|
||||
path: path.resolve(
|
||||
process.cwd(),
|
||||
`.env.${process.env.NODE_ENV || "development"}`
|
||||
),
|
||||
});
|
||||
let Client = require("ssh2-sftp-client");
|
||||
|
||||
const client = require("../graphql-client/graphql-client").client;
|
||||
|
||||
exports.default = async (req, res) => {
|
||||
//Query for the List of Bodyshop Clients.
|
||||
logger.log("arms-start", "DEBUG", "api", null, null);
|
||||
const { bodyshops } = await client.request(queries.GET_AUTOHOUSE_SHOPS);
|
||||
|
||||
const allxmlsToUpload = [];
|
||||
const allErrors = [];
|
||||
try {
|
||||
for (const bodyshop of bodyshops) {
|
||||
logger.log("arms-start-shop-extract", "DEBUG", "api", bodyshop.id, {
|
||||
shopname: bodyshop.shopname,
|
||||
});
|
||||
const erroredJobs = [];
|
||||
try {
|
||||
const { jobs } = await client.request(queries.AUTOHOUSE_QUERY, {
|
||||
bodyshopid: bodyshop.id,
|
||||
});
|
||||
|
||||
jobs.map((job) => {
|
||||
return {
|
||||
RepairOrderFolderAddRq: {
|
||||
RqUID: "426cce3a-efa7-44d9-b76e-50b9102c4198", //TODO UID Tracking
|
||||
DocumentInfo: {
|
||||
BMSVer: "4.0.0",
|
||||
DocumentType: "Repair Order",
|
||||
DocumentVerCode: "EM",
|
||||
DocumentVerNum: GetSupplementNumber(job.joblines), //TODO Get Supplement Number
|
||||
DocumentStatus: GetDocumentstatus(job, bodyshop),
|
||||
CreateDateTime: moment().format(),
|
||||
// TransmitDateTime: "2009-03-11T11:58:31.0404914-07:00", Omitted from ARMS docs
|
||||
},
|
||||
EventInfo: {
|
||||
AssignmentEvent: {
|
||||
CreateDateTime: moment(job.asgn_date).format(),
|
||||
},
|
||||
EstimateEvent: {
|
||||
UploadDateTime: "2009-03-02T17:00:00.0000000-08:00", //TODO Figure out what this actually is. 'Date Estimate was uploaded'
|
||||
},
|
||||
RepairEvent: {
|
||||
ArrivalDateTime: moment(job.date_open).format(),
|
||||
ArrivalOdometerReading: job.kmin,
|
||||
TargetCompletionDateTime: moment(
|
||||
job.scheduled_compltion
|
||||
).format(),
|
||||
ActualCompletionDateTime:
|
||||
job.actual_complation &&
|
||||
moment(job.actual_complation).format(),
|
||||
ActualPickUpDateTime:
|
||||
job.actual_delivery && moment(job.actual_delivery).format(),
|
||||
CloseDateTime:
|
||||
job.date_exported && moment(job.date_exported).format(),
|
||||
},
|
||||
},
|
||||
RepairOrderHeader: {
|
||||
AdminInfo: {
|
||||
InsuranceCompany: {
|
||||
Party: {
|
||||
OrgInfo: {
|
||||
CompanyName: job.ins_co_nm,
|
||||
IDInfo: {
|
||||
IDQualifierCode: "US",
|
||||
IDNum: 44, // ** Not sure where to get this entegral ID from?
|
||||
},
|
||||
Communications: [
|
||||
{
|
||||
CommQualifier: "WA",
|
||||
Address: {
|
||||
Address1: job.ins_addr1,
|
||||
Address2: job.ins_addr2,
|
||||
City: job.ins_city,
|
||||
StateProvince: job.ins_st,
|
||||
PostalCode: job.ins_zip,
|
||||
CountryCode: job.ins_ctry,
|
||||
},
|
||||
},
|
||||
{
|
||||
CommQualifier: "WP",
|
||||
CommPhone: job.ins_ph1,
|
||||
},
|
||||
{
|
||||
CommQualifier: "WF",
|
||||
CommPhone: job.ins_ph2,
|
||||
},
|
||||
],
|
||||
},
|
||||
ContactInfo: {
|
||||
ContactJobTitle: "Adjuster",
|
||||
ContactName: {
|
||||
FirstName: job.est_ct_fn,
|
||||
LastName: job.est_ct_ln,
|
||||
},
|
||||
},
|
||||
},
|
||||
},
|
||||
InsuranceAgent: {
|
||||
Party: {
|
||||
OrgInfo: {
|
||||
CompanyName: "Nationwide Insurance",
|
||||
Communications: {
|
||||
CommQualifier: "WP",
|
||||
CommPhone: "714-5551212",
|
||||
},
|
||||
},
|
||||
ContactInfo: {
|
||||
ContactJobTitle: "Insurance Agent",
|
||||
ContactName: {
|
||||
FirstName: "Paul",
|
||||
LastName: "White",
|
||||
},
|
||||
},
|
||||
},
|
||||
},
|
||||
Insured: {
|
||||
Party: {
|
||||
PersonInfo: {
|
||||
PersonName: {
|
||||
FirstName: "Jim",
|
||||
LastName: "Smith",
|
||||
},
|
||||
},
|
||||
},
|
||||
},
|
||||
Owner: {
|
||||
Party: {
|
||||
PersonInfo: {
|
||||
PersonName: {
|
||||
FirstName: job.ownr_fn,
|
||||
LastName: job.ownr_ln,
|
||||
},
|
||||
Communications: [
|
||||
{
|
||||
CommQualifier: "HA",
|
||||
Address: {
|
||||
Address1: job.ownr_addr1,
|
||||
|
||||
City: job.ownr_city,
|
||||
StateProvince: job.ownr_st,
|
||||
PostalCode: job.ownr_zip,
|
||||
CountryCode: job.ownr_ctry,
|
||||
},
|
||||
},
|
||||
{
|
||||
CommQualifier: "HP",
|
||||
CommPhone: job.ownr_ph1,
|
||||
},
|
||||
{
|
||||
CommQualifier: "WP",
|
||||
CommPhone: job.ownr_ph2,
|
||||
},
|
||||
{
|
||||
CommQualifier: "CP",
|
||||
CommPhone: job.ownr_ph1,
|
||||
},
|
||||
{
|
||||
CommQualifier: "EM",
|
||||
CommEmail: job.ownr_ea,
|
||||
},
|
||||
],
|
||||
},
|
||||
},
|
||||
},
|
||||
Claimant: {
|
||||
Party: {
|
||||
PersonInfo: {
|
||||
PersonName: {
|
||||
FirstName: "Jim",
|
||||
LastName: "Smith",
|
||||
},
|
||||
},
|
||||
},
|
||||
OwnerInd: true,
|
||||
},
|
||||
Estimator: {
|
||||
Party: {
|
||||
PersonInfo: {
|
||||
PersonName: {
|
||||
FirstName: "Jim",
|
||||
LastName: "Smith",
|
||||
},
|
||||
IDInfo: {
|
||||
IDQualifierCode: "US",
|
||||
IDNum: 2941,
|
||||
},
|
||||
},
|
||||
},
|
||||
},
|
||||
RepairFacility: {
|
||||
//This section not in documentation.
|
||||
Party: {
|
||||
OrgInfo: {
|
||||
CompanyName: bodyshop.shopname,
|
||||
IDInfo: {
|
||||
IDQualifierCode: "US",
|
||||
IDNum: 2207,
|
||||
},
|
||||
},
|
||||
},
|
||||
},
|
||||
},
|
||||
RepairOrderIDs: {
|
||||
RepairOrderNum: job.ro_number,
|
||||
// VendorCode: "C",
|
||||
// EstimateDocumentID: "1223HJ76",
|
||||
},
|
||||
//RepairOrderType: "DRP",
|
||||
//ReferralSourceType: "Yellow Pages",
|
||||
VehicleInfo: {
|
||||
VINInfo: {
|
||||
VIN: {
|
||||
VINNum: job.v_vin,
|
||||
},
|
||||
},
|
||||
License: {
|
||||
LicensePlateNum: job.plate_no,
|
||||
},
|
||||
VehicleDesc: {
|
||||
//ProductionDate: "2009-10",
|
||||
ModelYear: job.v_model_yr,
|
||||
MakeDesc: job.v_make_desc,
|
||||
ModelName: job.v_model_desc,
|
||||
},
|
||||
Paint: {
|
||||
Exterior: {
|
||||
Color: {
|
||||
ColorName: job.v_color,
|
||||
// OEMColorCode: "1M3",
|
||||
},
|
||||
},
|
||||
},
|
||||
// Body: {
|
||||
// BodyStyle: "2 Door Convertible",
|
||||
// Trim: {
|
||||
// TrimCode: "1B3",
|
||||
// },
|
||||
// },
|
||||
Condition: {
|
||||
DrivableInd: job.driveable ? "Y" : "N",
|
||||
},
|
||||
},
|
||||
ClaimInfo: {
|
||||
ClaimNum: job.clm_no,
|
||||
PolicyInfo: {
|
||||
PolicyNum: job.policy_no,
|
||||
},
|
||||
LossInfo: {
|
||||
Facts: {
|
||||
LossDateTime:
|
||||
job.loss_date && moment(job.loss_date).format(),
|
||||
LossDescCode: "Collision",
|
||||
PrimaryPOI: {
|
||||
POICode: job.area_of_damage.impact1,
|
||||
},
|
||||
SecondaryPOI: {
|
||||
POICode: job.area_of_damage.impact2,
|
||||
},
|
||||
},
|
||||
TotalLossInd: job.tlos_ind,
|
||||
},
|
||||
},
|
||||
},
|
||||
ProfileInfo: {
|
||||
//ProfileName: "Shop Standard Rates",
|
||||
RateInfo: [
|
||||
{
|
||||
RateType: "PA",
|
||||
RateDesc: "Parts Tax",
|
||||
TaxInfo: {
|
||||
TaxType: "LS",
|
||||
TaxableInd: true,
|
||||
TaxTierInfo: {
|
||||
TierNum: 1,
|
||||
Percentage: 0, //TODO Find the best place to take the tax rates for parts.
|
||||
},
|
||||
},
|
||||
},
|
||||
{
|
||||
RateType: "LA",
|
||||
RateDesc: "Labor Tax",
|
||||
TaxInfo: {
|
||||
TaxType: "LS",
|
||||
TaxableInd: true,
|
||||
TaxTierInfo: {
|
||||
TierNum: 1,
|
||||
Percentage: 0, //TODO Find the best place to take the tax rates for labor.
|
||||
},
|
||||
},
|
||||
},
|
||||
{
|
||||
RateType: "LAB",
|
||||
RateDesc: "Body Labor",
|
||||
RateTierInfo: {
|
||||
TierNum: 1,
|
||||
Rate: job.rate_lab,
|
||||
},
|
||||
},
|
||||
{
|
||||
RateType: "LAS",
|
||||
RateDesc: "Structural Labor",
|
||||
RateTierInfo: {
|
||||
TierNum: 1,
|
||||
Rate: job.rate_las,
|
||||
},
|
||||
},
|
||||
{
|
||||
RateType: "LAR",
|
||||
RateDesc: "Refinish Labor",
|
||||
RateTierInfo: {
|
||||
TierNum: 1,
|
||||
Rate: job.rate_lar,
|
||||
},
|
||||
},
|
||||
{
|
||||
RateType: "LAG",
|
||||
RateDesc: "Glass Labor",
|
||||
RateTierInfo: {
|
||||
TierNum: 1,
|
||||
Rate: job.rate_lag,
|
||||
},
|
||||
},
|
||||
{
|
||||
RateType: "LAF",
|
||||
RateDesc: "Frame Labor",
|
||||
RateTierInfo: {
|
||||
TierNum: 1,
|
||||
Rate: job.rate_laf,
|
||||
},
|
||||
},
|
||||
{
|
||||
RateType: "LAM",
|
||||
RateDesc: "Mechancial Labor",
|
||||
RateTierInfo: {
|
||||
TierNum: 1,
|
||||
Rate: job.rate_lam,
|
||||
},
|
||||
},
|
||||
{
|
||||
RateType: "LAU",
|
||||
RateDesc: "User Defined Labor",
|
||||
RateTierInfo: {
|
||||
TierNum: 1,
|
||||
Rate: job.rate_lau,
|
||||
},
|
||||
},
|
||||
{
|
||||
RateType: "MAPA",
|
||||
RateDesc: "Paint Materials",
|
||||
RateTierInfo: {
|
||||
TierNum: 1,
|
||||
Rate: job.rate_mapa,
|
||||
ThresholdAmt: 0,
|
||||
},
|
||||
MaterialCalcSettings: {
|
||||
CalcMethodCode: 2,
|
||||
CalcMaxAmt: 9999.99, //TODO Find threshold amts.
|
||||
},
|
||||
},
|
||||
{
|
||||
RateType: "MASH",
|
||||
RateDesc: "Shop Materials",
|
||||
RateTierInfo: {
|
||||
TierNum: 1,
|
||||
Rate: job.rate_mash,
|
||||
},
|
||||
MaterialCalcSettings: {
|
||||
CalcMethodCode: 4,
|
||||
CalcMaxAmt: 9999.99, //TODO Find threshold amounts.
|
||||
},
|
||||
},
|
||||
{
|
||||
RateType: "MAHW",
|
||||
RateDesc: "Hazardous Wastes Removal",
|
||||
RateTierInfo: {
|
||||
TierNum: 1,
|
||||
Rate: job.rate_mahw,
|
||||
},
|
||||
MaterialCalcSettings: {
|
||||
CalcMethodCode: 2,
|
||||
CalcMaxAmt: 10,
|
||||
},
|
||||
},
|
||||
{
|
||||
RateType: "MA2S",
|
||||
RateDesc: "Two Stage Paint",
|
||||
RateTierInfo: {
|
||||
TierNum: 1,
|
||||
Rate: job.rate_ma2s,
|
||||
},
|
||||
MaterialCalcSettings: {
|
||||
CalcMethodCode: 1,
|
||||
CalcMaxAmt: 999999.99,
|
||||
},
|
||||
},
|
||||
{
|
||||
RateType: "MA2T",
|
||||
RateDesc: "Two Tone Paint",
|
||||
RateTierInfo: {
|
||||
TierNum: 1,
|
||||
Rate: job.rate_ma2t,
|
||||
},
|
||||
MaterialCalcSettings: {
|
||||
CalcMethodCode: 1,
|
||||
CalcMaxAmt: 999999.99,
|
||||
},
|
||||
},
|
||||
{
|
||||
RateType: "MA3S",
|
||||
RateDesc: "Three Stage Paint",
|
||||
RateTierInfo: {
|
||||
TierNum: 1,
|
||||
Rate: job.rate_ma3s,
|
||||
},
|
||||
MaterialCalcSettings: {
|
||||
CalcMethodCode: 1,
|
||||
CalcMaxAmt: 999999.99,
|
||||
},
|
||||
},
|
||||
],
|
||||
},
|
||||
//StorageDuration: 17,
|
||||
RepairTotalsInfo: {
|
||||
LaborTotalsInfo: [
|
||||
{
|
||||
TotalType: "LAB",
|
||||
TotalTypeDesc: "Body Labor",
|
||||
TotalHours: job.job_totals.rates.lab.hours,
|
||||
TotalAmt: Dinero(job.job_totals.rates.lab.total).toFormat(
|
||||
0.0
|
||||
),
|
||||
},
|
||||
{
|
||||
TotalType: "LAF",
|
||||
TotalTypeDesc: "Frame Labor",
|
||||
TotalHours: job.job_totals.rates.laf.hours,
|
||||
TotalAmt: Dinero(job.job_totals.rates.laf.total).toFormat(
|
||||
0.0
|
||||
),
|
||||
},
|
||||
{
|
||||
TotalType: "LAM",
|
||||
TotalTypeDesc: "Mechanical Labor",
|
||||
TotalHours: job.job_totals.rates.lam.hours,
|
||||
TotalAmt: Dinero(job.job_totals.rates.lam.total).toFormat(
|
||||
0.0
|
||||
),
|
||||
},
|
||||
{
|
||||
TotalType: "LAR",
|
||||
TotalTypeDesc: "Refinish Labor",
|
||||
TotalHours: job.job_totals.rates.lar.hours,
|
||||
TotalAmt: Dinero(job.job_totals.rates.lar.total).toFormat(
|
||||
0.0
|
||||
),
|
||||
},
|
||||
],
|
||||
PartsTotalsInfo: [
|
||||
{
|
||||
TotalType: "PAA",
|
||||
TotalTypeDesc: "Aftermarket Parts",
|
||||
TotalAmt: Dinero(
|
||||
job.job_totals.parts.parts.list.paa &&
|
||||
job.job_totals.parts.parts.list.paa.total
|
||||
).toFormat(0.0),
|
||||
},
|
||||
{
|
||||
TotalType: "PAC",
|
||||
TotalTypeDesc: "Re-Chromed Parts",
|
||||
TotalAmt: Dinero(
|
||||
job.job_totals.parts.parts.list.pac &&
|
||||
job.job_totals.parts.parts.list.pac.total
|
||||
).toFormat(0.0),
|
||||
},
|
||||
{
|
||||
TotalType: "PAG",
|
||||
TotalTypeDesc: "Glass Parts",
|
||||
TotalAmt: Dinero(
|
||||
job.job_totals.parts.parts.list.pag &&
|
||||
job.job_totals.parts.parts.list.pag.total
|
||||
).toFormat(0.0),
|
||||
},
|
||||
{
|
||||
TotalType: "PAL",
|
||||
TotalTypeDesc: "LKQ/Used Parts",
|
||||
TotalAmt: Dinero(
|
||||
job.job_totals.parts.parts.list.pal &&
|
||||
job.job_totals.parts.parts.list.pal.total
|
||||
).toFormat(0.0),
|
||||
},
|
||||
{
|
||||
TotalType: "PAM",
|
||||
TotalTypeDesc: "Remanufactured Parts",
|
||||
TotalAmt: Dinero(
|
||||
job.job_totals.parts.parts.list.pam &&
|
||||
job.job_totals.parts.parts.list.pam.total
|
||||
).toFormat(0.0),
|
||||
},
|
||||
{
|
||||
TotalType: "PAN",
|
||||
TotalTypeDesc: "New Parts",
|
||||
TotalAmt: Dinero(
|
||||
job.job_totals.parts.parts.list.pan &&
|
||||
job.job_totals.parts.parts.list.pan.total
|
||||
).toFormat(0.0),
|
||||
},
|
||||
{
|
||||
TotalType: "PAR",
|
||||
TotalTypeDesc: "Recored Parts",
|
||||
TotalAmt: Dinero(
|
||||
job.job_totals.parts.parts.list.par &&
|
||||
job.job_totals.parts.parts.list.par.total
|
||||
).toFormat(0.0),
|
||||
},
|
||||
],
|
||||
OtherChargesTotalsInfo: [
|
||||
{
|
||||
TotalType: "OTSL",
|
||||
TotalTypeDesc: "Sublet",
|
||||
TotalAmt: Dinero(
|
||||
job.job_totals.parts.sublets.total
|
||||
).toFormat(0.0),
|
||||
},
|
||||
{
|
||||
TotalType: "MAPA",
|
||||
TotalTypeDesc: "Paint Materials",
|
||||
TotalAmt: Dinero(job.job_totals.rates.mapa.total).toFormat(
|
||||
0.0
|
||||
),
|
||||
},
|
||||
{
|
||||
TotalType: "MASH",
|
||||
TotalTypeDesc: "Shop Materials",
|
||||
TotalAmt: Dinero(job.job_totals.rates.mash.total).toFormat(
|
||||
0.0
|
||||
),
|
||||
},
|
||||
{
|
||||
TotalType: "MAHW",
|
||||
TotalTypeDesc: "Hazardous Wastes Removal",
|
||||
TotalAmt: Dinero(job.job_totals.rates.mahw.total).toFormat(
|
||||
0.0
|
||||
),
|
||||
},
|
||||
{
|
||||
TotalType: "OTST",
|
||||
TotalTypeDesc: "Storage",
|
||||
TotalAmt: Dinero(
|
||||
job.job_totals.additional.storage
|
||||
).toFormat(0.0),
|
||||
},
|
||||
{
|
||||
TotalType: "OTTW",
|
||||
TotalTypeDesc: "Towing",
|
||||
TotalAmt: Dinero(job.job_totals.additional.towing).toFormat(
|
||||
0.0
|
||||
),
|
||||
},
|
||||
{
|
||||
TotalType: "OTAC",
|
||||
TotalTypeDesc: "Additional Charges",
|
||||
TotalAmt: Dinero(
|
||||
job.job_totals.additional.additionalCosts
|
||||
).toFormat(0.0),
|
||||
},
|
||||
],
|
||||
SummaryTotalsInfo: [
|
||||
{
|
||||
TotalType: "TOT",
|
||||
TotalSubType: "T2",
|
||||
TotalTypeDesc: "Net Total",
|
||||
TotalAmt: 471.3,
|
||||
},
|
||||
{
|
||||
TotalType: "TOT",
|
||||
TotalSubType: "F7",
|
||||
TotalTypeDesc: "Sales Tax",
|
||||
TotalAmt: 0,
|
||||
},
|
||||
{
|
||||
TotalType: "TOT",
|
||||
TotalSubType: "GST",
|
||||
TotalTypeDesc: "GST Tax",
|
||||
TotalAmt: 0,
|
||||
},
|
||||
{
|
||||
TotalType: "TOT",
|
||||
TotalSubType: "TT",
|
||||
TotalTypeDesc: "Gross Total",
|
||||
TotalAmt: 471.3,
|
||||
},
|
||||
{
|
||||
TotalType: "TOT",
|
||||
TotalSubType: "SM",
|
||||
TotalTypeDesc: "Supplement Total",
|
||||
TotalAmt: 0,
|
||||
},
|
||||
{
|
||||
TotalType: "TOT",
|
||||
TotalSubType: "D2",
|
||||
TotalTypeDesc: "Deductible",
|
||||
TotalAmt: 0,
|
||||
},
|
||||
{
|
||||
TotalType: "TOT",
|
||||
TotalSubType: "BTR",
|
||||
TotalTypeDesc: "Betterment",
|
||||
TotalAmt: 0,
|
||||
},
|
||||
{
|
||||
TotalType: "TOT",
|
||||
TotalSubType: "AA",
|
||||
TotalTypeDesc: "Appearance Allowance",
|
||||
TotalAmt: 0,
|
||||
},
|
||||
{
|
||||
TotalType: "TOT",
|
||||
TotalSubType: "D8",
|
||||
TotalTypeDesc: "Bottom Line Discount",
|
||||
TotalAmt: 0,
|
||||
},
|
||||
{
|
||||
TotalType: "TOT",
|
||||
TotalSubType: "INS",
|
||||
TotalTypeDesc: "Insurance Pay",
|
||||
TotalAmt: 471.3,
|
||||
},
|
||||
{
|
||||
TotalType: "TOT",
|
||||
TotalSubType: "DEPOSIT",
|
||||
TotalTypeDesc: "Deposit",
|
||||
TotalAmt: 0,
|
||||
},
|
||||
{
|
||||
TotalType: "TOT",
|
||||
TotalSubType: "CUST",
|
||||
TotalTypeDesc: "Customer Pay",
|
||||
TotalAmt: 0,
|
||||
},
|
||||
],
|
||||
RepairTotalsType: 1,
|
||||
},
|
||||
RepairLabor: {
|
||||
LaborAllocations: {
|
||||
LaborAllocation: [
|
||||
{
|
||||
LaborAllocationUUID:
|
||||
"426cce3a-efa7-44d9-b76e-50b9102c4198",
|
||||
LaborType: "LAB",
|
||||
Technician: {
|
||||
Employee: {
|
||||
PersonInfo: {
|
||||
PersonName: {
|
||||
FirstName: "Jose",
|
||||
LastName: "Gonzalez",
|
||||
},
|
||||
IDInfo: {
|
||||
IDQualifierCode: "US",
|
||||
IDNum: 2987,
|
||||
},
|
||||
},
|
||||
},
|
||||
},
|
||||
AllocatedHours: 3.5,
|
||||
},
|
||||
{
|
||||
LaborAllocationUUID:
|
||||
"426cce3a-efa7-44d9-b76e-50b9102c4199",
|
||||
LaborType: "LAR",
|
||||
Technician: {
|
||||
Employee: {
|
||||
PersonInfo: {
|
||||
PersonName: {
|
||||
FirstName: "Rcardo",
|
||||
LastName: "Himenez",
|
||||
},
|
||||
IDInfo: {
|
||||
IDQualifierCode: "US",
|
||||
IDNum: 2989,
|
||||
},
|
||||
},
|
||||
},
|
||||
},
|
||||
AllocatedHours: 5.5,
|
||||
},
|
||||
],
|
||||
},
|
||||
},
|
||||
ProductionStatus: {
|
||||
ProductionStage: {
|
||||
ProductionStageCode: 4,
|
||||
ProductionStageDateTime: "2009-03-11T11:58:32.1898319-07:00",
|
||||
ProductionStageStatusComment:
|
||||
"Going to be painted this afternoon",
|
||||
},
|
||||
RepairStatus: {
|
||||
RepairStatusCode: 2,
|
||||
RepairStatusDateTime: "2009-03-11T11:58:32.1898319-07:00",
|
||||
RepairStatusMemo: "Waiting on back ordered parts",
|
||||
},
|
||||
},
|
||||
RepairOrderNotes: {
|
||||
RepairOrderNote: {
|
||||
LineSequenceNum: 1,
|
||||
Note: "Revision Requested : approved--but needs est separated.8/22/2008 11:58:53 AM",
|
||||
CreateDateTime: "2008-08-22T11:58:53",
|
||||
AuthoredBy: {
|
||||
FirstName: {
|
||||
"#text": "Elizabeth/FirstName>",
|
||||
LastName: "Unis",
|
||||
},
|
||||
},
|
||||
RepairOrderNote: {
|
||||
LineSequenceNum: 2,
|
||||
Note: "Approved : 8/26/2008 12:21:08 PM",
|
||||
CreateDateTime: "2008-08-26T12:21:08",
|
||||
AuthoredBy: {
|
||||
FirstName: {
|
||||
"#text": "Elizabeth/FirstName>",
|
||||
LastName: "Unis",
|
||||
},
|
||||
},
|
||||
},
|
||||
},
|
||||
},
|
||||
},
|
||||
};
|
||||
});
|
||||
|
||||
if (erroredJobs.length > 0) {
|
||||
logger.log("arms-failed-jobs", "ERROR", "api", bodyshop.id, {
|
||||
count: erroredJobs.length,
|
||||
jobs: JSON.stringify(erroredJobs.map((j) => j.job.ro_number)),
|
||||
});
|
||||
}
|
||||
|
||||
logger.log("arms-end-shop-extract", "DEBUG", "api", bodyshop.id, {
|
||||
shopname: bodyshop.shopname,
|
||||
});
|
||||
} catch (error) {
|
||||
//Error at the shop level.
|
||||
logger.log("arms-error-shop", "ERROR", "api", bodyshop.id, {
|
||||
error,
|
||||
});
|
||||
|
||||
allErrors.push({
|
||||
bodyshopid: bodyshop.id,
|
||||
imexshopid: bodyshop.imexshopid,
|
||||
fatal: true,
|
||||
errors: [error.toString()],
|
||||
});
|
||||
} finally {
|
||||
allErrors.push({
|
||||
bodyshopid: bodyshop.id,
|
||||
imexshopid: bodyshop.imexshopid,
|
||||
errors: erroredJobs,
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
res.sendStatus(200);
|
||||
} catch (error) {
|
||||
res.status(200).json(error);
|
||||
}
|
||||
};
|
||||
|
||||
function GetSupplementNumber(joblines) {
|
||||
return _.max(joblines.map((jl) => jl.line_ind));
|
||||
}
|
||||
|
||||
function GetDocumentstatus(job, bodyshop) {
|
||||
switch (job.status) {
|
||||
case bodyshop.md_ro_status.default_void:
|
||||
return "V";
|
||||
case bodyshop.md_ro_status.default_invoiced:
|
||||
case bodyshop.md_ro_status.default_exported:
|
||||
return "V";
|
||||
|
||||
default:
|
||||
return "0";
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user