| 1 | PSOORFI2 ;BIR/BHW-finish cprs orders cont. ;1/27/07  13:25
 | 
|---|
| 2 |  ;;7.0;OUTPATIENT PHARMACY;**7,15,23,27,46,130,146,177,222,208**;DEC 1997;Build 39
 | 
|---|
| 3 |  ; Modified from FOIA VISTA,
 | 
|---|
| 4 |  ; GPL Copyright (C) 2007 WorldVistA
 | 
|---|
| 5 |  ;Ext ref ^YSCL(603.01 supported by DBIA 2697
 | 
|---|
| 6 |  ;Ext refs PSOL and PSOUL^PSSLOCK supported by DBIA 2789
 | 
|---|
| 7 | HLP W !,"Enter 'S' to process orders with a priority of STAT",!,"      'E' to process orders with an Emergency priority,",!,"      'R' to process Routine orders.",! Q
 | 
|---|
| 8 | HELP ;
 | 
|---|
| 9 |  W !,"Please enter a minimum of two (2) characters.",!,"Enter Patient's name whose med orders are to be completed.",!
 | 
|---|
| 10 |  S (PATN,DPT)=0 F  S DPT=$O(^PS(52.41,"AOR",DPT)) Q:'DPT  I $D(^PS(52.41,"AOR",DPT,PSOPINST)) W !,$P(^DPT(DPT,0),"^") S PATN=PATN+1 I PATN=20 D  I $D(DUOUT)!($D(DTOUT)) G HELPX
 | 
|---|
| 11 |  .K DIR,DUOUT,DTOUT,DIRUT S DIR(0)="E" D ^DIR S PATN=0 K DIR
 | 
|---|
| 12 | HELPX K DTOUT,DUOUT,DIRUT,PAINST S DIR(0)="FO^2:30",DIR("A")="Select Patient",DIR("?")="^D HELP^PSOORFIN"
 | 
|---|
| 13 |  K PATN,DPT Q
 | 
|---|
| 14 | RTE ;
 | 
|---|
| 15 |  S PSZFIN=1
 | 
|---|
| 16 |  F PSZFZZ=0:0 S PSZFZZ=$O(^PS(52.41,"AC",PAT,$E(PSRT),PSZFZZ)) Q:'PSZFZZ!('PSZFIN)  D
 | 
|---|
| 17 |  .I $P($G(^PS(52.41,PSZFZZ,0)),"^",3)="NW"!($P($G(^(0)),"^",3)="RNW")!($P($G(^(0)),"^",3)="RF") I $P($G(^PS(52.41,PSZFZZ,"INI")),"^")=$G(PSOPINST) S PSZFIN=0
 | 
|---|
| 18 |  Q
 | 
|---|
| 19 | PRI ;
 | 
|---|
| 20 |  S PSZFIN=1
 | 
|---|
| 21 |  F PSZFZZ=0:0 S PSZFZZ=$O(^PS(52.41,"AP",PAT,$E(PSRT),PSZFZZ)) Q:'PSZFZZ!('PSZFIN)  D
 | 
|---|
| 22 |  .I $P($G(^PS(52.41,PSZFZZ,0)),"^",3)="NW"!($P($G(^(0)),"^",3)="RNW")!($P($G(^(0)),"^",3)="RF") I $P($G(^PS(52.41,PSZFZZ,"INI")),"^")=$G(PSOPINST) S PSZFIN=0
 | 
|---|
| 23 |  Q
 | 
|---|
| 24 | PROFILE ;
 | 
|---|
| 25 |  S MEDA=3
 | 
|---|
| 26 |  I $G(PSOAFYN)'="Y" W !!! K MEDP,DIR,DUOUT,DIRUT,DTOUT S DIR(0)="Y",DIR("B")="Yes",DIR("A")="Do you want to see Medication Profile" D ^DIR K DIR Q:$D(DIRUT)!('Y)
 | 
