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

PSOQMCAL.m

Go to the documentation of this file.
  1. PSOQMCAL ; SEA/HAM3 PMI - PHARMACY MEDICATION INSTRUCTION ; 30 Nov 2007 7:55 AM
  1. ;;7.0;OUTPATIENT PHARMACY;**294**;DEC 1997;Build 13
  1. ;
  1. ;Reference to CKP^GMTSUP supported by DBIA 4231
  1. ;Reference to COVER^ORWPS supported by DBIA 4954
  1. ;Credit to Herb Morriss and Al Hernandez for the original design
  1. ;Puget Sound Health Care System, Seattle WA
  1. EN N PSOQPEND,DAYSEP,DRUGHDR1,DRUGHDR2,DRUGSEP,INSTSEP1,INSTSEP2,INSTSEP3
  1. N EMPTYLN,PRETYPE,SUPTYPE,ADDR,AL,ALFLAG,ARLDASH
  1. N ARLDATE,ARLDFN,ARLDOB,ARLNAME,ARLSITE,ARLSN
  1. N BLANKLN,BLNKLN,DRUG1,FOOD,GMRAL,IDRUG,ISIG,ITYPE
  1. N NVA,NONE,PAGE,PGWIDTH,PGLENGTH,PHONE
  1. N RXIEN,SIGCNT,SIGPOS,XPOS1,XPOS2,XPOS3,XPOS4
  1. N FN,HP,IA,RPTDATE,TYPE,WP,ST,SUPCNT,SUPDRUG,X,X1,X2,ADDRFL
  1. N DIWF,DIWL,DIWR,INSTSEP1,INSTSEP2,INSTSEP3,DRUGHDR1,DRUGHDR2,DRUGSEP
  1. S PGWIDTH=IOM-5,PGLENGTH=IOSL-9
  1. Q:PGWIDTH<48 ;ensure that the IOM variable is wide enough
  1. S RPTDATE=$$FMTE^XLFDT($$NOW^XLFDT,"1D")
  1. S XPOS1=(PGWIDTH-26)\2 ;title
  1. S XPOS2=PGWIDTH-6 ;page number
  1. S XPOS3=(PGWIDTH-29)\2 ;site
  1. S XPOS4=(PGWIDTH-53)\2 ;refill info
  1. S BLANKLN="",$P(BLNKLN," ",PGWIDTH)=" "
  1. S EMPTYLN="!,""|"_$E(BLNKLN,1,PGWIDTH-2)_"|"""
  1. S DAYSEP="| | | | |"
  1. S DRUGHDR1="| |MORNING| NOON |EVENING|BEDTIME| COMMENTS"
  1. S DRUGHDR1=DRUGHDR1_$E(BLNKLN,$L(DRUGHDR1),PGWIDTH-2)_"|"
  1. S DRUGHDR2="| "_DAYSEP
  1. S DRUGHDR2=DRUGHDR2_$E(BLNKLN,$L(DRUGHDR2),PGWIDTH-2)_"|"
  1. S $P(DRUGSEP,"~",PGWIDTH-2)="~"
  1. S DRUGSEP="|"_DRUGSEP_"|"
  1. S $P(INSTSEP1,"-",PGWIDTH-2)="-"
  1. S INSTSEP1="|"_INSTSEP1_"|"
  1. S INSTSEP2="| UNITS PER DOSE: "_DAYSEP
  1. S INSTSEP2=INSTSEP2_$E(BLNKLN,$L(INSTSEP2),PGWIDTH-2)_"|"
  1. S INSTSEP3="| "_DAYSEP
  1. S INSTSEP3=INSTSEP3_$E(BLNKLN,$L(INSTSEP3),PGWIDTH-2)_"|"
  1. S X1=DT,X2=-45 D C^%DTC S ARLDATE=X
  1. 1 ;Patient
  1. S ARLDFN=""
  1. F IA=1:1 S ARLDFN=$P(ARLPAT,";",IA) Q:ARLDFN="" D
  1. . S PAGE=1
  1. . D HD,SHOW(ARLDFN)
  1. Q
  1. SHOW(PTIEN) ;
  1. N LIST,NVA
  1. D COVER^ORWPS(.LIST,PTIEN)
  1. D GETOPORD(.LIST)
  1. D GETRXDAT(.LIST)
  1. S SUPTYPE=0,PRETYPE="D"
  1. S ITYPE="@"
  1. F S ITYPE=$O(LIST(ITYPE)) Q:ITYPE]"ZZZ" Q:ITYPE="" D
  1. . I PRETYPE'=ITYPE D
  1. . . W !,DRUGSEP
  1. . . W @EMPTYLN
  1. . . W !,"|","SUPPLY ITEMS:"_$E(BLNKLN,14,PGWIDTH-2)_"|"
  1. . . S PRETYPE=ITYPE
  1. . . I (ITYPE="S")&(SUPTYPE=0) D
  1. . . . S SUPTYPE=1,SUPCNT=0,SUPDRUG=""
  1. . . . F S SUPDRUG=$O(LIST(ITYPE,SUPDRUG)) Q:SUPDRUG="" D
  1. . . . . S SUPCNT=SUPCNT+1
  1. . . . I $Y>(PGLENGTH-SUPCNT) W !,DRUGSEP,@IOF D HD3
  1. . S IDRUG=""
  1. . F S IDRUG=$O(LIST(ITYPE,IDRUG)) Q:IDRUG="" D
  1. . . I 'SUPTYPE D
  1. . . S SIGCNT=0,SIGPOS=""
  1. . . F S SIGPOS=$O(LIST(ITYPE,IDRUG,SIGPOS)) Q:SIGPOS="" D
  1. . . . S SIGCNT=SIGCNT+1
  1. . . I $Y>(PGLENGTH-SIGCNT) W !,DRUGSEP,@IOF D HD3
  1. . . W:'SUPTYPE !,DRUGSEP,@EMPTYLN
  1. . . W !,"|",IDRUG_$E(BLNKLN,$L(IDRUG),PGWIDTH-3)_"|"
  1. . . Q:SUPTYPE
  1. . . S ISIG=0
  1. . . F S ISIG=$O(LIST(ITYPE,IDRUG,ISIG)) Q:ISIG<1 D
  1. . . . W !,"| ",LIST(ITYPE,IDRUG,ISIG),$E(BLNKLN,$L(LIST(ITYPE,IDRUG,ISIG)),PGWIDTH-8),"|"
  1. . . W !,INSTSEP1,!,INSTSEP2 W:'$G(PSOQHS) !,INSTSEP3
  1. NVA ;NVA MEDS ADDED 5/6/05
  1. I $D(NVA) D
  1. . N NVACNT,NVADRUG
  1. . W !,DRUGSEP
  1. . W @EMPTYLN
  1. . W !,"|","NON-VA Medications:"_$E(BLNKLN,20,PGWIDTH-2)_"|"
  1. . W @EMPTYLN
  1. . S NVACNT=0
  1. . S NVADRUG=""
  1. . F S NVADRUG=$O(NVA(NVADRUG)) Q:NVADRUG="" D
  1. . . S NVACNT=NVACNT+1
  1. . . I $Y>(PGLENGTH-NVACNT) W !,DRUGSEP,@IOF D HD3
  1. . . W !,"|",NVADRUG_$E(BLNKLN,$L(NVADRUG),PGWIDTH-3)_"|"
  1. K NVACNT,NVADRUG
  1. W !,INSTSEP1
  1. D
  1. . Q:'$G(PSOQPEND)
  1. . W !!,"Any medication items listed as ""pending"" are those that have just been" D PGE Q:$D(GMTSQIT)
  1. . W !,"written by your provider(s). These medication orders will be reviewed" D PGE Q:$D(GMTSQIT)
  1. . W !,"by your pharmacist, prior to the prescription(s) being dispensed. When" D PGE Q:$D(GMTSQIT)
  1. . W !,"you receive your new prescription(s), by mail or from the pharmacy window," D PGE Q:$D(GMTSQIT)
  1. . W !,"be sure to follow the instructions on the prescription label. If you" D PGE Q:$D(GMTSQIT)
  1. . W !,"have any question about your medication, please call your provider or " D PGE Q:$D(GMTSQIT)
  1. . W !,"your pharmacist." D PGE Q:$D(GMTSQIT)
  1. Q
  1. PGE D:$G(PSOQHS) CKP^GMTSUP
  1. Q
  1. GETOPORD(ORDLIST) ;
  1. N LISTIEN,KILLORD
  1. S LISTIEN=0
  1. F S LISTIEN=$O(ORDLIST(LISTIEN)) Q:LISTIEN<1 D
  1. . S KILLORD=$$IPORD(ORDLIST(LISTIEN))
  1. . I 'KILLORD S KILLORD=$$CKSTATUS(ORDLIST(LISTIEN)) D
  1. . K:KILLORD ORDLIST(LISTIEN)
  1. Q
  1. IPORD(LISTNODE) ;
  1. N RETURN,PKG
  1. S RETURN=0
  1. S PKG=$P($P(LISTNODE,"^",1),";",2)
  1. I "UI"[PKG S RETURN=1
  1. I $P(LISTNODE,"^",1)["N;" D
  1. . S:$P(LISTNODE,"^",4)="ACTIVE" NVA($P(LISTNODE,"^",2),+LISTNODE)=LISTNODE
  1. . S RETURN=1
  1. Q RETURN
  1. CKSTATUS(LISTNODE) ;
  1. N RETURN,RXIEN
  1. S RETURN=0 ; ASSUME ACTIVE AND NOT PASS MED
  1. S:$P(LISTNODE,"^",4)["DISCONTINUED" RETURN=1
  1. S:$P(LISTNODE,"^",4)["EXPIRED" RETURN=1
  1. Q RETURN
  1. GETRXDAT(RXS) ;
  1. N RXSIEN,DRUGNAME,FSIG,RXTYPE
  1. S RXSIEN=0
  1. F S RXSIEN=$O(RXS(RXSIEN)) Q:RXSIEN<1 D
  1. . I $P(RXS(RXSIEN),";")["P" D GETPEND(RXSIEN) S PSOQPEND=1 Q ;->
  1. . S RXIEN=+RXS(RXSIEN)
  1. . S DRUGNAME=$$ZZ^PSOSUTL(RXIEN)
  1. . D FSIG^PSOUTLA("R",RXIEN,PGWIDTH-8)
  1. . S RXTYPE=$$GETTYPE(RXIEN)
  1. . M RXS(RXTYPE,DRUGNAME)=FSIG
  1. . N PSOQSUB
  1. . S PSOQSUB=$O(RXS(RXTYPE,DRUGNAME,":"),-1)+1
  1. . S RXS(RXTYPE,DRUGNAME,PSOQSUB)=$$REFILLS^PSOQ0076(RXIEN)_" refill(s) remaining prior to "_$$FMTE^XLFDT($$EXPDATE^PSOQ0076(RXIEN))
  1. Q
  1. GETPEND(RXSIEN) ;RMS/HINES 8-16-07 ADD PENDING RX'S
  1. N PSOQPDN,PSOQDIND,PSOQOIND,PSOQ100,PSOQSIND,PSOQSCT,PSOQRAW,SUB
  1. S PSOQ100=$P(RXS(RXSIEN),U,3) Q:'+PSOQ100
  1. S PSOQOIND=$O(^OR(100,PSOQ100,4.5,"ID","ORDERABLE",0)) Q:'+PSOQOIND
  1. S PSOQPDN=$P($G(^ORD(101.43,+$G(^OR(100,PSOQ100,4.5,PSOQOIND,1)),0)),U)
  1. S PSOQDIND=$O(^OR(100,PSOQ100,4.5,"ID","DRUG",0)) D
  1. . Q:'+PSOQDIND
  1. . S PSOQPDN=$P($G(^PSDRUG(+$G(^OR(100,PSOQ100,4.5,PSOQDIND,1)),0)),U)
  1. S PSOQSIND=$O(^OR(100,PSOQ100,8,":"),-1) Q:'+PSOQSIND
  1. F PSOQSCT=2:1:$O(^OR(100,PSOQ100,8,PSOQSIND,.1,":"),-1) D
  1. . S PSOQRAW=$G(^OR(100,PSOQ100,8,PSOQSIND,.1,PSOQSCT,0))
  1. . N WORDS,COUNT,LINE,NEXTWORD
  1. . S WORDS=$L(PSOQRAW," "),SUB=$G(SUB,0)+1
  1. . F COUNT=1:1:WORDS D
  1. .. S NEXTWORD=$P(PSOQRAW," ",COUNT)
  1. .. Q:NEXTWORD=""
  1. .. S LINE=$G(LINE)_NEXTWORD_" "
  1. .. I $L($G(LINE))>65&(COUNT'=WORDS) K LINE S SUB=SUB+1
  1. .. S RXS("D","**PENDING**"_PSOQPDN,SUB)=$G(RXS("D","**PENDING**"_PSOQPDN,SUB))_NEXTWORD_" "
  1. Q
  1. GETTYPE(IEN52) ;
  1. N RETURN,CLASS
  1. S RETURN="D"
  1. S CLASS=$$GETCLASS(IEN52)
  1. S:$E(CLASS,1,1)="X" RETURN="S"
  1. S:$E(CLASS,1,2)="DX" RETURN="S"
  1. Q RETURN
  1. GETCLASS(IENRX) ;
  1. N RETURN,NODE0RX,IENDRUG,NODE0DRG,NODEND50,IENCLASS,NODE0CLS,VACLASS
  1. S RETURN=""
  1. S NODE0RX=$G(^PSRX(IENRX,0))
  1. S IENDRUG=$P(NODE0RX,"^",6)
  1. Q:+IENDRUG=0 RETURN
  1. S NODE0DRG=$G(^PSDRUG(IENDRUG,0))
  1. S NODEND50=$G(^PSDRUG(IENDRUG,"ND"))
  1. S IENCLASS=$P(NODEND50,"^",6)
  1. Q:+IENCLASS=0 RETURN
  1. S NODE0CLS=$G(^PS(50.605,IENCLASS,0))
  1. S VACLASS=$P(NODE0CLS,"^",1)
  1. S RETURN=VACLASS
  1. Q RETURN
  1. HD ;
  1. S FN=ARLDFN
  1. S ARLNAME=$E($P(^DPT(ARLDFN,0),"^",1),1,28)
  1. S ARLSN=$P(^(0),"^",9),ARLDOB=$P(^(0),"^",3)
  1. S PHONE=$S($D(^DPT(ARLDFN,.13)):^(.13),1:"")
  1. S HP=$P(PHONE,"^",1),WP=$P(PHONE,"^",2)
  1. S ADDR=$S($D(^DPT(ARLDFN,.11)):^(.11),1:"")
  1. I $D(^DPT(ARLDFN,.121)),$P(^(.121),"^",9)="Y" D
  1. . S X=$S($P(^(.121),"^",8):$P(^(.121),"^",8),1:9999999)
  1. . I DT'<$P(^(.121),"^",7),DT'>X D
  1. . . S ADDR=^(.121)
  1. . . S ADDRFL="(temporary)"
  1. . . S HP=$P(ADDR,"^",10)
  1. S ST=$S($D(^DIC(5,+$P(ADDR,"^",5),0)):$P(^(0),"^",2),1:"UNKNOWN")
  1. S ADDR(4)=$P(ADDR,"^",4)_", "_ST_" "_$P(ADDR,"^",6)
  1. S ADDR(3)=$P(ADDR,"^",3),ADDR(2)=$P(ADDR,"^",2),ADDR(1)=$P(ADDR,"^",1)
  1. I ADDR(2)']"" D
  1. . S ADDR(2)=ADDR(3)
  1. . S ADDR(3)=""
  1. HD1 ; Header for 1st page
  1. S ARLSITE=^PS(59,PSOSITE,0)
  1. D PGE Q:$D(GMTSQIT)
  1. W !,"Date: ",RPTDATE,?XPOS1,"PATIENT MEDICATION INFORMATION"
  1. I $D(PAGE) D
  1. . W ?XPOS2,"Page: ",PAGE
  1. . S PAGE=PAGE+1
  1. W !,?XPOS4,"PRINTED BY THE VA MEDICAL CENTER AT: "_$P($G(^DIC(4,+$G(^PS(59,PSOSITE,"INI")),0)),U,1)
  1. W !,?XPOS4,"FOR PRESCRIPTION REFILLS CALL ("_$P(ARLSITE,U,3)_") "_$P(ARLSITE,U,4)
  1. HD2 W !!,"Name: ",$E(ARLNAME,1,40)," - ",$E(ARLSN,6,9)
  1. W ?30," PHARMACY - ",$P(ARLSITE,"^",7)," DIVISION (",$P(ARLSITE,"^",3),"-",$P(ARLSITE,"^",4),")",!
  1. W !,INSTSEP1,!,DRUGHDR1 ;!,DRUGHDR2
  1. Q
  1. HD3 ;Header for subsequent pages
  1. W !,"Date: ",RPTDATE,?XPOS1,"PATIENT MEDICATION INFORMATION"
  1. I $D(PAGE) W ?XPOS2,"Page: ",PAGE S PAGE=PAGE+1
  1. W !,?XPOS4,"PRINTED BY THE VA MEDICAL CENTER AT: "_$P($G(^DIC(4,+$G(^PS(59,PSOSITE,"INI")),0)),U,1)
  1. W !,?XPOS4,"FOR PRESCRIPTION REFILLS CALL ("_$P(ARLSITE,U,3)_") "_$P(ARLSITE,U,4),!
  1. W !?1,"Name: ",$E(ARLNAME,1,40)," - ",$E(ARLSN,6,9)
  1. W ?30," PHARMACY - ",$P(ARLSITE,"^",7)," DIVISION (",$P(ARLSITE,"^",3),"-",$P(ARLSITE,"^",4),")",!
  1. W !,INSTSEP1
  1. W:$G(SUPCNT)&'$G(NVACNT) !,"|","SUPPLY ITEMS:"_$E(BLNKLN,14,PGWIDTH-2)_"|",@EMPTYLN
  1. W:$G(NVACNT) @EMPTYLN,!,"|","NON-VA Medications:"_$E(BLNKLN,20,PGWIDTH-2)_"|",@EMPTYLN
  1. W:'$G(NVACNT)&'$G(SUPCNT) !,DRUGHDR1
  1. Q
  1. RE ;Allergies
  1. S ARLDASH="",$P(ARLDASH,"=",$E(BLNKLN,1,PGWIDTH-10))=ARLDASH W !,ARLDASH,!!
  1. S NONE="NO INFORMATION (COMPLETE SECTION BELOW)",ALFLAG=0 D ALL
  1. W "REACTIONS/ALLERGIES currently on file : ",$S($D(GMRAL):"",1:NONE) Q:'$D(GMRAL)
  1. S X=DRUG1_FOOD,DIWL=5,DIWR=PGWIDTH-5,DIWF="W" D ^DIWP,^DIWW
  1. Q
  1. ALL ;Gets allergy info
  1. K GMRA,GMRAL
  1. N IFN,DATA,VER,ARLEND
  1. S ARLEND=0,DFN=ARLDFN,GMRA="0^0^011" D ^GMRADPT S (DRUG1,FOOD)=""
  1. I $D(GMRAL),GMRAL=0 S DRUG1="NO KNOWN ALLERGIES"
  1. I $D(GMRAL),GMRAL=1 S IFN="" F S IFN=$O(GMRAL(IFN)) Q:IFN=""!(ARLEND) S DATA=GMRAL(IFN),AL=$P(DATA,U,2),TYPE=$P(DATA,U,3),VER=$S($P(DATA,U,4)=1:"V",1:"NV") D
  1. .I $L(DRUG1)>300 S DRUG1="TOO MANY TO LIST",ARLEND=1
  1. .S:TYPE="D" DRUG1=AL_" ("_VER_"),"_DRUG1
  1. .S:TYPE="F" FOOD="Food Allergies on File"
  1. Q