Home   Package List   Routine Alphabetical List   Global Alphabetical List   FileMan Files List   FileMan Sub-Files List   Package Component Lists   Package-Namespace Mapping  
Routine: PSJBCMA4

PSJBCMA4.m

Go to the documentation of this file.
  1. PSJBCMA4 ;BIR/JLC-BCMA ORDER UPDATE FOR INPATIENT MEDS ;18 JUN 01
  1. ;;5.0; INPATIENT MEDICATIONS ;**63,66,58,104**;16 DEC 97
  1. ;
  1. ;Reference to ^DPT is supported by DBIA 10035
  1. ;Reference to ^PS(55 is supported by DBIA 2191
  1. ;Reference to ^XMB is supported by DBIA 1131
  1. ;Reference to ^%DTC is supported by DBIA 10000
  1. ;Reference to ^DIE is supported by DBIA 10018
  1. ;Reference to ^DIQ is supported by DBIA 2056
  1. ;Reference to ^XMD is supported by DBIA 10070
  1. ;
  1. ENE(DFN,ON) ;
  1. N PSJIEN,PSJSTOP,PSJSTAT,PSJSTOP,PSJNOW,DA,DR,DIE,PSIVACT,ON55,PSIVREA,PSIVAL,PSIVALT,PSJSCH,X
  1. I $G(DFN)=""!($G(ON)="") Q
  1. D NOW^%DTC S PSJNOW=%
  1. I ON["V" D Q
  1. . I '$D(^PS(55,DFN,"IV",+ON)) Q
  1. . S X=$G(^PS(55,DFN,"IV",+ON,0))
  1. . S PSJSTART=$P(X,"^",2),PSJSTOP=$P(X,"^",3),PSJSCH=$P(X,"^",9),PSJSTAT=$P(X,"^",17)
  1. . I $P($G(^PS(55,DFN,"IV",+ON,.2)),"^",4)="D" Q
  1. . S DIE="^PS(55,"_DFN_",""IV"",",DA=+ON,DA(1)=DFN
  1. . I PSJSTAT'="A" D IEA(0) Q
  1. . I PSJSTOP'>PSJNOW D IEA(0) Q
  1. . I $$ONE^PSJBCMA(DFN,ON,PSJSCH,PSJSTART,PSJSTOP)'="O" D IEA(0) Q
  1. . S PSIVACT=1,DR="116////"_PSJSTOP_";.03////"_PSJNOW_";100////E;147////1" D ^DIE
  1. . D IEA(1),EN1^PSJHL2(DFN,"SC",ON,"BCMA EXPIRED")
  1. I ON["U" D Q
  1. . I '$D(^PS(55,DFN,5,+ON)) Q
  1. . S X=$G(^PS(55,DFN,5,+ON,2)),PSJSCH=$P(X,"^"),PSJSTART=$P(X,"^",2),PSJSTOP=$P(X,"^",4)
  1. . S PSJIEN=+ON_","_DFN_",",PSJSTAT=$$GET1^DIQ(55.06,PSJIEN,28,"I")
  1. . I $P($G(^PS(55,DFN,5,+ON,.2)),"^",4)="D" Q
  1. . S DIE="^PS(55,"_DFN_",5,",DA=+ON,DA(1)=DFN
  1. . I PSJSTAT'="A" D UEA(0) Q
  1. . I PSJSTOP'>PSJNOW D UEA(0) Q
  1. . I $$ONE^PSJBCMA(DFN,ON,PSJSCH,PSJSTART,PSJSTOP)'="O" D UEA(0) Q
  1. . S DR="25////"_PSJSTOP_";34////"_PSJNOW_";28////E;123////1" D ^DIE
  1. . D UEA(1),EN1^PSJHL2(DFN,"SC",ON,"BCMA EXPIRED")
  1. Q
  1. ENR(DFN,ON) ;
  1. N PSJIEN,PSJORIG,PSJSTAT,PSJSTOP,PSJNOW,DA,DR,DIE,PSIVACT,PSJF,X,PSJ,XMY,XMDUZ,XMSUB,XMTEXT
  1. I $G(DFN)=""!($G(ON)="") Q
  1. D NOW^%DTC S PSJNOW=%
  1. I ON["V" D Q
  1. . I '$D(^PS(55,DFN,"IV",+ON)) Q
  1. . S PSJIEN=+ON_","_DFN_",",PSJBCMA=$$GET1^DIQ(55.01,PSJIEN,147,"I"),PSJORIG=$$GET1^DIQ(55.01,PSJIEN,116,"I")
  1. . S DIE="^PS(55,"_DFN_",""IV"",",DA=+ON,DA(1)=DFN
  1. . I PSJBCMA'=1!(PSJORIG'>PSJNOW) D IRA(0) Q
  1. . S PSIVACT=1,DR="116////;.03////"_PSJORIG_";100////A;147////0" D ^DIE
  1. . D IRA(1),EN1^PSJHL2(DFN,"SC",ON,"BCMA REINSTATED")
  1. I ON["U" D Q
  1. . I '$D(^PS(55,DFN,5,+ON)) Q
  1. . S PSJIEN=+ON_","_DFN_",",PSJBCMA=$$GET1^DIQ(55.06,PSJIEN,123,"I"),PSJORIG=$$GET1^DIQ(55.06,PSJIEN,25,"I")
  1. . S DIE="^PS(55,"_DFN_",5,",DA=+ON,DA(1)=DFN
  1. . I PSJBCMA'=1!(PSJORIG'>PSJNOW) D URA(0) Q
  1. . S DR="25////;34////"_PSJORIG_";28////A;123////0" D ^DIE
  1. . D URA(1),EN1^PSJHL2(DFN,"SC",ON,"BCMA REINSTATED")
  1. Q
  1. IEA(STAT) ;
  1. S ON55=ON,PSIVREA="E",PSIVAL=$S(STAT:"BCMA EXPIRED",1:"BCMA EXPIRE DENIED")
  1. D LOG^PSIVORAL Q
  1. UEA(STAT) ;
  1. S PSGAL("C")=$S(STAT:25000,1:25100) D ^PSGAL5 Q
  1. IRA(STAT) ;
  1. S ON55=ON,PSIVREA="E",PSIVAL=$S(STAT:"BCMA REINSTATED",1:"BCMA REINSTATE DENIED")
  1. D LOG^PSIVORAL
  1. F PSJF=.06,135,16 S X=$$GET1^DIQ(55.01,PSJIEN,PSJF,"I") I X]"" S XMY(X)=""
  1. D MSG(STAT)
  1. Q
  1. URA(STAT) ;
  1. S PSGAL("C")=$S(STAT:25200,1:25300) D ^PSGAL5
  1. F PSJF=16,18,20 S X=$$GET1^DIQ(55.06,PSJIEN,PSJF,"I") I X]"" S XMY(X)=""
  1. D MSG(STAT)
  1. Q
  1. MSG(STAT) ;
  1. S XMDUZ="Inpatient Medications",XMSUB="Medication Order"_$S(STAT:"",1:" not")_" reinstated.",XMTEXT="PSJ(",XMY(DUZ)="",XMY("G.PSJ-ORDERS REINSTATED@"_$G(^XMB("NETNAME")))=""
  1. S PSJ(1,0)="Patient: "_$P(^DPT(DFN,0),"^"),PSJ(2,0)="The following order was"_$S(STAT:"",1:" not")_" reinstated after a status change in BCMA."
  1. S PSJLINE=0 I ON["U" D DSPLORDU^PSJLMUT1(DFN,ON)
  1. I ON["V" D DSPLORDV^PSJLMUT1(DFN,ON)
  1. S CNT=2,X="" F S X=$O(PSJOC(ON,X)) Q:X="" S CNT=CNT+1,PSJ(CNT,0)=PSJOC(ON,X)
  1. D ^XMD I $D(XMZ) S DA=XMZ,DIE=3.9,DR="1.7///P;" D ^DIE
  1. Q