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

PSON52.m

Go to the documentation of this file.
  1. PSON52 ;BIR/DSD - files new entries in prescription file ;Jan 20, 2022@11:18:18
  1. ;;7.0;OUTPATIENT PHARMACY;**1,16,23,27,32,46,71,111,124,117,131,139,157,143,219,148,239,201,268,260,225,303,358,251,387,379,390,391,313,408,473,504,505,517,457,617,562,441,746,753,769**;DEC 1997;Build 26
  1. ;External reference ^PS(55 supported by DBIA 2228
  1. ;External reference to PSOUL^PSSLOCK supported by DBIA 2789
  1. ;External reference to ^XUSEC supported by DBIA 10076
  1. ;External reference SWSTAT^IBBAPI supported by DBIA 4663
  1. ;External reference SAVNDC^PSSNDCUT supported by DBIA 4707
  1. ;External reference to $$DS^PSSDSAPI supported by DBIA 5425
  1. EN(PSOX) ;Entry Point
  1. START ;
  1. D:$D(XRTL) T0^%ZOSV ; Start RT Monitor
  1. D INIT G:PSON52("QFLG") END D NFILE Q:$G(PSONEW("DFLG"))
  1. D PS55,DIK
  1. S:$D(XRT0) XRTN=$T(+0) D:$D(XRT0) T1^%ZOSV ; Stop RT Monitor
  1. D FINISH
  1. ; If parked, set PARK level, APARK xref, activity log, and remove from label queue and suspense 441 PAPI
  1. I $G(PSOX("MAIL/WINDOW"))="P" D PARK^PSOPRKA(PSOX("IRXN")),RMP^PSOPRKA(PSOX("IRXN"))
  1. I $P(^PSRX(PSOX("IRXN"),0),"^",11)="W",$G(^("IB")) S ^PSRX("ACP",$P(^PSRX(PSOX("IRXN"),0),"^",2),$P(^(2),"^",2),0,PSOX("IRXN"))=""
  1. END D EOJ
  1. Q
  1. INIT ;
  1. K X,%DT S:$G(PSOID) PSOX("ISSUE DATE")=PSOID
  1. S PSOX("CS")=0 K PSOX("NOPSDRPH")
  1. F DEA=1:1 Q:$E(PSODRUG("DEA"),DEA)="" I $E(+PSODRUG("DEA"),DEA)>1,$E(+PSODRUG("DEA"),DEA)<6 S $P(PSOX("CS"),"^")=1 S:$E(+PSODRUG("DEA"),DEA)=2 $P(PSOX("CS"),"^",2)=1
  1. I $P($G(PSOX("CS")),"^"),'$D(^XUSEC("PSDRPH",DUZ)) S PSOX("NOPSDRPH")=1
  1. S PSON52("QFLG")=0,X1=PSOX("ISSUE DATE"),X2=PSOX("DAYS SUPPLY")*(PSOX("# OF REFILLS")+1)\1
  1. I $D(CLOZPAT) S X2=$S(X2=14:14,X2=7:7,1:X2) G DT
  1. S X2=$S(PSOX("DAYS SUPPLY")=X2:X2,+$G(PSOX("CS")):184,+$G(DEA("CS")):184,1:366)
  1. I X2<30 D
  1. . N % S %=$P($G(PSORX("PATIENT STATUS")),"^"),X2=30
  1. . S:%?.N %=$P($G(^PS(53,+%,0)),"^") I %["AUTH ABS" S X2=5
  1. DT D C^%DTC S PSOX("STOP DATE")=$P(X,".") K X
  1. ;*473 - If Calculated Exp. Date < Fill Date with No refills, reset Exp.
  1. I '$D(CLOZPAT),'PSOX("# OF REFILLS"),PSOX("FILL DATE")>PSOX("STOP DATE") D
  1. . N EXP S EXP=$$FMADD^XLFDT(PSOX("FILL DATE"),PSOX("DAYS SUPPLY"))
  1. . I $$FMDIFF^XLFDT(EXP,PSOX("ISSUE DATE"))>$S(+$G(PSOX("CS")):184,1:366) D
  1. . . S EXP=$$FMADD^XLFDT(PSOX("ISSUE DATE"),$S(+$G(PSOX("CS")):184,1:366))
  1. . I EXP<PSOX("FILL DATE") S EXP=PSOX("FILL DATE")
  1. . S PSOX("STOP DATE")=EXP
  1. ; Titration to Maintenance Rx Conversion - Set Maint. Rx Exp. Date = Original Rx Exp. Date
  1. I $G(PSOTITRX) D
  1. . S PSOX("STOP DATE")=$$GET1^DIQ(52,PSOTITRX,26,"I")
  1. I PSOX("# OF REFILLS")>0 S X1=PSOX("FILL DATE"),X2=$S((PSOX("DAYS SUPPLY")-10\1)<1:1,1:PSOX("DAYS SUPPLY")-10\1) D C^%DTC S PSOX("NEXT POSSIBLE REFILL")=$P(X,".") K X
  1. S PSOX("TYPE OF RX")=0,PSOX("DISPENSED DATE")=PSOX("FILL DATE") D NOW^%DTC S PSOX("LOGIN DATE")=$S($P($G(OR0),"^",12):$P($G(OR0),"^",12),1:%) K %,X
  1. S PSOX("STATUS")=$S($G(PSOX("STATUS"))]"":PSOX("STATUS"),$D(PSORX("VERIFY")):1,$D(PSOX("NOPSDRPH")):1,1:0)
  1. S PSOX("COPIES")=$S($G(PSOX("COPIES"))]"":PSOX("COPIES"),1:1)
  1. I $G(PSORX("PHARM"))]"" S PSOX("PHARMACIST")=PSORX("PHARM") K PSORX("PHARM")
  1. INITX Q
  1. ;
  1. NFILE I $G(OR0) D Q:$G(PSONEW("DFLG"))
  1. .D NOOR^PSONEW Q:$G(PSONEW("DFLG"))
  1. .I $G(PSOSIGFL)!($G(PSODRUG("OI"))'=$P(OR0,"^",8)) S PSONEW("CLERK CODE")=DUZ,PSONEW("REMARKS")=$G(PSONEW("REMARKS"))_" CPRS Order #"_$P(OR0,"^")_" Edited."
  1. S DIC="^PSRX(",DLAYGO=52,DIC(0)="L",X=PSOX("RX #") K DD,DO D FILE^DICN S PSOX("IRXN")=+Y K DLAYGO,X,Y,DIC,DD,DO
  1. I '$D(^XUSEC("PSORPH",DUZ))!($D(PSOX("NOPSDRPH"))),$$DS^PSSDSAPI&(+$G(^TMP("PSODOSF",$J,0))) S PSON52(PSOX("IRXN"),"STA")=1,PSOX("STATUS")=1
  1. F PSOX1=0:1 S PSON52=$P($T(DD+PSOX1),";;",2,4) Q:PSON52="" K PSOY S PSOY=$P(PSON52,";;") I $G(@PSOY)]"" S $P(PSON52(PSOX("IRXN"),$P(PSON52,";;",2)),"^",$P(PSON52,";;",3))=@PSOY
  1. F I=1:1:PSOX("ENT") S ^PSRX(PSOX("IRXN"),6,I,0)=PSOX("DOSE",I)_"^"_$G(PSOX("DOSE ORDERED",I))_"^"_$G(PSOX("UNITS",I))_"^"_$G(PSOX("NOUN",I))_"^" D
  1. .S ^PSRX(PSOX("IRXN"),6,I,0)=^PSRX(PSOX("IRXN"),6,I,0)_$G(PSOX("DURATION",I))_"^"_$G(PSOX("CONJUNCTION",I))_"^"_$G(PSOX("ROUTE",I))_"^"_$G(PSOX("SCHEDULE",I))_"^"_$G(PSOX("VERB",I))
  1. .I $G(PSOX("ODOSE",I))]"" S ^PSRX(PSOX("IRXN"),6,I,1)=PSOX("ODOSE",I)
  1. S ^PSRX(PSOX("IRXN"),6,0)="^52.0113^"_PSOX("ENT")_"^"_PSOX("ENT")
  1. ;*441-IND
  1. I $G(PSOX("IND"))]"" S ^PSRX(PSOX("IRXN"),"IND")=PSOX("IND")_$S($G(PSOX("INDF")):"^"_PSOX("INDF"),1:"") S:$G(PSOX("INDO"))]"" $P(^PSRX(PSOX("IRXN"),"IND"),"^",3)=PSOX("INDO")
  1. K PSOX1,PSOY
  1. S PSOX1="" F S PSOX1=$O(PSON52(PSOX("IRXN"),PSOX1)) Q:PSOX1="" S ^PSRX(PSOX("IRXN"),PSOX1)=$G(PSON52(PSOX("IRXN"),PSOX1))
  1. ; PSO*7*505 - quantity check - leading zeros
  1. N QTYTMP
  1. S QTYTMP=$P(^PSRX(PSOX("IRXN"),0),U,7)
  1. I QTYTMP["." D
  1. .Q:$P(QTYTMP,".")'=""
  1. .;Q:$P(QTYTMP,".")=0
  1. .S $P(^PSRX(PSOX("IRXN"),0),U,7)=0_QTYTMP
  1. ; PSO*7*505 - end quantity check - leading zeros
  1. I $O(PSOX("SIG",0)) D
  1. .S D=0 F S D=$O(PSOX("SIG",D)) Q:'D S ^PSRX(PSOX("IRXN"),"INS1",D,0)=PSOX("SIG",D),TP=$G(TP)+1
  1. .S ^PSRX(PSOX("IRXN"),"INS1",0)="^52.0115^"_TP_"^"_TP_"^"_DT_"^^" K TP,D
  1. I $G(PSOX("SINS"))]"" S ^PSRX(PSOX("IRXN"),"INSS")=PSOX("SINS")
  1. I $G(SIGOK) D
  1. .S $P(^PSRX(PSOX("IRXN"),"SIG"),"^",2)=1,^PSRX(PSOX("IRXN"),"SIG1",0)="^52.04A^^"
  1. .S D=0 F S D=$O(SIG(D)) Q:'D S ^PSRX(PSOX("IRXN"),"SIG1",D,0)=SIG(D),$P(^PSRX(PSOX("IRXN"),"SIG1",0),"^",3)=+$P(^PSRX(PSOX("IRXN"),"SIG1",0),"^",3)+1,$P(^(0),"^",4)=+$P(^(0),"^",4)+1 Q:'$O(SIG(D))
  1. .K SIG
  1. I $D(PSOINSFL) S ^PSRX(PSOX("IRXN"),"A",0)="^52.3DA^1^1",^PSRX(PSOX("IRXN"),"A",1,0)=DT_"^G^^0^Patient Instructions "_$S(PSOINSFL=1:"",1:"Not ")_"Sent By Provider."
  1. I $G(PSOTITRF) D ;PSO*441 - marked in CPRS
  1. .S $P(^PSRX(PSOX("IRXN"),"TIT"),"^",3)=1,COMM="MARKED as Titration"
  1. .D RXACT^PSOBPSU2(PSOX("IRXN"),,COMM,"K",PSONEW("CLERK CODE"))
  1. I $G(OR0) D
  1. . ; Allow CS from eRX to proceed without OR0|24 being set
  1. . N ERXIEN,PSCSERX S ERXIEN=$$ERXIEN^PSOERXUT($G(ORD)_"P"),PSCSERX=0
  1. . I ERXIEN,$$GET1^DIQ(52.49,ERXIEN,95.1,"I"),$$CS^PSOERXA0(+$$GET1^DIQ(52.49,ERXIEN,3.2,"I")) S PSCSERX=1
  1. . ;Allow processing to continue if ERX order and is a CS without $P(OR0,"^",24)
  1. . I $P(OR0,"^",24)!PSCSERX S $P(^PSRX(PSOX("IRXN"),"PKI"),"^",1,3)=$S($G(PSOSIGFL):"^1^",1:"1^^") D ACLOG
  1. . N ORDIEN S ORDIEN=$O(^PS(52.41,"B",$P(OR0,"^"),0))
  1. . I $P($G(PSOX("CS")),"^"),ORDIEN,$$ERXIEN^PSOERXUT(ORDIEN_"P"),$$GET1^DIQ(52.49,$$ERXIEN^PSOERXUT(ORDIEN_"P"),95.1,"I") D
  1. . . S $P(^PSRX(PSOX("IRXN"),"PKI"),"^",1,3)="^^1"
  1. I $P($G(PSOX("CS")),"^"),'+$P($G(^PSRX(PSOX("IRXN"),"PKI")),"^"),'+$P($G(^PSRX(PSOX("IRXN"),"PKI")),"^",3) D
  1. . S $P(^PSRX(PSOX("IRXN"),"PKI"),"^",2)=1
  1. K PSOX1,PSOFINFL,HLDSIG,D,PSOINSFL,D
  1. D:$G(^TMP("PSODAI",$J,0))
  1. .S $P(^PSRX(PSOX("IRXN"),3),"^",6)=1
  1. .I $O(^TMP("PSODAI",$J,0)) S DAI=0 F S DAI=$O(^TMP("PSODAI",$J,DAI)) Q:'DAI D
  1. ..S:'$D(^PSRX(PSOX("IRXN"),"DAI",0)) ^PSRX(PSOX("IRXN"),"DAI",0)="^52.03^^" S ^PSRX(PSOX("IRXN"),"DAI",DAI,0)=^TMP("PSODAI",$J,DAI,0)
  1. ..S $P(^PSRX(PSOX("IRXN"),"DAI",0),"^",3)=+$P(^PSRX(PSOX("IRXN"),"DAI",0),"^",3)+1,$P(^(0),"^",4)=+$P(^(0),"^",4)+1
  1. .K ^TMP("PSODAI",$J),DAI
  1. I $G(PSOX("CHCS NUMBER"))'="" S $P(^PSRX(PSOX("IRXN"),"EXT"),"^")=$G(PSOX("CHCS NUMBER"))
  1. I $G(PSOX("EXTERNAL SYSTEM"))'="" S $P(^PSRX(PSOX("IRXN"),"EXT"),"^",2)=$G(PSOX("EXTERNAL SYSTEM"))
  1. I $G(PSOX("NEWCOPAY")) S ^PSRX(PSOX("IRXN"),"IB")=$G(PSOX("NEWCOPAY"))
  1. ;Next line, set SC question based on Copay status?
  1. IBQ ;I $G(PSOBILL)=2 S ^PSRX(PSOX("IRXN"),"IBQ")=$S($G(PSOX("NEWCOPAY")):0,1:1)
  1. N PSOSCFLD S PSOSCFLD=$S(PSOSCP'="":$G(PSOANSQ("SC")),1:"")_"^"_$G(PSOANSQ("MST"))_"^"_$G(PSOANSQ("VEH"))_"^"_$G(PSOANSQ("RAD"))_"^"_$G(PSOANSQ("PGW"))_"^"_$G(PSOANSQ("HNC"))_"^"_$G(PSOANSQ("CV"))_"^"_$G(PSOANSQ("SHAD"))
  1. I PSOSCP<50&($TR(PSOSCFLD,"^")'="")&($P($G(^PS(53,+$G(PSONEW("PATIENT STATUS")),0)),"^",7)'=1) D
  1. . S ^PSRX(PSOX("IRXN"),"IBQ")=PSOSCFLD K PSOSCFLD ;don't set if SC % is null or 0, just set it in ICD node
  1. D ICD^PSODIAG
  1. D:$$SWSTAT^IBBAPI() GACT^PSOPFSU0(PSOX("IRXN"),0)
  1. D:$G(PSOTITRX) SAVETIT(PSOTITRX,PSOX("IRXN"))
  1. K PSOTITRX,PSOANSQ,PSOANSQD,PSOX("NEWCOPAY")
  1. L -^PSRX("B",PSOX("IRXN"))
  1. Q
  1. ;
  1. ACLOG ;activity log (digitally signed CS orders)
  1. N DTTM,CNT,OCNT,XX
  1. D NOW^%DTC S DTTM=%
  1. S CNT=0 F XX=0:0 S XX=$O(^PSRX(PSOX("IRXN"),"A",XX)) Q:'XX S CNT=XX
  1. S OCNT=CNT
  1. I $G(PSOCSP("NAME"))'=PSODRUG("NAME") S CNT=CNT+1,^PSRX(PSOX("IRXN"),"A",CNT,0)=DTTM_"^K^"_DUZ_"^0^NAME: "_PSOCSP("NAME")
  1. S XX=0 F S XX=$O(PSOCSP("DOSE",XX)) Q:'XX I PSOCSP("DOSE",XX)'=$G(PSONEW("DOSE",XX)) D
  1. .S CNT=CNT+1,^PSRX(PSOX("IRXN"),"A",CNT,0)=DTTM_"^K^"_DUZ_"^0^DOSAGE: "_PSOCSP("DOSE",XX)
  1. S XX=0 F S XX=$O(PSOCSP("DOSE ORDERED",XX)) Q:'XX I PSOCSP("DOSE ORDERED",XX)'=$G(PSONEW("DOSE ORDERED",XX)) D
  1. .S CNT=CNT+1,^PSRX(PSOX("IRXN"),"A",CNT,0)=DTTM_"^K^"_DUZ_"^0^DISPENSE UNITS: "_PSOCSP("DOSE ORDERED",XX)
  1. I PSOCSP("ISSUE DATE")'=PSONEW("ISSUE DATE") S CNT=CNT+1,^PSRX(PSOX("IRXN"),"A",CNT,0)=DTTM_"^K^"_DUZ_"^0^ISSUE DATE: "_$$FMTE^XLFDT(PSOCSP("ISSUE DATE"))
  1. I PSOCSP("DAYS SUPPLY")'=PSONEW("DAYS SUPPLY") S CNT=CNT+1,^PSRX(PSOX("IRXN"),"A",CNT,0)=DTTM_"^K^"_DUZ_"^0^DAYS SUPPLY: "_PSOCSP("DAYS SUPPLY")
  1. I PSOCSP("QTY")'=PSONEW("QTY") S CNT=CNT+1,^PSRX(PSOX("IRXN"),"A",CNT,0)=DTTM_"^K^"_DUZ_"^0^QTY: "_PSOCSP("QTY")
  1. I PSOCSP("# OF REFILLS")'=PSONEW("# OF REFILLS") S CNT=CNT+1,^PSRX(PSOX("IRXN"),"A",CNT,0)=DTTM_"^K^"_DUZ_"^0^# OF REFILLS: "_PSOCSP("# OF REFILLS")
  1. I '$$SUBSCRIB^ORDEA($P(OR0,"^"),PSOX("IRXN")) S CNT=CNT+1,^PSRX(PSOX("IRXN"),"A",CNT,0)=DTTM_"^K^"_DUZ_"^0^ORDER DEA ARCHIVE INFO file entry failure"
  1. I OCNT'=CNT S ^PSRX(PSOX("IRXN"),"A",0)="^52.3DA^"_CNT_"^"_CNT
  1. Q
  1. ;
  1. PS55 ;
  1. L +^PS(55,PSODFN,"P"):$S(+$G(^DD("DILOCKTM"))>0:+^DD("DILOCKTM"),1:3)
  1. S:'$D(^PS(55,PSODFN,"P",0)) ^(0)="^55.03PA^^"
  1. F PSOX1=$P(^PS(55,PSODFN,"P",0),"^",3):1 Q:'$D(^PS(55,PSODFN,"P",PSOX1))
  1. S PSOX("55 IEN")=PSOX1
  1. S ^PS(55,PSODFN,"P",PSOX1,0)=PSOX("IRXN"),$P(^PS(55,PSODFN,"P",0),"^",3,4)=PSOX1_"^"_($P(^PS(55,PSODFN,"P",0),"^",4)+1)
  1. S ^PS(55,PSODFN,"P","A",PSONEW("STOP DATE"),PSOX("IRXN"))=""
  1. PS55X L -^PS(55,PSODFN,"P")
  1. K PSOX1
  1. Q
  1. DIK ;
  1. I $D(^XUSEC("PSORPH",DUZ)) S DA=PSOX("IRXN"),DIE=52,DR="41////"_PSOCOU_";S:'X Y=""@1"";42////"_PSOCOUU_";@1" D ^DIE K DIE,DR
  1. I $D(^XUSEC("PSORPH",DUZ)) S DA=PSOX("IRXN"),DIE=52,DR="100.2////"_PSOMAILX D ^DIE K DIE,DR ;p753
  1. K DIK,DA S DIK="^PSRX(",DA=PSOX("IRXN") D IX1^DIK K DIK
  1. S DA=PSOX("IRXN") D ORC^PSORN52C
  1. Q
  1. FINISH ;
  1. ANQ I $G(ANQDATA)]"" D NOW^%DTC H 1 G:$D(^PS(52.52,"B",%)) ANQ D
  1. .K DD,DO S DIC="^PS(52.52,",DIC(0)="L",DLAYGO=52.52,X=% D FILE^DICN K DIC,DLAYGO,DD,DO
  1. .S ^PS(52.52,+Y,0)=$P(Y,"^",2)_"^"_PSOX("IRXN")_"^"_ANQDATA,^PS(52.52,"A",PSOX("IRXN"),+Y)="" K X,Y,%,ANQREM
  1. ;PSO 457 Added H 1 to line tag ANQ
  1. ; ** START NCC REMEDIATION ** 457/RTW RJS
  1. I $D(ANQDATA) D ;ADD ADDITIONAL LOGIC FOR ORDERING PROVIDER RJS/457
  1. .I $P($G(ANQDATA),"^",2)["UNKNOWN",$D(PSOX("PROVIDER")) S $P(ANQDATA,"^",2)=PSOX("PROVIDER")
  1. .I $D(PSOX("PROVIDER")),$P($G(ANQDATA),"^",2)'=PSOX("PROVIDER") S $P(ANQDATA,"^",2)=PSOX("PROVIDER")
  1. I $G(ANQDATA)]"" N PSOUSER,PSO1PH,PSO2PH,PSOREASN,PSOREMRK,DTM D NOW^%DTC S DTM=% G:$$FIND1^DIC(52.52,,"X",DTM) ANQ D
  1. .S PSOUSER=$P(ANQDATA,"^",2),PSO1PH=$P(ANQDATA,"^"),PSO2PH=$P(ANQDATA,"^",5)
  1. .S PSOREASN=$P(ANQDATA,"^",3),PSOREMRK=$P(ANQDATA,"^",4)
  1. .K DD,DO S DIC="^PS(52.52,",DIC(0)="L",DLAYGO=52.52,X=DTM
  1. .D FILE^DICN K DIC,DLAYGO,DD,DO,DA,DR
  1. .N PS52 S (PS52,DA)=+Y,DIE="^PS(52.52,",DR="1////^S X=PSOX(""IRXN"")"_";2////^S X=PSO1PH;3////^S X=PSOUSER;4////^S X=PSOREASN;5////^S X=PSOREMRK;6////^S X=PSO2PH"
  1. .D ^DIE K DIE,DA,DR
  1. .K X,Y,%,ANQREM
  1. .D ALERT^PSORENW0
  1. I $$GET1^DIQ(50,+$G(PSODRUG("IEN")),17.5)="PSOCLO1" D ^YSCLTST6
  1. ;/RBN END MODIFICATIONS FOR PSO*7.0*457
  1. ;
  1. N PSOTFIN
  1. I $D(PSOX("NOPSDRPH"))!('$D(^XUSEC("PSORPH",DUZ))) S PSOTFIN="",PSOTFIN=$$TECH2^PSODGDGP(PSOX("IRXN"),PSODFN,DUZ,.PSOX)
  1. I $D(PSOX("NOPSDRPH"))!('$D(^XUSEC("PSORPH",DUZ))) G FINISHP:$G(PSOTFIN)=1 G FINISHX:$G(PSOTFIN)=2
  1. ;
  1. I PSOX("FILL DATE")>DT,$P(PSOPAR,"^",6) S DA=PSOX("IRXN"),RXFL(PSOX("IRXN"))=0 D SUS^PSORXL K DA G FINISHX
  1. ;
  1. ; - Calling ECME for claims generation and transmission / REJECT handling
  1. N ACTION,PSOERX
  1. S PSOERX=PSOX("IRXN")
  1. I ($G(PSOX("MAIL/WINDOW"))'="P"),($$SUBMIT^PSOBPSUT(PSOERX,0)) D I ACTION="Q"!(ACTION="^") Q ;441 PAPI
  1. . S ACTION="" D ECMESND^PSOBPSU1(PSOERX,0,"","OF")
  1. . ; Quit if there is an unresolved Tricare/CHAMPVA non-billable reject code, PSO*7*358
  1. . I $$PSOET^PSOREJP3(PSOERX,0) S ACTION="Q" Q
  1. . I $$FIND^PSOREJUT(PSOERX,0) D
  1. . . S ACTION=$$HDLG^PSOREJU1(PSOERX,0,"79,88,943","OF","IOQ","Q")
  1. . I $$STATUS^PSOBPSUT(PSOERX,0)="E PAYABLE" D
  1. . . D SAVNDC^PSSNDCUT(+$$GET1^DIQ(52,PSOERX,6,"I"),$G(PSOSITE),$$GETNDC^PSONDCUT(PSOERX,0))
  1. ;
  1. FINISHP ;
  1. I $G(PSORX("PSOL",1))']"" S PSORX("PSOL",1)=PSOX("IRXN")_",",RXFL(PSOX("IRXN"))=0 G FINISHX
  1. F PSOX1=0:0 S PSOX1=$O(PSORX("PSOL",PSOX1)) Q:'PSOX1 S PSOX2=PSOX1
  1. I $L(PSORX("PSOL",PSOX2))+$L(PSOX("IRXN"))<220 S PSORX("PSOL",PSOX2)=PSORX("PSOL",PSOX2)_PSOX("IRXN")_","
  1. E S PSORX("PSOL",PSOX2+1)=PSOX("IRXN")_","
  1. S RXFL(PSOX("IRXN"))=0
  1. FINISHX ;call to build Rx array for bingo board
  1. I $G(PSORX("MAIL/WINDOW"))["W" S BINGCRT=1,BINGRTE="W",BBFLG=1 D BBRX^PSORN52C
  1. K PSOX1,PSOX2
  1. K ^TMP("PSODGI",$J),^TMP("PSOSER",$J),^TMP("PSOSERS",$J),^TMP("PSODGS",$J),^TMP("PSOTDD",$J),^TMP("PSODOSF",$J)
  1. Q
  1. ;
  1. SAVETIT(TITRX,MNTRX) ; Save Titration/Maintenance dose Rx information
  1. I '$D(^PSRX(+$G(TITRX),0))!'$D(^PSRX(+$G(MNTRX),0)) Q
  1. S $P(^PSRX(TITRX,"TIT"),"^",2,3)=MNTRX_"^1"
  1. D RXACT^PSOBPSU2(TITRX,0,"Maintenance Rx#: "_$$GET1^DIQ(52,MNTRX,.01),"E")
  1. S $P(^PSRX(MNTRX,"TIT"),"^",1)=TITRX
  1. D RXACT^PSOBPSU2(MNTRX,0,"Titration Rx#: "_$$GET1^DIQ(52,TITRX,.01),"E")
  1. Q
  1. ;
  1. EOJ ;
  1. ;B xref locked in routine PSONRXN
  1. L -^PSRX("B",PSOX("IRXN")) K OTHDOS,DA,PSON52,PSOPRC,RTE,SCH,PSOX("INS"),PSONEW("INS"),PSORXED("INS"),PSONEW("ENT"),PSORXED("ENT"),OLENT
  1. D PSOUL^PSSLOCK(PSOX("IRXN"))
  1. Q
  1. ;
  1. ;;PSOX("SIG");;SIG;;1
  1. DD ;;PSOX("RX #");;0;;1
  1. ;;PSOX("ISSUE DATE");;0;;13
  1. ;;PSODFN;;0;;2
  1. ;;PSOX("PATIENT STATUS");;0;;3
  1. ;;PSOX("PROVIDER");;0;;4
  1. ;;PSOX("CLINIC");;0;;5
  1. ;;PSODRUG("IEN");;0;;6
  1. ;;PSODRUG("TRADE NAME");;TN;;1
  1. ;;PSOX("QTY");;0;;7
  1. ;;PSOX("DAYS SUPPLY");;0;;8
  1. ;;PSOX("# OF REFILLS");;0;;9
  1. ;;PSOX("COPIES");;0;;18
  1. ;;PSOX("MAIL/WINDOW");;0;;11
  1. ;;PSOX("REMARKS");;3;;7
  1. ;;PSOX("ADMINCLINIC");;0;;15
  1. ;;PSOX("CLERK CODE");;0;;16
  1. ;;PSODRUG("COST");;0;;17
  1. ;;PSOSITE;;2;;9
  1. ;;PSOX("LOGIN DATE");;2;;1
  1. ;;PSOX("FILL DATE");;2;;2
  1. ;;PSOX("PHARMACIST");;2;;3
  1. ;;PSOX("LOT #");;2;;4
  1. ;;PSOX("DISPENSED DATE");;2;;5
  1. ;;PSOX("STOP DATE");;2;;6
  1. ;;PSODRUG("NDC");;2;;7
  1. ;;PSODRUG("DAW");;EPH;;1
  1. ;;PSODRUG("MANUFACTURER");;2;;8
  1. ;;PSOX("EXPIRATION DATE");;2;;11
  1. ;;PSOX("GENERIC PROVIDER");;2;;12
  1. ;;PSOX("RELEASED DATE/TIME");;2;;13
  1. ;;PSOX("METHOD OF PICK-UP");;MP;;1
  1. ;;PSOX("STATUS");;STA;;1
  1. ;;PSOX("LAST DISPENSED DATE");;3;;1
  1. ;;PSOX("NEXT POSSIBLE REFILL");;3;;2
  1. ;;PSOX("COSIGNING PROVIDER");;3;;3
  1. ;;PSOX("TYPE OF RX");;TYPE;;1
  1. ;;PSOX("SAND");;SAND;;1
  1. ;;PSOX("POE");;POE;;1
  1. ;;PSOX("INS");;INS;;1
  1. ;;PSOX("IND");;IND;;1
  1. ;;PSOX("INDF");;IND;;2
  1. ;;PSOX("INDO");;IND;;3
  1. ;;PSOX("MAIL EXEMPTION");;7;;2