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

PSOORNE1.m

Go to the documentation of this file.
  1. PSOORNE1 ;BIR/SAB - Display new orders from backdoor ;Jun 09, 2021@15:24:21
  1. ;;7.0;OUTPATIENT PHARMACY;**11,21,27,32,37,46,71,94,104,117,133,148,279,251,372,313,422,441**;DEC 1997;Build 208
  1. ;External reference to ^PS(55 is supported by DBIA 2228
  1. EN(PSONEW) D DSPL^PSOORNE3,^PSOLMPO2
  1. Q
  1. EDT N FLD,FIELDLST K DIR,DUOUT,DIRUT S DIR("A")="Select Field to Edit by number",DIR(0)="LO^1:14" D ^DIR I $D(DTOUT)!($D(DUOUT)) K DIR,DIRUT,DTOUT,DTOUT S VALMBCK="" Q
  1. EDTSEL S:'$G(COPY) PSOEDIT=1 S (PSONEW("DFLG"),PSONEW("FIELD"),PSONEW3)=0
  1. I +Y S FIELDLST=Y D HLDHDR^PSOLMUTL D Q:$G(PSORX("DFLG"))!($G(PSORX("QFLG"))) S VALMBCK="R" G DSPL^PSOORNE3
  1. .F FLD=1:1:$L(FIELDLST,",") Q:$P(FIELDLST,",",FLD)']"" D @(+$P(FIELDLST,",",FLD)) Q:$G(PSODIR("DFLG"))!($G(PSODIR("QFLG")))
  1. E S VALMBCK="" D FULL^VALM1
  1. D RDSPL G DSPL^PSOORNE3
  1. Q
  1. ACP K VALMSG,DIR,PSORX("DFLG") D VER I $G(PSONEW2("QFLG"))!($G(PSORX("DFLG"))) S VALMBCK="Q" K PSONEW2 Q
  1. N PSONOBCK S PSONOBCK=$S($G(PSOSIGFL):1,1:0)
  1. D NOOR^PSONEW I $D(DIRUT) S PSONEW("DFLG")=1 K DIR,X,Y,DIRUT,DUOUT,DTOUT Q
  1. D RXNCHK,RDSPL
  1. I $G(PSONEW("QFLG")) S PSONEW("DFLG")=1 K DIR,X,Y,DIRUT,DUOUT,DTOUT Q
  1. D DISPLAY^PSONEW2
  1. D ^PSONEWG I $G(PSOCPZ("DFLG")) S PSONEW("DFLG")=1 K PSOANSQ,DIR,X,Y,DIRUT,DUOUT,DTOUT,PSOCPZ("DFLG"),PSOANSQD Q
  1. K PSOCPZ("DFLG")
  1. K DIR,DIRUT,X,Y S DIR(0)="Y",DIR("B")="YES",DIR("A")="Is this correct" D ^DIR
  1. I $D(DIRUT) S PSONEW("DFLG")=1 K PSOANSQ,PSOANSQD,DIR,X,Y,DIRUT,DUOUT,DTOUT Q
  1. I 'Y S VALMBCK="R" K PSOANSQ,DIR,X,Y,DIRUT,DUOUT,DTOUT D DSPL^PSOORNE3 Q
  1. W "..." K PSOANSQD,DIR,X,Y,DIRUT,DUOUT,DTOUT D DCORD^PSONEW2
  1. I $G(NCPDPFLG) D NCPDP^PSOORED6
  1. K:$G(COPY)!($G(PSOSIGFL)) PRC,PHI
  1. S:'$G(PSOID) PSOID=DT S (PSORX("FN"),PSONEW("POE"))=1 D EN^PSON52(.PSONEW) ; Files entry in File 52
  1. ;
  1. ; - Possible Titration prescription
  1. I $G(PSONEW("IRXN")) D MARK^PSOOTMRX(PSONEW("IRXN"),0)
  1. ;
  1. I $G(PSOBEDT) D
  1. .I '$D(^TMP("PSOBEDT",$J,PSODFN,0)) S ^TMP("PSOBEDT",$J,PSODFN,0)=PSORXED("IRXN") S:$G(PSONEW("MAIL/WINDOW"))["W" ^TMP("PSOBEDT",$J,PSODFN,1)=1 Q
  1. .S ^TMP("PSOBEDT",$J,PSODFN,0)=^TMP("PSOBEDT",$J,PSODFN,0)_","_PSORXED("IRXN")
  1. .I $G(PSONEW("MAIL/WINDOW"))["W" S ^TMP("PSOBEDT",$J,PSODFN,1)=1
  1. D NPSOSD^PSOUTIL(.PSONEW) ; Adds newly added rx to PSOSD array
  1. D ^PSOBUILD S VALMBCK="Q"
  1. K PSONEW("# OF REFILLS"),PSONEW("DAYS SUPPLY"),SDA,SEG1,SSN1,STA,Z4,ZDA
  1. Q:$G(COPY) S PSONEW("DFLG")=0
  1. Q
  1. VER I $G(PSOAC),$G(PSODRUG("NAME"))']"" D FULL^VALM1,2^PSOORNW1
  1. I $G(PSODRUG("NAME"))']"" S VALMSG="A Dispense Drug Must be Chosen!" S PSONEW2("QFLG")=1 Q
  1. I '$G(PSONEW("ENT")) W !,"Dosing Instruction Missing!!",! D I PSONEW("DFLG")=1 S PSONEW2("QFLG")=1 Q
  1. .S PSOORRNW=1
  1. .K VALMSG D FULL^VALM1 W !,"Drug: "_PSODRUG("NAME")
  1. .I $O(SIG(0)) F I=1:1 Q:$G(SIG(I))']"" W !,SIG(I)
  1. .E I $G(^PSRX(PSONEW("OIRXN"),"SIG"))]"" S X=$P(^PSRX(PSONEW("OIRXN"),"SIG"),"^") D SIGONE^PSOHELP W !,$E($G(INS1),2,250)
  1. .W ! D 5 K PSOORRNW I PSONEW("DFLG")=1 D M3 Q
  1. .D 6 D:PSONEW("DFLG")=1 M3
  1. D:$G(COPY) PROV^PSOUTIL(.PSORENW) I $G(PSONEW("DFLG"))=1 S PSONEW2("QFLG")=1 Q
  1. N PSODOSD D FULL^VALM1,POST^PSODRG:'$G(PSOSIGFL)
  1. I $G(POERR("DFLG"))=1 S (PSONEW("DFLG"),PSONEW2("QFLG"))=1 Q
  1. I $G(PSODOSD) S (PSONEW("DFLG"),PSONEW2("QFLG"))=1 Q
  1. D:'$G(PSORX("DFLG")) DOSCK^PSODOSUT("N") K PSONOOR I $G(PSORX("DFLG")) S VALMBCK="Q" Q
  1. I +$G(PSEXDT) D
  1. .D FULL^VALM1 S:$G(PSONEW("MAIL/WINDOW"))["W" BINGCRT="Y",BINGRTE="W"
  1. .D:+$G(PSEXDT)
  1. ..S Y=PSONEW("FILL DATE") X ^DD("DD") W !!,$C(7),Y_" fill date is greater than possible expiration date of " S Y=$P(PSEXDT,"^",2) X ^DD("DD") W Y_"."
  1. .S PSONEW2("QFLG")=1,VALMBCK="R" D PAUSE^VALM1
  1. Q
  1. 1 I $G(PSOSIGFL)!$G(PSOMTFLG) D Q
  1. . S PSOAC=1 D 2^PSOORNW1 D:'$G(PSORX("DFLG")) 10^PSOBKDED,MW K PSOAC Q:$G(PSORX("DFLG")) D RDSPL D DSPL^PSOORNE3
  1. . I $G(PSOMTFLG),$G(PSORXED("DRUG IEN"))'=$G(PSODRUG("IEN")) D
  1. . . I FIELDLST'["5," D 5 Q:$G(PSODIR("DFLG"))!($G(PSODIR("QFLG")))
  1. . . I FIELDLST'["6," D 6 Q:$G(PSODIR("DFLG"))!($G(PSODIR("QFLG")))
  1. . . I FIELDLST'["8," D 8 Q:$G(PSODIR("DFLG"))!($G(PSODIR("QFLG")))
  1. ;
  1. D 6^PSOBKDED,MW
  1. D RDSPL G DSPL^PSOORNE3 Q
  1. ;
  1. MW I PSONEW("MAIL/WINDOW")="P",$G(PSODRUG("DEA"))["D" D
  1. .W !!,"This drug cannot be Parked! You must select a different routing!"
  1. .D 12^PSOBKDED
  1. Q
  1. ;
  1. 2 D 3^PSOBKDED Q
  1. ;
  1. 3 D 1^PSOBKDED Q
  1. ;
  1. 4 D 2^PSOBKDED Q
  1. ;
  1. 5 I '$G(PSODRUG("IEN")) W !,"DRUG NAME REQUIRED!" D 2^PSOORNW1 I '$G(PSODRUG("IEN")) S VALMSG="No Dispense Drug Selected" Q
  1. W !!,"Drug: "_PSODRUG("NAME") D 10^PSOBKDED Q
  1. ;
  1. 6 ;D INS^PSOBKDED Q:$G(PSONEW("DFLG")) I $P($G(^PS(55,PSODFN,"LAN")),"^") D SINS^PSODIR(.PSONEW) ;*422
  1. N PSOINSCH,PSODELINS
  1. S:'$D(PSOOEINS) PSOOEINS=$G(PSONEW("INS")) S:'$D(PSOOSINS) PSOOSINS=$G(PSONEW("SINS")) S:'$D(PSOOEIND) PSOOEIND=$G(PSONEW("IND")) S:'$D(PSOOINDF) PSOOEINDF=$G(PSONEW("INDF"))
  1. I '$P($G(^PS(55,PSODFN,"LAN")),"^") D INS^PSOBKDED Q:$G(PSONEW("DFLG"))
  1. I $P($G(^PS(55,PSODFN,"LAN")),"^") D
  1. .N PSODONE S (PSODONE,PSODELINS)=0
  1. .F D I PSODONE Q:$G(PSONEW("DFLG")) D SIND^PSODIR(.PSONEW) Q
  1. ..K PSONEW("DFLG")
  1. ..D INS^PSOBKDED
  1. ..I '$G(PSONEW("DFLG")),'PSODONE,'$G(PSODELINS) D SINS^PSODIR(.PSONEW)
  1. ..;POSS NOT NEEDED;I $G(PSONEW("DFLG")) S PSODONE=1,(PSONEW("SIG"),PSONEW("INS"))=$G(PSOOEINS),PSONEW("SINS")=$G(PSOOSINS) K PSONEW("SIG") D EN^PSOFSIG(.PSONEW,1) Q
  1. ..I $G(PSONEW("DFLG")) S (X,Y)=$G(PSONEW("INS")) D SIG^PSOHELP S (PSONEW("SIG",1),PSONEW("SIG"))=$E($G(INS1),2,9999999) K X,Y S PSODONE=1 Q
  1. ..S PSOINSCH=$$INSCHK^PSOHELP3(.PSONEW)
  1. ..I '$G(PSOINSCH) S PSODONE=1
  1. ;
  1. K PSOOEINS,PSOOSINS,PSOOEIND,PSOOEINDF
  1. Q
  1. ;
  1. 7 D 8^PSOBKDED Q
  1. ;
  1. 8 D 7^PSOBKDED Q
  1. ;
  1. 9 D 9^PSOBKDED Q
  1. ;
  1. 10 D 12^PSOBKDED Q
  1. ;
  1. 11 D 5^PSOBKDED Q
  1. ;
  1. 12 D 4^PSOBKDED Q
  1. ;
  1. 13 D 11^PSOBKDED Q
  1. ;
  1. 14 D 13^PSOBKDED Q
  1. ;
  1. 15 Q
  1. ;D 14^PSOBKDED Q
  1. ;
  1. SUMM ;print break down of orders to be finished
  1. K ^TMP($J,"PSOCZT"),^TMP($J,"PSODPAT"),PAT,RT,DIR,DUOUT,DIRUT,PSZLQUIT
  1. S DIR("A")="Do you want an Order Summary",DIR(0)="Y",DIR("B")="No"
  1. D ^DIR K DIR I 'Y!($D(DIRUT)) K Y,X,DIRUT Q
  1. K PSOINPRT,DIQ,^UTILITY("DIQ1",$J) I $G(PSOPINST) S DA=PSOPINST,DIC=4,DIQ(0)="E",DR=".01" D EN^DIQ1 S PSOINPRT=$G(^UTILITY("DIQ1",$J,4,DA,.01,"E")) K ^UTILITY("DIQ1",$J),DA,DR,DIC,DIQ
  1. I $D(^PS(52.41,"ACL")) N PSOCLSUM D SUMMCL I $G(PSOCLSUM) K PSOINPRT Q
  1. F PSI=0:0 S PSI=$O(^PS(52.41,"AOR",PSI)) Q:'PSI F PSID=0:0 S PSID=$O(^PS(52.41,"AOR",PSI,PSID)) Q:'PSID F PIN=0:0 S PIN=$O(^PS(52.41,"AOR",PSI,PSID,PIN)) Q:'PIN D
  1. .I '$D(^TMP($J,"PSOCZT",PSID,"PAT")) F PZA="PAT","WIN","MAIL","CLIN","PARK" S ^TMP($J,"PSOCZT",PSID,PZA)=0 ;441 PAPI
  1. .I '$D(^TMP($J,"PSODPAT",PSID,PSI)) S ^TMP($J,"PSODPAT",PSID,PSI)=1,^TMP($J,"PSOCZT",PSID,"PAT")=^TMP($J,"PSOCZT",PSID,"PAT")+1
  1. .;441 PAPI
  1. .S PZROUT=$P($G(^PS(52.41,PIN,0)),"^",17) I PZROUT'="" S ^TMP($J,"PSOCZT",PSID,$S(PZROUT="C":"CLIN",PZROUT="M":"MAIL",PZROUT="P":"PARK",1:"WIN"))=^TMP($J,"PSOCZT",PSID,$S(PZROUT="C":"CLIN",PZROUT="M":"MAIL",PZROUT="P":"PARK",1:"WIN"))+1
  1. W @IOF W !?20,"Pending Outpatient Medication Orders",! I $G(PSZCNT)>1 W ?20,"(signed in under "_$G(PSOINPRT)_")",!
  1. F PSOINL=0:0 S PSOINL=$O(^TMP($J,"PSOCZT",PSOINL)) Q:'PSOINL!($G(PSZLQUIT)) D
  1. .I ($Y+6)>IOSL K DIR S DIR(0)="E" D ^DIR K DIR D:$G(Y) I '$G(Y) S PSZLQUIT=1 W ! Q
  1. ..W @IOF W !?20,"Pending Outpatient Medication Orders",! I $G(PSZCNT)>1 W ?20,"(signed in under "_$G(PSOINPRT)_")",!
  1. .K ^UTILITY("DIQ1",$J),DIQ,PSOINPRX S DA=$G(PSOINL),DIC=4,DIQ(0)="E",DR=".01" D EN^DIQ1 S PSOINPRX=$G(^UTILITY("DIQ1",$J,4,DA,.01,"E")) K ^UTILITY("DIQ1",$J),DA,DR,DIC,DIQ
  1. .;PSO*7*279 Change division to Institution
  1. .W !,"Institution: ",$G(PSOINPRX)
  1. .W !,"Patients: "_$G(^TMP($J,"PSOCZT",PSOINL,"PAT"))_" Window: "_$G(^("WIN"))_" Mail: "_$G(^("MAIL"))_" Clinic: "_$G(^("CLIN"))_" Park: "_$G(^("PARK")),! ;441 PAPI
  1. K DIR S DIR(0)="E",(DIR("A"),DIR("?"))="Press Return to Continue" D ^DIR K DIR
  1. K ^TMP($J,"PSOCZT"),^TMP($J,"PSODPAT"),RT,PSOINPRT,PSOINPRX,PSI,PSID,PIN,PZA,PZROUT,PSOINL,PSZLQUIT
  1. Q
  1. SUMMCL ;
  1. ;PSO*7*279 Change Division to Institution
  1. W ! K DIR S DIR(0)="SMB^I:INSTITUTION;C:CLINIC",DIR("A")="Do you want the summary by Institution or Clinic",DIR("B")="Institution",DIR("?")=" "
  1. S DIR("?",1)="Enter 'I' to see the summary by Institution, and within Institution the orders",DIR("?",2)="shown by Mail, Window, or Administered in Clinic.",DIR("?",3)="Enter 'C' to see the summary by Clinic, along with Clinic Sort Groups."
  1. D ^DIR K DIR I $D(DTOUT)!($D(DUOUT)) S PSOCLSUM=1 Q
  1. Q:$G(Y)="I"
  1. S PSOCLSUM=1
  1. K ^TMP($J,"PSOLOC"),^TMP($J,"PSOLOCP") N PSCX,PSCXL,PSLX,PSCIN,PSCPT,PSCNDE,PSNCL,PSNPAT,PSCLOUT,PSCSFLAG,PCCNT,PSOCAG
  1. F PSCX=0:0 S PSCX=$O(^PS(52.41,"ACL",PSCX)) Q:'PSCX F PSLX=0:0 S PSLX=$O(^PS(52.41,"ACL",PSCX,PSLX)) Q:'PSLX F PSCIN=0:0 S PSCIN=$O(^PS(52.41,"ACL",PSCX,PSLX,PSCIN)) Q:'PSCIN S PSCPT=+$P($G(^PS(52.41,PSCIN,0)),"^",2) D:PSCPT
  1. .S PSCNDE=$G(^PS(52.41,PSCIN,0))
  1. .I $P(PSCNDE,"^",3)'="NW",$P(PSCNDE,"^",3)'="RNW",$P(PSCNDE,"^",3)'="RF" Q
  1. .I $P(PSCNDE,"^",13)="" Q
  1. .S PSNCL=+$P(PSCNDE,"^",13),PSNPAT=+$P(PSCNDE,"^",2)
  1. .I '$D(^TMP($J,"PSOLOC",PSNCL)) S ^TMP($J,"PSOLOC",PSNCL)="1^1",^TMP($J,"PSOLOCP",PSNCL,PSNPAT)="" Q
  1. .S $P(^TMP($J,"PSOLOC",PSNCL),"^",2)=$P(^TMP($J,"PSOLOC",PSNCL),"^",2)+1
  1. .I '$D(^TMP($J,"PSOLOCP",PSNCL,PSNPAT)) S $P(^TMP($J,"PSOLOC",PSNCL),"^")=$P(^TMP($J,"PSOLOC",PSNCL),"^")+1
  1. .S ^TMP($J,"PSOLOCP",PSNCL,PSNPAT)=""
  1. I '$O(^TMP($J,"PSOLOC",0)) G SUMMQ
  1. W @IOF W !?20,"Pending Outpatient Medication Orders" I $G(PSZCNT)>1 W !?20,"(signed in under "_$G(PSOINPRT)_")"
  1. F PSCXL=0:0 S PSCXL=$O(^TMP($J,"PSOLOC",PSCXL)) Q:'PSCXL!($G(PSCLOUT)) D
  1. .I ($Y+7)>IOSL D CLDIR Q:$G(PSCLOUT)
  1. .W !!,"Clinic: ",$P($G(^SC(+PSCXL,0)),"^")
  1. .W !,"Patients: ",$P($G(^TMP($J,"PSOLOC",PSCXL)),"^"),?16,"Orders: ",$P($G(^TMP($J,"PSOLOC",PSCXL)),"^",2)
  1. .W !,"In Sort Groups:"
  1. .S (PCCNT,PSCSFLAG)=0 F PSCSORT=0:0 S PSCSORT=$O(^PS(59.8,PSCSORT)) Q:'PSCSORT!($G(PSCLOUT)) I $D(^PS(59.8,PSCSORT,1,"B",PSCXL)) S PSOCAG=0 D
  1. ..S PSCSFLAG=1 S:($Y+5)>IOSL&(PCCNT) PSOCAG=1 D:($Y+5)>IOSL&(PCCNT) CLDIR Q:$G(PSCLOUT) W:$G(PSOCAG) !,"Clinic: "_$P($G(^SC(PSCXL,0)),"^")_" cont." W:$G(PCCNT)>0 ! W ?16,$P($G(^PS(59.8,PSCSORT,0)),"^") S PCCNT=1
  1. .I '$G(PSCSFLAG) W ?16,"*** NO CLINIC SORT GROUPS ***"
  1. I '$G(PSCLOUT) K DIR S DIR(0)="E",(DIR("A"),DIR("?"))="Press Return to continue" D ^DIR K DIR
  1. SUMMQ K ^TMP($J,"PSOLOC"),^TMP($J,"PSOLOCP")
  1. Q
  1. CLDIR K DIR S DIR(0)="E",(DIR("A"),DIR("?"))="Press Return to continue, '^' to exit" D ^DIR K DIR I Y'=1 S PSCLOUT=1 Q
  1. W @IOF
  1. Q
  1. RXNCHK I $G(PSONEW("RX #"))']"" D RXNCHK^PSOORNE5
  1. Q
  1. RDSPL D RDSPL^PSOORNE5
  1. Q
  1. M3 D M3^PSOOREDX
  1. Q