| 1 | PSORX1 ;BIR/SAB-medication processing driver ;3/28/05 1:14pm | 
|---|
| 2 | ;;7.0;OUTPATIENT PHARMACY;**7,22,23,57,62,46,74,71,90,95,115,117,146,139,135,182,195,233,268**;DEC 1997;Build 9 | 
|---|
| 3 | ;External reference PDA^PPPPDA1 supported by DBIA 1374 | 
|---|
| 4 | ;External reference ^PS(55 supported by DBIA 2228 | 
|---|
| 5 | ;External reference ^DIC(31 supported by DBIA 658 | 
|---|
| 6 | ;External reference ^DPT(D0,.372 supported by DBIA 1476 | 
|---|
| 7 | ;External reference DISPPRF^DGPFAPI supported by DBIA #4563 | 
|---|
| 8 | ;External reference ^ORRDI1 is supported by DBIA 4659 | 
|---|
| 9 | ;External reference ^XTMP("ORRDI" is supported by DBIA 4660 | 
|---|
| 10 | ; | 
|---|
| 11 | ;PSO*195 add call to display Patient Record Flag (DISPPRF^DGPFAPI) | 
|---|
| 12 | ; | 
|---|
| 13 | START K PSOQFLG,PSOID,PSOFIN,PSOQUIT,PSODRUG S (PSOBCK,PSOERR)=1 D INIT G:PSORX("QFLG") END | 
|---|
| 14 | D PT G:$G(PSORX("QFLG")) END D FULL^VALM1 I $G(NOPROC) K NOPROC G NX | 
|---|
| 15 | ;call to add bingo board data to file 52.11 | 
|---|
| 16 | F SLPPL=0:0 S SLPPL=$O(RXRS(SLPPL)) Q:'SLPPL  D | 
|---|
| 17 | .I $P($G(^PSRX(SLPPL,"STA")),"^")'=5 K RXRS(SLPPL) Q | 
|---|
| 18 | .S RXREC=SLPPL D WIND^PSOSUPOE I $G(PBINGRTE) D BBADD^PSOSUPOE S (BINGCRT,BINGRTE)=1 S:$G(PSOFROM)'="NEW" PSOFROM="REFILL" | 
|---|
| 19 | K TM,TM1 I $G(PSORX("PSOL",1))]""!($D(RXRS)) D ^PSORXL K PSORX S PSOPBM1=1 | 
|---|
| 20 | G:$G(NOBG) NX | 
|---|
| 21 | S TM=$P(^TMP("PSOBB",$J),"^"),TM1=$P(^TMP("PSOBB",$J),"^",2) K ^TMP("PSOBB",$J) | 
|---|
| 22 | I $G(PSOFROM)="NEW"!($G(PSOFROM)="REFILL")!($G(PSOFROM)="PARTIAL") D:$D(BINGCRT)&($D(BINGRTE)&($D(DISGROUP))) ^PSOBING1 K BINGCRT,BINGRTE,BBRX,BBFLG | 
|---|
| 23 | I $G(PSOPBM),$G(PSOPBM1) S $P(^PS(55,PSODFN,0),"^",7)=PSOPBM,$P(^(0),"^",8)="A" K PSOPBM,PSOPBM1 | 
|---|
| 24 | NX I $G(POERR("DEAD"))!$G(PSOQFLG) D EOJ G START | 
|---|
| 25 | D EOJ G START | 
|---|
| 26 | END Q | 
|---|
| 27 | ;--------------------------------------------------------- | 
|---|
| 28 | INIT ; | 
|---|
| 29 | S PSORX("QFLG")=0 | 
|---|
| 30 | D:'$D(PSOPAR) ^PSOLSET I '$D(PSOPAR) S PSORX("QFLG")=1 | 
|---|
| 31 | I $P($G(PSOPAR),"^",2),'$D(^XUSEC("PSORPH",DUZ)) S PSORX("VERIFY")=1 | 
|---|
| 32 | INITX Q | 
|---|
| 33 | ; | 
|---|
| 34 | PT ; | 
|---|
| 35 | K ^TMP("PSORXDC",$J),CLOZPAT,DIC,PSODFN,PSOPBM,PSOPBM1 S PSORX("QFLG")=0,DIC=2,DIC(0)="QEAM" D ^DIC K DIC,DA | 
|---|
| 36 | I +Y'>0 S PSORX("QFLG")=1 G PTX | 
|---|
| 37 | OERR N:$G(MEDP) PAT,POERR K PSOXFLG S (DFN,PSODFN)=+Y,PSORX("NAME")=$P(Y,"^",2) | 
|---|
| 38 | K NPPROC,PSOQFLG,DIC,DR,DIQ S DIC=2,DA=PSODFN,DR=.351,DIQ="PSOPTPST" D EN^DIQ1 K DIC,DA,DR,DIQ D DEAD^PSOPTPST I $G(PSOQFLG) S NOPROC=1 Q | 
|---|
| 39 | ;PSO*195 move SSN write to here and add DISPPRF call | 
|---|
| 40 | S SSN=$P(^DPT(PSODFN,0),"^",9) W !!?10,$C(7),PSORX("NAME") | 
|---|
| 41 | W " ("_$E(SSN,1,3)_"-"_$E(SSN,4,5)_"-"_$E(SSN,6,9)_")" K SSN | 
|---|
| 42 | S PSONOAL="" D ALLERGY^PSOORUT2 D  I PSONOAL'="" D PAUSE | 
|---|
| 43 | .I PSONOAL'="" W !,$C(7),"     No Allergy Assessment!" | 
|---|
| 44 | D REMOTE | 
|---|
| 45 | N PSOUPDT | 
|---|
| 46 | S PSOUPDT=1 | 
|---|
| 47 | I XQY0["PSO LMOE FINISH" S PSOUPDT=0 | 
|---|
| 48 | D CHKADDR^PSOBAI(PSODFN,1,PSOUPDT) | 
|---|
| 49 | D:(XQY0["PSO LMOE FINISH")&('$G(SNGLPAT)) DISPPRF^DGPFAPI(PSODFN) | 
|---|
| 50 | ; | 
|---|
| 51 | I $P($G(^PS(55,PSODFN,"LAN")),"^") W !?10,"Patient has another language preference!",! H 3 | 
|---|
| 52 | I $G(^PS(55,"ASTALK",PSODFN)) W !,"Patient is enrolled to receive ScripTalk 'talking' prescription labels.",! H 2 D MAIL | 
|---|
| 53 | D NOW^%DTC S TM=$E(%,1,12),TM1=$P(TM,".",2) S ^TMP("PSOBB",$J)=TM_"^"_TM1 | 
|---|
| 54 | I '$G(MEDP) S X="PPPPDA1" X ^%ZOSF("TEST") S:$T X=$$PDA^PPPPDA1(PSODFN) | 
|---|
| 55 | S PSOQFLG=0,DIC="^PS(55,",DLAYGO=55 | 
|---|
| 56 | K PSOPBM ; KILL SO THAT WON'T CARRY OVER PRIOR PATIENT'S VALUE | 
|---|
| 57 | I '$D(^PS(55,PSODFN,0)) D | 
|---|
| 58 | .S PSOPBM=$P(TM,".") | 
|---|
| 59 | .K DD,DO S DIC(0)="L",(DINUM,X)=PSODFN D FILE^DICN D:Y<1  K DIC,DA,DR,DD,DO | 
|---|
| 60 | ..S $P(^PS(55,PSODFN,0),"^")=PSODFN K DIK S DA=PSODFN,DIK="^PS(55,",DIK(1)=.01 D EN^DIK K DIK | 
|---|
| 61 | D RXSTA | 
|---|
| 62 | S PSOLOUD=1 D:$P($G(^PS(55,PSODFN,0)),"^",6)'=2 EN^PSOHLUP(PSODFN) K PSOLOUD | 
|---|
| 63 | I $G(^PS(55,PSODFN,"PS"))']"" D  I $G(POERR("QFLG")) G EOJ | 
|---|
| 64 | .L +^PS(55,PSODFN):$S(+$G(^DD("DILOCKTM"))>0:+^DD("DILOCKTM"),1:3) I '$T W $C(7),!!,"Patient Data is Being Edited by Another User!",! S POERR("QFLG")=1 S:$G(PSOFIN) PSOQUIT=1 Q | 
|---|
| 65 | .S PSOXFLG=1,SSN=$P(^DPT(PSODFN,0),"^",9) W !!?10,$C(7),PSORX("NAME")_" ("_$E(SSN,1,3)_"-"_$E(SSN,4,5)_"-"_$E(SSN,6,9)_")",! K SSN | 
|---|
| 66 | .S DIE=55,DR=".02;.03;.04;.05;1;D ELIG^PSORX1;3;50;106;106.1",DA=PSODFN W !!,?5,">>PHARMACY PATIENT DATA<<",! D ^DIE L -^PS(55,PSODFN) | 
|---|
| 67 | S PSOX=$G(^PS(55,PSODFN,"PS")) I PSOX]"" S PSORX("PATIENT STATUS")=$P($G(^PS(53,PSOX,0)),"^") | 
|---|
| 68 | I $G(^PS(55,PSODFN,"PS"))']"" D  I $G(POERR("QFLG")) G EOJ | 
|---|
| 69 | .W !!,"Patient Status Required!!",! D ELIG | 
|---|
| 70 | .W ! K POERR("QFLG"),DIC,DR,DIE S DIC("A")="RX PATIENT STATUS: ",DIC(0)="QEAMZ",DIC=53 D ^DIC K DIC | 
|---|
| 71 | .I $D(DIRUT)!(Y=-1) D  Q | 
|---|
| 72 | ..W $C(7),"Required Data!",! S POERR("QFLG")=1 S:$G(PSOFIN) PSOQUIT=1 | 
|---|
| 73 | ..I $G(PSOPBM) D  K PSOPBM | 
|---|
| 74 | ...I $O(^PS(55,PSODFN,0))="" S DA=PSODFN,DIK="^PS(55," D ^DIK | 
|---|
| 75 | .S ^PS(55,PSODFN,"PS")=+Y,PSORX("PATIENT STATUS")=$P(^PS(53,+Y,0),"^") | 
|---|
| 76 | .K DIRUT,DTOUT,DUOUT,X,Y,DA | 
|---|
| 77 | Q:$G(PSOFIN) | 
|---|
| 78 | I '$G(PSOPBM),'$P(^PS(55,PSODFN,0),"^",7),$P(^(0),"^",8)']"" S PSOPBM=$P(TM,".") | 
|---|
| 79 | D ^PSOBUILD | 
|---|
| 80 | F PT="GET","DEAD","INP","CNH","TPB","ADDRESS","COPAY" S RTN=PT_"^PSOPTPST" D @RTN Q:$G(POERR("DEAD"))!($G(PSOQFLG)) | 
|---|
| 81 | I $G(POERR("DEAD")) S POERR("QFLG")=1 F II=0:0 S II=$O(^PS(52.41,"P",PSODFN,II)) D:$P($G(^PS(52.41,II,0)),"^",3)'="DC"&($P($G(^(0)),"^",3)'="DE") DC^PSOORFI2 | 
|---|
| 82 | K PSOERR("DEAD"),II I $G(PSOQFLG) S POERR("QFLG")=1 G EOJ Q | 
|---|
| 83 | S (PAT,PSOXXDFN)=PSODFN,POERR=1 D ^PSOORUT2,BLD^PSOORUT1,EN^PSOLMUTL | 
|---|
| 84 | D CLEAR^VALM1 G:$G(PSOQUIT) PTX D EN^PSOLMAO | 
|---|
| 85 | S (DFN,PSODFN)=PSOXXDFN K DIE,DIC,DLAYGO,DR,DA,PSOX,PSORXED | 
|---|
| 86 | PTX ; | 
|---|
| 87 | K X,Y,^TMP("PS",$J),C,DEA,PRC,PSCNT,PSOACT,PSOCLC,PSOCS,PSOCT,PSOFINFL,PSOHD,PSOLST,PSOOPT,PSOPF,PSOX,PSOX1,PSOXXDFN,SIGOK,STP,STR | 
|---|
| 88 | Q | 
|---|
| 89 | EOJ ; | 
|---|
| 90 | K PSOERR,PSOMED,PSORX,PSOSD,PSODRUG,PSODFN,PSOOPT,PSOBILL,PSOIBQS,PSOCPAY,PSOPF,PSOPI,COMM,DGI,DGS,PT,PTDY,PTRF,RN,RTN,SERS,ST0,STAT,DFN,STOP,SLPPL,RXREC,PSOPBM | 
|---|
| 91 | K:'$G(MEDP) PSOQFLG | 
|---|
| 92 | D KVA^VADPT,FULL^VALM1 K PSOLST,PSOXFLG,PSCNT,PSDIS,PSOAL,P1,LOG,%,%DT,%I,D0,DAT,DFN,DRG,ORX,PSON,PSOPTPST,PSORX,PTST,PSOBCK,PSOID,PSOBXPUL | 
|---|
| 93 | K INCOM,SIG,SG,STP,RX0,RXN,RX2,RX3,RTS,C,DEAD,PS,PSOCLC,PSOCNT,PSOCT,PSODA,PSOFROM,PSOHD,R3,REA,RF,RFD,RFM,RLD,RXNUM,RXP,RXPR,RXRP,RXRS,STR,POERR,VALMSG | 
|---|
| 94 | K ^TMP("PSORXDC",$J),^TMP("PSOAL",$J),^TMP("PSOAO",$J),^TMP("PSOSF",$J),^TMP("PSOPF",$J),^TMP("PSOPI",$J),^TMP("PSOPO",$J),^TMP("PSOHDR",$J) I '$G(MEDP),'$G(PSOQUIT) K PAT | 
|---|
| 95 | K PSORX,RFN,PSOXXDFN,VALM,VALMKEY,PSOBCK,SPOERR,PSOFLAG,VALMBCK,D,GMRA,GMRAL,GMRAREC,PSOSTA,PSODT,RXFL,NOBG,BBRX,BBFLG | 
|---|
| 96 | Q | 
|---|
| 97 | ELIG ; shows eligibility and disabilities | 
|---|
| 98 | D ELIG^VADPT W !,"Eligibility: "_$P(VAEL(1),"^",2)_$S(+VAEL(3):"     SC%: "_$P(VAEL(3),"^",2),1:"") S N=0 F  S N=$O(VAEL(1,N)) Q:'N  W !,?10,$P(VAEL(1,N),"^",2) | 
|---|
| 99 | W !,"Disabilities: " F I=0:0 S I=$O(^DPT(DFN,.372,I)) Q:'I  S I1=$S($D(^DPT(DFN,.372,I,0)):^(0),1:"") D:+I1 | 
|---|
| 100 | .S PSDIS=$S($P($G(^DIC(31,+I1,0)),"^")]""&($P($G(^(0)),"^",4)']""):$P(^(0),"^"),$P($G(^DIC(31,+I1,0)),"^",4)]"":$P(^(0),"^",4),1:""),PSCNT=$P(I1,"^",2) | 
|---|
| 101 | .W:$L(PSDIS_"-"_PSCNT_"% ("_$S($P(I1,"^",3):"SC",1:"NSC")_"), ")>80 !,?15 | 
|---|
| 102 | .W $S($G(PSDIS)]"":PSDIS_"-",1:"")_PSCNT_"% ("_$S($P(I1,"^",3):"SC",1:"NSC")_"), " | 
|---|
| 103 | K N | 
|---|
| 104 | Q | 
|---|
| 105 | PROFILE ; | 
|---|
| 106 | S (PSORX("REFILL"),PSORX("RENEW"))=0,PSOX="" D ^PSOBUILD | 
|---|
| 107 | I '$G(PSOSD) W !,"This patient has no prescriptions" S:'$D(DFN) DFN=PSODFN D GMRA^PSODEM G PROFILEX | 
|---|
| 108 | S (PSODRG,PSOX)="" F  S PSODRG=$O(PSOSD(PSODRG)) Q:PSODRG=""  F  S PSOX=$O(PSOSD(PSODRG,PSOX)) Q:PSOX=""  S:$P(PSOSD(PSODRG,PSOX),"^",3)="" PSORX("RENEW")=1 S:$P(PSOSD(PSODRG,PSOX),"^",4)="" PSORX("REFILL")=1 | 
|---|
| 109 | K PSOX | 
|---|
| 110 | PROFILEX Q | 
|---|
| 111 | ; | 
|---|
| 112 | MAIL ; MAKE SURE MAIL STATUS IS COMPATIBLE WITH SCRIPTALK PATIENT | 
|---|
| 113 | I $P($G(^PS(59,PSOSITE,"STALK")),"^")="" Q  ; NO SCRIPTALK PRINTER SET UP FOR THIS DIVISION | 
|---|
| 114 | N MAIL | 
|---|
| 115 | S MAIL=$G(^PS(55,PSODFN,0)) I $P(MAIL,"^",3)>1 Q | 
|---|
| 116 | MAILP W !!,"REMINDER: CMOP does not fill ScripTalk prescriptions.Please select mail" | 
|---|
| 117 | W !,"status:  2 (DO NOT MAIL), 3 (LOCAL REGULAR MAIL) or 4 (LOCAL CERTFIED MAIL)." | 
|---|
| 118 | R !,"MAIL: ",MAIL:120 | 
|---|
| 119 | I MAIL?1"^".E Q | 
|---|
| 120 | I MAIL<2!(MAIL>4) W !,"INVALID MAIL SETTING - ENTER 2,3, OR 4" G MAILP | 
|---|
| 121 | W "  ",$S(MAIL=2:"DO NOT MAIL",MAIL=3:"LOCAL REGULAR MAIL",1:"LOCAL CERTIFIED MAIL") | 
|---|
| 122 | S $P(^PS(55,PSODFN,0),"^",3)=MAIL | 
|---|
| 123 | Q | 
|---|
| 124 | REMOTE ; | 
|---|
| 125 | I $T(HAVEHDR^ORRDI1)']"" Q | 
|---|
| 126 | I '$$HAVEHDR^ORRDI1 Q | 
|---|
| 127 | I $D(^XTMP("ORRDI","OUTAGE INFO","DOWN")) W !,"Remote data not available - Only local order checks processed." D  Q | 
|---|
| 128 | .K DIR W ! S DIR(0)="EA",DIR("A")="Press Return to continue..." D ^DIR W ! K DIR | 
|---|
| 129 | Q | 
|---|
| 130 | PAUSE ; | 
|---|
| 131 | W ! K DIR S DIR(0)="E",DIR("A")="Press Return to continue" D ^DIR K DIR | 
|---|
| 132 | Q | 
|---|
| 133 | ; | 
|---|
| 134 | RXSTA ; DISPLAY ELIGIBILITY & PROMPT FOR RX PATIENT STATUS | 
|---|
| 135 | N DA,PSOSTA | 
|---|
| 136 | I '$G(PSODFN) Q | 
|---|
| 137 | S DA=PSODFN,PSOSTA=$G(^PS(55,PSODFN,"PS")) | 
|---|
| 138 | I XQY0["PSO LMOE FINISH"!(XQY0["PSO LM BACKDOOR ORDERS") I PSOSTA]"" D | 
|---|
| 139 | .D ELIG^VADPT W !,"Eligibility: "_$P(VAEL(1),"^",2)_$S(+VAEL(3):"     SC%: "_$P(VAEL(3),"^",2),1:"") | 
|---|
| 140 | .S N=0 F  S N=$O(VAEL(1,N)) Q:'N  W !,?10,$P(VAEL(1,N),"^",2) | 
|---|
| 141 | .S DIC("A")="RX PATIENT STATUS: ",DIC("B")=PSOSTA,DIC(0)="QEAMZ",DIC=53 D ^DIC K DIC | 
|---|
| 142 | .I +Y>0,+Y'=PSOSTA S DIE="^PS(55,",DR="3////"_+Y D ^DIE | 
|---|
| 143 | Q | 
|---|