|---|
| 27 |  I $G(PSOAFYN)'="Y" I Y S MEDP=1
 | 
|---|
| 28 |  I $G(PSOAFYN)="Y" K MEDP
 | 
|---|
| 29 |  K DIR,DUOUT,DIRUT,DTOUT
 | 
|---|
| 30 |  Q
 | 
|---|
| 31 | DC I '$G(PSOORRNW),$G(PSOOPT)=3 S PSORENW("DFLG")=1 S:'$D(PSOBBC1("FROM")) VALMBCK="Q",VALMSG="Renew Rx Request Canceled.",Y=-1 Q
 | 
|---|
| 32 |  I $G(PSOAFYN)'="Y" N VALMCNT W ! K DIR,DUOUT,DIROUT,DTOUT,PSOELSE I '$G(PSOERR("DEAD")) S PSOELSE=1 D  Q:$D(DIRUT)
 | 
|---|
| 33 |  .D NOOR^PSOCAN4 Q:$D(DIRUT)
 | 
|---|
| 34 |  .S DIR("A")="Comments",DIR(0)="F^10:75",DIR("B")="Per Pharmacy Request" D ^DIR K DIR
 | 
|---|
| 35 |  I $G(PSOAFYN)="Y" N VALMCNT K DIR,DUOUT,DIROUT,DTOUT,PSOELSE I '$G(PSOERR("DEAD")) S PSOELSE=1 D  Q:$D(DIRUT)  ;vfah
 | 
|---|
| 36 |  .D NOOR^PSOCAN4 Q:$D(DIRUT)  ;vfah
 | 
|---|
| 37 |  .S Y="Rx AutoFinish" ;vfah
 | 
|---|
| 38 |  I $G(PSOAFYN)'="Y" S PSOELSE="1"
 | 
|---|
| 39 |  I '$G(PSOELSE) K PSOELSE S PSONOOR="A" G DE
 | 
|---|
| 40 |  K PSOELSE I $D(DIRUT) K DIRUT,DUOUT,DTOUT,Y Q
 | 
|---|
| 41 |  S ACOM=Y
 | 
|---|
| 42 | DE I $G(PSOAFYN)="Y" Q
 | 
|---|
| 43 |  I $G(PSOAFYN)'="Y" Q:'$D(^PS(52.41,ORD,0))
 | 
|---|
| 44 |  K ^PS(52.41,"AOR",$P(^PS(52.41,ORD,0),"^",2),+$P($G(^PS(52.41,ORD,"INI")),"^"),ORD),^PS(52.41,"AD",$P(^PS(52.41,ORD,0),"^",12),+$P($G(^PS(52.41,ORD,"INI")),"^"),ORD)
 | 
|---|
| 45 |  S $P(^PS(52.41,ORD,0),"^",3)="DC",POERR("PLACER")=$P(^(0),"^"),POERR("STAT")="OC"
 | 
|---|
| 46 |  S POERR("COMM")=$S($G(POERR("DEAD")):"Patient died on "_$G(PSOPTPST(2,PSODFN,.351))_".",1:ACOM),$P(^PS(52.41,ORD,4),"^")=POERR("COMM")
 | 
|---|
| 47 |  D EN^PSOHLSN(POERR("PLACER"),POERR("STAT"),POERR("COMM"),PSONOOR)
 | 
|---|
| 48 |  I '$G(POERR("DEAD")) S DIR("A")="Press Return to Continue" D PAUSE^VALM1
 | 
|---|
| 49 |  K PSONOOR,PDORUG,ACOM,CMOP,DEA,DEF,DREN,FDR,HDR,PHI,PRC,SIGOK,DIR,DTOUT,DUOUT,DIRUT
 | 
|---|
| 50 |  S Y=-1 Q
 | 
|---|
| 51 |  ;
 | 
|---|
| 52 | RF ;
 | 
