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

PSOELPST.m

Go to the documentation of this file.
  1. PSOELPST ;BIR/RTR-Status update ;11/27/01
  1. ;;7.0;OUTPATIENT PHARMACY;**86**;DEC 1997
  1. ;External reference to STATUS^ORQOR2 supported by DBIA 3458
  1. ;External reference to ^OR(100 supported by DBIA 3463
  1. ;CPRS/Outpatient status update
  1. ;PSOCPRS = CPRS number (Placer)
  1. ;PSORXNUM = Outpatient number (52 ien)
  1. I '$G(XPDENV) Q
  1. N PSOPACRF
  1. S DIC=9.4,DIC(0)="Z",X="OUTPATIENT PHARMACY" D ^DIC K DIC I +Y'>0 W !!,"A problem was found when trying to identify a valid Outpatient Pharmacy",!,"package reference from the PACKAGE (#9.4) file." D S XPDQUIT=2 Q
  1. .W !,"This Patch cannot be installed until this problem is resolved.",!
  1. .K DIR S DIR(0)="E",DIR("A")="Press Return to Continue" D ^DIR K DIR
  1. S PSOPACRF=+Y
  1. W !,"This patch queues a job to find Outpatient Pharmacy orders that are expired or",!,"Discontinued, but are Active in CPRS. This patch will update the order in CPRS",!,"with the appropriate status."
  1. W ! K ZTDTH S ZTRTN="EN^PSOELPST",ZTDESC="Pharmacy/CPRS status clean up",ZTIO="",ZTSAVE("PSOPACRF")="" D ^%ZTLOAD I '$G(ZTSK) D S XPDQUIT=2
  1. .W !!,"Since this job was not queued, the patch will not be installed.",! K DIR S DIR(0)="E",DIR("A")="Press Return to Continue" D ^DIR K DIR
  1. Q
  1. EN ;
  1. N PSOCPRS,PSORXNUM,PSOXCOM,PSOXDT,PSOIJ,PSOJJ,PSOREAS,PSOACRL,PSOPHR,PSOALC,PSOADT,PSONAT,PSOCOMM,PSOZDUZ,PSOELSTA,PSOELSTP,PSOETEXT,PSOECT,PSOCSTAT
  1. I '$G(DT) S DT=$$DT^XLFDT
  1. D NOW^%DTC S PSOELSTA=%
  1. S PSOECT=0
  1. S PSOCPRS="" F S PSOCPRS=$O(^PSRX("APL",PSOCPRS)) Q:PSOCPRS="" S PSORXNUM="" F S PSORXNUM=$O(^PSRX("APL",PSOCPRS,PSORXNUM)) Q:PSORXNUM="" D
  1. .I PSOCPRS'=$P($G(^PSRX(PSORXNUM,"OR1")),"^",2) Q
  1. .I '$D(^PSRX(PSORXNUM,0)) Q
  1. .I +$$STATUS^ORQOR2(PSOCPRS)'=6 Q
  1. .I PSORXNUM'=$P($G(^OR(100,PSOCPRS,4)),"^") Q
  1. .I PSOPACRF'=$P($G(^OR(100,PSOCPRS,0)),"^",14) Q
  1. .S PSOCSTAT=$P($G(^PSRX(PSORXNUM,"STA")),"^")
  1. .I PSOCSTAT=11 D Q
  1. ..I $P(^PSRX(PSORXNUM,0),"^",19)=2 S $P(^(0),"^",19)=1
  1. ..S PSOXCOM="Prescription past expiration date" D EN^PSOHLSN1(PSORXNUM,"SC","ZE",PSOXCOM) S PSOECT=PSOECT+1
  1. ..S PSOXDT=$S($P($G(^PSRX(PSORXNUM,2)),"^",6):$E($P($G(^(2)),"^",6),1,7),1:DT)_".2200"
  1. ..I $D(^OR(100,PSOCPRS,3)) S $P(^(3),"^")=PSOXDT
  1. .I PSOCSTAT=12!(PSOCSTAT=14)!(PSOCSTAT=15) D
  1. ..S (PSOIJ,PSOJJ,PSOPHR,PSOADT)=0 F S PSOIJ=$O(^PSRX(PSORXNUM,"A",PSOIJ)) Q:'PSOIJ S PSOREAS=$P($G(^(PSOIJ,0)),"^",2) I PSOREAS="C"!(PSOREAS="L") S PSOJJ=PSOIJ
  1. ..I PSOJJ S PSOACRL=$G(^PSRX(PSORXNUM,"A",PSOJJ,0)) D
  1. ...S PSOPHR=$P(PSOACRL,"^",3),PSOALC=$P(PSOACRL,"^",5),PSOADT=$P(PSOACRL,"^"),(PSONAT,PSOCOMM)=""
  1. ...I PSOALC["Renewed" S PSOCOMM="Renewed by Pharmacy"
  1. ...I PSOALC["Auto Discontinued" S PSOPHR="",PSONAT="A",PSOCOMM=$E($P(PSOALC,".",2),2,99) S:PSOCOMM="" PSOCOMM=PSOALC
  1. ...I PSOALC["Discontinued During" S PSOCOMM="Discontinued by Pharmacy"
  1. ..I 'PSOJJ S PSOCOMM="Discontinued by Pharmacy",PSONAT=""
  1. ..S PSOZDUZ=$G(DUZ) S:$G(PSOPHR) DUZ=PSOPHR D EN^PSOHLSN1(PSORXNUM,"OD",$S(PSOCSTAT=15:"RP",1:""),PSOCOMM,PSONAT) S PSOECT=PSOECT+1 S DUZ=PSOZDUZ
  1. ..I '$G(PSOADT) S PSOADT=DT_".2200"
  1. ..I $D(^OR(100,PSOCPRS,6)) S $P(^(6),"^",3)=$E(PSOADT,1,12)
  1. ..I $D(^OR(100,PSOCPRS,3)) S $P(^(3),"^")=$E(PSOADT,1,12)
  1. MAIL ;Send mail message upon job completion
  1. K PSOPACRF
  1. I $G(DUZ) D
  1. .S XMDUZ="Patch PSO*7*86 Patch Install",XMSUB="Outpatient/CPRS Status clean-up",XMY(DUZ)=""
  1. .D NOW^%DTC S PSOELSTP=%
  1. .S PSOETEXT(1)="The tasked job for patch PSO*7*86 is complete."
  1. .S PSOETEXT(2)="The total number of mismatched statuses found were "_+$G(PSOECT)_"."
  1. .S Y=$G(PSOELSTA) D DD^%DT S PSOELSTA=$G(Y)
  1. .S Y=$G(PSOELSTP) D DD^%DT S PSOELSTP=$G(Y)
  1. .S PSOETEXT(3)="The job started on "_$G(PSOELSTA)_"."
  1. .S PSOETEXT(4)="The job ended on "_$G(PSOELSTP)_"."
  1. .S XMTEXT="PSOETEXT(" N DIFROM D ^XMD K Y,XMDUZ,XMTEXT,XMSUB
  1. S:$D(ZTQUEUED) ZTREQ="@"
  1. Q