|---|
| 53 |  S PSOREF("IRXN")=$P(OR0,"^",19) D PSOL^PSSLOCK($P(OR0,"^",19)) I '$G(PSOMSG) D  D PAUSE^VALM1 K PSOREF,PSOMSG Q
 | 
|---|
| 54 |  .I $P($G(PSOMSG),"^",2)'="" W $C(7),!!,$P(PSOMSG,"^",2),! Q
 | 
|---|
| 55 |  .W $C(7),!!,"Another person is editing Rx "_$P(^PSRX($P(OR0,"^",19),0),"^"),!
 | 
|---|
| 56 |  K PSOMSG S (PSOREF("DFLG"),PSOREF("FIELD"),PSOREF1)=0,X="T-6M",%DT="X" D ^%DT
 | 
|---|
| 57 |  S (PSOID,PSOREF("ISSUE DATE"))=$S($P(^PSRX(PSOREF("IRXN"),0),"^",13)<Y:Y,1:$P(^PSRX(PSOREF("IRXN"),0),"^",13))
 | 
|---|
| 58 |  S:$G(PSORX("BAR CODE"))&($G(PSOBBC1("FROM"))="NEW") PSOREF("ISSUE DATE")=DT K X,X1,X2
 | 
|---|
| 59 |  ;
 | 
|---|
| 60 |  S PSONEW("DAYS SUPPLY")=$P(^PSRX(PSOREF("IRXN"),0),"^",8),PSONEW("# OF REFILLS")=$P(^(0),"^",9) D FULL^VALM1
 | 
|---|
| 61 |  W !!,"Processing Refill Request for Rx "_$P(^PSRX(PSOREF("IRXN"),0),"^")
 | 
|---|
| 62 |  D FILLDT^PSODIR2(.PSOREF) I PSOREF("DFLG") S VALMBCK="R" G END
 | 
|---|
| 63 |  ;
 | 
|---|
| 64 |  S PSORX("MAIL/WINDOW")=$S($P(OR0,"^",17)="M":"MAIL",1:"WINDOW") D MW^PSODIR2(.PSOREF) I PSOREF("DFLG") S VALMBCK="R" G END
 | 
|---|
| 65 |  S:'$G(PSOFROM)'="NEW" PSOFROM="REFILL" S PSOREF("DFLG")=0
 | 
|---|
| 66 |  D ^PSOREF0
 | 
|---|
| 67 | END D PSOUL^PSSLOCK(PSOREF("IRXN")) K PSOREF,NODE,PSOREF1,PSL,PSOERR,PSORX("QFLG")
 | 
|---|
| 68 |  Q
 | 
|---|
| 69 | S D KPRI,KPRIZ F  S ORD=$O(^PS(52.41,"AP",PAT,"S",ORD)) Q:'ORD!($G(POERR("QFLG")))  I $P(^PS(52.41,ORD,0),"^",3)'="DC",$P(^(0),"^",3)'="DE" D LOCK1^PSOORFI1,ORD^PSOORFIN S PSOSTATZ=1
 | 
|---|
| 70 |  D:$G(POERR("QFLG")) KPRI Q:$G(POERR("QFLG"))  I $G(PSOSTATZ) S ORD=0 D
 | 
|---|
| 71 |  .D KPRIZ F  S ORD=$O(^PS(52.41,"AP",PAT,"E",ORD)) Q:'ORD!($G(POERR("QFLG")))  I $P(^PS(52.41,ORD,0),"^",3)'="DC",$P(^(0),"^",3)'="DE" D LOCK1^PSOORFI1,ORD^PSOORFIN
 | 
|---|
| 72 |  .Q:$G(POERR("QFLG"))
 | 
|---|
| 73 |  .D KPRIZ S ORD=0 F  S ORD=$O(^PS(52.41,"AP",PAT,"R",ORD)) Q:'ORD!($G(POERR("QFLG")))  I $P(^PS(52.41,ORD,0),"^",3)'="DC",$P(^(0),"^",3)'="DE" D LOCK1^PSOORFI1,ORD^PSOORFIN
 | 
|---|
| 74 |  D KPRI
 | 
|---|
| 75 |  Q
 | 
|---|
| 76 | E D KPRI,KPRIZ F  S ORD=$O(^PS(52.41,"AP",PAT,"E",ORD)) Q:'ORD!($G(POERR("QFLG")))  I $P(^PS(52.41,ORD,0),"^",3)'="DC",$P(^(0),"^",3)'="DE" D LOCK1^PSOORFI1,ORD^PSOORFIN S PSOEMERZ=1
 | 
|---|
| 77 |  D:$G(POERR("QFLG")) KPRI Q:$G(POERR("QFLG"))  I $G(PSOEMERZ) S ORD=0 D
 | 
|---|
| 78 |  .D KPRIZ F  S ORD=$O(^PS(52.41,"AP",PAT,"S",ORD)) Q:'ORD!($G(POERR("QFLG")))  I $P(^PS(52.41,ORD,0),"^",3)'="DC",$P(^(0),"^",3)'="DE" D LOCK1^PSOORFI1,ORD^PSOORFIN
 | 
|---|
| 79 |  .Q:$G(POERR("QFLG"))
 | 
|---|
| 80 |  .D KPRIZ S ORD=0 F  S ORD=$O(^PS(52.41,"AP",PAT,"R",ORD)) Q:'ORD!($G(POERR("QFLG")))  I $P(^PS(52.41,ORD,0),"^",3)'="DC",$P(^(0),"^",3)'="DE" D LOCK1^PSOORFI1,ORD^PSOORFIN
 | 
|---|
| 81 |  D KPRI
 | 
|---|
| 82 |  Q
 | 
|---|
| 83 | R D KPRI,KPRIZ F  S ORD=$O(^PS(52.41,"AP",PAT,"R",ORD)) Q:'ORD!($G(POERR("QFLG")))  I $P(^PS(52.41,ORD,0),"^",3)'="DC",$P(^(0),"^",3)'="DE" D LOCK1^PSOORFI1,ORD^PSOORFIN S PSOROUTZ=1
 | 
|---|
| 84 |  D:$G(POERR("QFLG")) KPRI Q:$G(POERR("QFLG"))  I $G(PSOROUTZ) S ORD=0 D
 | 
|---|
| 85 |  .D KPRIZ F  S ORD=$O(^PS(52.41,"AP",PAT,"E",ORD)) Q:'ORD!($G(POERR("QFLG")))  I $P(^PS(52.41,ORD,0),"^",3)'="DC",$P(^(0),"^",3)'="DE" D LOCK1^PSOORFI1,ORD^PSOORFIN
 | 
|---|
| 86 |  .Q:$G(POERR("QFLG"))
 | 
|---|
| 87 |  .D KPRIZ S ORD=0 F  S ORD=$O(^PS(52.41,"AP",PAT,"S",ORD)) Q:'ORD!($G(POERR("QFLG")))  I $P(^PS(52.41,ORD,0),"^",3)'="DC",$P(^(0),"^",3)'="DE" D LOCK1^PSOORFI1,ORD^PSOORFIN
 | 
|---|
| 88 |  D KPRI
 | 
|---|
| 89 |  Q
 | 
|---|
| 90 | KPRI K PSOSTATZ,PSOROUTZ,PSOEMERZ
 | 
|---|
| 91 |  Q
 | 
|---|
| 92 | KPRIZ K PSOQUIT,POERR("QFLG")
 | 
|---|
| 93 |  Q
 | 
|---|
| 94 | INST ;
 | 
|---|
| 95 |  I '$G(PSOSITE) D ^PSOLSET I '$G(PSOSITE) S PSOIQUIT=1 Q
 | 
|---|
| 96 |  N PSIR,PSCT,PSINST K PSOPINST
 | 
|---|
| 97 |  I $G(PSOAFYN)="Y" S PSCT=1,PSOPINST=+ORL ;vfah selects CPRS Ordering Institution if autofinishing and non-interactive
 | 
|---|
| 98 |  I $G(PSOAFYN)'="Y" S PSCT=0 F PSIR=0:0 S PSIR=$O(^PS(59,PSOSITE,"INI1",PSIR)) Q:'PSIR  I $P($G(^PS(59,PSOSITE,"INI1",PSIR,0)),"^") S PSCT=PSCT+1 I PSCT=1 S PSOPINST=$P($G(^(0)),"^") ;vfah
 | 
|---|
| 99 |  I PSCT=0 W !!,"There are no CPRS Ordering Institutions associated with this Outpatient site!",!,"Use the Site Parameter enter/edit option to enter CPRS Ordering Institutions!",! S PSOIQUIT=1 Q
 | 
|---|
| 100 |  I PSCT=1 Q
 | 
|---|
| 101 |  W !!!,"There are multiple Institutions associated with this Outpatient Site for",!,"finishing orders entered through CPRS. Select the Institution for which to",!,"finish orders from.  Enter '?' to see all choices.",!
 | 
|---|
| 102 |  K PSOPNAME D:$G(PSOPINST)  K DIC S DIC(0)="AEQMZ",DIC="^PS(59,"_PSOSITE_",""INI1""," S:$G(PSOPNAME)'="" DIC("B")=$G(PSOPNAME) D ^DIC K DIC,PSOPNAME I Y<1 W !!,"No Institution selected",! S PSOIQUIT=1 Q
 | 
|---|
| 103 |  .K ^UTILITY("DIQ1",$J),DIQ S DA=$G(PSOPINST),DIC=4,DIQ(0)="E",DR=".01" D EN^DIQ1 S PSOPNAME=$G(^UTILITY("DIQ1",$J,4,DA,.01,"E")) K ^UTILITY("DIQ1",$J),DA,DR,DIC,DIQ
 | 
|---|
| 104 |  W ! S PSOPINST=$P(Y,"^",2) K Y
 | 
|---|
| 105 |  D INSTNM W !,"You have selected "_$G(PSODINST)_".",!,"After completing these orders, you may re-enter this option and select again.",! K PSODINST
 | 
|---|
| 106 |  Q
 | 
|---|
| 107 | INST1 ;
 | 
|---|
| 108 |  K PSOPINST N PSIR
 | 
|---|
| 109 |  F PSIR=0:0 S PSIR=$O(^PS(59,PSOSITE,"INI1",PSIR)) Q:'PSIR!($G(PSOPINST))  I $P($G(^PS(59,PSOSITE,"INI1",PSIR,0)),"^") S PSOPINST=$P($G(^(0)),"^")
 | 
|---|
| 110 |  Q
 | 
|---|
| 111 | CLOZ ;
 | 
|---|
| 112 |  S CLOZPAT=$O(^YSCL(603.01,"C",PSODFN,0))
 | 
|---|
| 113 |  S CLOZPAT=$P($G(^YSCL(603.01,+CLOZPAT,0)),"^",3)
 | 
|---|
| 114 |  S CLOZPAT=$S(CLOZPAT="M":2,CLOZPAT="B":1,1:0)
 | 
|---|
| 115 |  S:'$D(PSONEW("# OF REFILLS")) (PSONEW("# OF REFILLS"),PSONEW("N# REF"))=0
 | 
|---|
| 116 |  Q
 | 
|---|
| 117 | ELIG I $G(CLOZPAT)=1 S IEN=IEN+1,^TMP("PSOPO",$J,IEN,0)="   Patient Eligible for 14 Day Supply or 7 Day Supply with 1 refill"
 | 
|---|
| 118 |  I $G(CLOZPAT)=2 S IEN=IEN+1,^TMP("PSOPO",$J,IEN,0)="   Patient Eligible for 28 Day Supply or 14 Day Supply with 1 refill or 7 Day Supply with 3 refill"
 | 
|---|
| 119 |  Q
 | 
|---|
| 120 | USER(USER) ;
 | 
|---|
| 121 |  K DIC,X,Y S DIC="^VA(200,",DIC(0)="M",X="`"_USER D ^DIC S USER1=$S(+Y:$P(Y,"^",2),1:"Unknown") K DIC,X,Y
 | 
|---|
| 122 |  Q
 | 
|---|
| 123 | INSTNM ;
 | 
|---|
| 124 |  K PSOFINDA,PSODINST I $G(DA) S PSOFINDA=$G(DA)
 | 
|---|
| 125 |  K PSODNM S DA=$G(PSOPINST) I DA S DIC=4,DIQ(0)="E",DR=".01",DIQ="PSODNM" D EN^DIQ1 S PSODINST=$G(PSODNM(4,DA,.01,"E")) K PSODNM,DIC,DR,DA
 | 
|---|
| 126 |  I $G(PSOFINDA) S DA=$G(PSOFINDA) K PSOFINDA
 | 
|---|
| 127 |  Q
 | 
|---|
| 128 | POST S PSOFINY=$G(Y) D ^PSOBUILD S Y=$G(PSOFINY) K PSOFINY D OERR^PSORX1 I $G(PSOQUIT) Q
 | 
|---|
| 129 |  K PSOQFLG F PT="GET","DEAD","INP","CNH","TPB","ADDRESS","COPAY" S RTN=PT_"^PSOPTPST" D @RTN K PSOXFLG Q:$G(POERR("DEAD"))!($G(PSOQFLG))
 | 
|---|
| 130 |  I $G(POERR("DEAD")) S POERR("QFLG")=1 Q
 | 
|---|
| 131 |  K PSOERR("DEAD") I $G(PSOQFLG) Q
 | 
|---|
| 132 |  D ^PSOORUT2,BLD^PSOORUT1,EN^PSOLMUTL
 | 
|---|
| 133 |  Q
 | 
|---|
| 134 | SIG ;
 | 
|---|
| 135 |  S SIG=0,PSOFINFL=1 F  S SIG=$O(^PS(52.41,ORD,"SIG",SIG)) Q:'SIG  D
 | 
|---|
| 136 |  .S (MIG,SIG(SIG))=^PS(52.41,ORD,"SIG",SIG,0)
 | 
|---|
| 137 |  .F SG=1:1:$L(MIG," ") S:$L(^TMP("PSOPO",$J,IEN,0)_" "_$P(MIG," ",SG))>80 IEN=IEN+1,$P(^TMP("PSOPO",$J,IEN,0)," ",20)=" " S ^TMP("PSOPO",$J,IEN,0)=$G(^TMP("PSOPO",$J,IEN,0))_" "_$P(MIG," ",SG) D
 | 
|---|
| 138 |  ..I $E(^TMP("PSOPO",$J,IEN,0),$L(^TMP("PSOPO",$J,IEN,0)))=" " S ^TMP("PSOPO",$J,IEN,0)=$E(^TMP("PSOPO",$J,IEN,0),1,($L(^TMP("PSOPO",$J,IEN,0))-1))
 | 
|---|
| 139 |  S:$O(SIG(0)) SIGOK=1 K MIG
 | 
|---|
| 140 |  F D=0:0 S D=$O(^PS(52.41,ORD,"INS1",D)) Q:'D  S PSONEW("INS",D)=^PS(52.41,ORD,"INS1",D,0)
 | 
|---|
| 141 |  ;I PSONEW("INS")]"" S X=PSONEW("INS") D SIG^PSOHELP I $G(INS1)]"" S PSONEW("SIG")=$E(INS1,2,9999999)
 | 
|---|
| 142 |  Q
 | 
|---|