- PSJORRE1 ;BIR/MV-RETURN INPATIENT ACTIVE MEDS (EXPANDED) ;29 Jan 99 / 8:49 AM
- ;;5.0; INPATIENT MEDICATIONS ;**22,51,50,58,81,91,110,111,134**;16 DEC 97;Build 124
- ;
- ; Reference to ^PS(51.2 is supported by DBIA 2178.
- ; Reference to ^PS(52.6 is supported by DBIA 1231.
- ; Reference to ^PS(52.7 is supported by DBIA 2173.
- ; Reference to ^PS(55 is supported by DBIA 2191.
- ; Reference to ^PSDRUG is supported by DBIA 2192.
- ; Reference to ^TMP("PS" is documented in DBIA #2384.
- ;
- OEL(DFN,ON) ; return list of expanded inpat meds
- K ^TMP("PS",$J)
- N ADM,CNT,DN,DO,F,INFUS,INST,MR,ND,ND0,ND2,ND2P5,ND6,NDOI,SCH,SIO,START,STAT,STOP,TYP,UNITS,X,Y
- S F=$S(ON["P":"^PS(53.1,",ON["U":"^PS(55,DFN,5,",1:"^PS(55,"_DFN_",""IV"",")
- I ON'["P",'$D(@(F_+ON_")")) Q
- I ON["P" S X=$G(^PS(53.1,+ON,0)) Q:$P(X,U,15)'=DFN S TYP=$P(X,U,4) D @$S(TYP="U":"UDTMP",1:"IVTMP")
- D:ON'["P" @$S(ON["U":"UDTMP",1:"IVTMP")
- S Y=$S(ON["V":5,1:12),CNT=0
- I $O(@(F_+ON_","_Y_",0)")) D
- . F X=0:0 S X=$O(@(F_+ON_","_Y_","_X_")")) Q:'X D
- ..S CNT=CNT+1,ND=$G(@(F_+ON_","_Y_","_X_",0)")),^TMP("PS",$J,"PC",CNT,0)=ND
- S ^TMP("PS",$J,"PC",0)=CNT
- Q
- ;
- UDTMP ;*** Set ^TMP for Unit dose orders.
- N DO,DN,INST,X,Y,PROVIDER,NOTGIVEN,RNWDT
- S (MR,SCH,INST)=""
- S ND2=$G(@(F_+ON_",2)")),ND0=$G(@(F_+ON_",0)"))
- S ND6=$P($G(@(F_+ON_",6)")),"^")
- S RNWDT=$$LASTREN^PSJLMPRI(DFN,ON) I RNWDT S RNWDT=+RNWDT
- S STAT=$$CODES^PSIVUTL($P(ND0,U,9),$S(ON["P":53.1,1:55.06),28)
- S NDOI=$G(@(F_+ON_",.2)")),DO=$P(NDOI,U,2)
- S DN(1)=$$OIDF^PSJLMUT1(NDOI) I DN(1)="" K DN D DRGDISP^PSJLMUT1(DFN,ON,40,0,.DN,1)
- S UNITS="" I '$O(@(F_+ON_",1,1)")) S UNITS=$P($G(@(F_+ON_",1,1,0)")),U,2) S:(ON["U")&(UNITS="") UNITS=1
- S MR=$$MR(+$P(ND0,U,3)),INST=$G(@(F_+ON_",.3)"))
- S NOTGIVEN=$S(ON["U":$P($G(^PS(55,DFN,5,+ON,0)),"^",22),1:"")
- S ^TMP("PS",$J,0)=DN(1)_"^^"_$P(ND2,U,4)_"^^"_$P(ND2,U,2)_U_STAT_"^^^"_DO_U_UNITS_U_$P(ND0,U,21)_U_U_NOTGIVEN_U_($P(ND0,U,9)="P"&($P(ND0,U,24)="R"))_U_U_$G(RNWDT)
- S PROVIDER=$P($G(@(F_+ON_",0)")),"^",2)
- I PROVIDER S ^TMP("PS",$J,"P",0)=PROVIDER_"^"_$P($G(^VA(200,PROVIDER,0)),"^")
- S ^TMP("PS",$J,"MDR",0)=MR]"" S:MR]"" ^TMP("PS",$J,"MDR",1,0)=MR
- S ^TMP("PS",$J,"SCH",0)=$P(ND2,U)]"" S:$P(ND2,U)]"" ^TMP("PS",$J,"SCH",1,0)=$P(ND2,U)
- S:$P(ND0,U,7)]"" ^TMP("PS",$J,"SCH",0)=1,$P(^TMP("PS",$J,"SCH",1,0),U,2)=$$GTSCHT($P(ND0,U,7))_"^"_$P(ND0,U,7)
- S ^TMP("PS",$J,"SIG",0)=INST]"" S:INST]"" ^TMP("PS",$J,"SIG",1,0)=INST
- S ^TMP("PS",$J,"ADM",0)=$P(ND2,U,5)]"" S:$P(ND2,U,5)]"" ^TMP("PS",$J,"ADM",1,0)=$P(ND2,U,5)
- S ^TMP("PS",$J,"SIO",0)=ND6]"" S:ND6]"" ^TMP("PS",$J,"SIO",1,0)=ND6
- NEW VERPHARM S:ON["U" VERPHARM=$P($G(@(F_+ON_",4)")),U,3)
- S:+$G(VERPHARM) $P(^TMP("PS",$J,"RXN",0),U,5)=VERPHARM
- NEW PSJDD,INACTDT,NDDD,OUTOI,PSJOUT S CNT=0
- F PSJDD=0:0 S PSJDD=$O(@(F_+ON_",1,PSJDD)")) Q:'PSJDD D
- . S NDDD=@(F_+ON_",1,PSJDD,0)")
- . I $P(NDDD,U,3)]"",($P(NDDD,U,3)'>DT) Q
- . S PSJOUT=$P($G(^PSDRUG(+NDDD,8)),U,5)
- . I +PSJOUT D
- .. S INACTDT=$G(^PSDRUG(+PSJOUT,"I")),OUTOI=+$G(^PSDRUG(+PSJOUT,2))
- .. I INACTDT]"",(INACTDT'>DT) S (PSJOUT,OUTOI)=""
- . I '+PSJOUT,($P($G(^PSDRUG(+NDDD,2)),U,3)["O") D
- .. S PSJOUT=+NDDD,OUTOI=+NDOI
- .. S INACTDT=$G(^PSDRUG(+NDDD,"I"))
- .. I INACTDT]"",(INACTDT'>DT) S (PSJOUT,OUTOI)=""
- . S UNITS=$P(NDDD,U,2) S:(ON["U")&(UNITS="") UNITS=1
- . S CNT=CNT+1,^TMP("PS",$J,"DD",CNT,0)=+NDDD_U_UNITS_U_PSJOUT_U_$G(OUTOI)
- S ^TMP("PS",$J,"DD",0)=CNT
- Q
- ;
- IVTMP ;*** Set ^TMP for IV orders.
- N PROVIDER,RNWDT,IVLIM S ND0=$G(@(F_+ON_",0)")),CNT=0
- F X=0:0 S X=$O(@(F_+ON_",""AD"","_X_")")) Q:'X S ND=$G(@(F_+ON_",""AD"","_X_",0)")),DN=$P($G(^PS(52.6,+ND,0)),U),Y=DN_U_$P(ND,U,2) S:$P(ND,U,3) Y=Y_U_$P(ND,U,3) S CNT=CNT+1,^TMP("PS",$J,"A",CNT,0)=Y
- S RNWDT=$$LASTREN^PSJLMPRI(DFN,ON) I RNWDT S RNWDT=+RNWDT
- S ^TMP("PS",$J,"A",0)=CNT,CNT=0
- F X=0:0 S X=$O(@(F_+ON_",""SOL"","_X_")")) Q:'X S ND=$G(@(F_+ON_",""SOL"","_X_",0)")),DN=$G(^PS(52.7,+ND,0)),CNT=CNT+1,^TMP("PS",$J,"B",CNT,0)=$P(DN,U)_U_$P(ND,U,2)_U_$P(DN,U,4)
- S ^TMP("PS",$J,"B",0)=CNT
- S INST=$G(@(F_+ON_",.3)"))
- I ON["P" D
- . S SCH=$P($G(^PS(53.1,+ON,2)),U)
- . S PROVIDER=$P(ND0,U,2)
- . S MR=$$MR(+$P(ND0,U,3)),STAT=$$CODES^PSIVUTL($P(ND0,U,9),53.1,28)
- . S INFUS=$P($G(^PS(53.1,+ON,8)),U,5)
- . S ND2=$G(@(F_+ON_",2)")),START=$P(ND2,U,2),STOP=$P(ND2,U,4)
- . S ADM=$P(ND2,U,5),SIO=$P($G(@(F_+ON_",6)")),"^")
- . S ND2P5=$G(@(F_+ON_",2.5)")) S IVLIM=$P(ND2P5,U,4) I $E(IVLIM)="a" S IVLIM="doses"_$P(IVLIM,"a",2)
- . I IVLIM="" S IVLIM=$P(ND2P5,U,2) S:(IVLIM'["d")&(IVLIM'["h") IVLIM=""
- I ON'["P" D
- . S PROVIDER=$P(ND0,U,6)
- . S SCH=$P(ND0,U,9),INFUS=$P(ND0,U,8),STAT=$$CODES^PSIVUTL($P(ND0,U,17),55.01,100)
- . S MR=$$MR(+$P($G(^PS(55,DFN,"IV",+ON,.2)),U,3))
- . S START=$P(ND0,U,2),STOP=$P(ND0,U,3)
- . S ADM=$P(ND0,U,11),SIO=$P($G(@(F_+ON_",3)")),"^")
- . NEW VERPHARM S VERPHARM=$P($G(^PS(55,DFN,"IV",+ON,4)),U,4)
- . S:+VERPHARM $P(^TMP("PS",$J,"RXN",0),U,5)=VERPHARM
- . S ND2P5=$G(@(F_+ON_",2.5)")) S IVLIM=$P(ND2P5,U,4) I IVLIM="" S IVLIM=$P(ND2P5,U,2) S:(IVLIM'["d")&(IVLIM'["h") IVLIM=""
- S DN=$G(@(F_+ON_",.2)")),DO=$P(DN,U,2)
- S DN=$S(+$P(DN,U):$$OIDF^PSJLMUT1($P(DN,U)),1:"")
- S ^TMP("PS",$J,0)=DN_U_INFUS_U_STOP_"^^"_START_U_STAT_"^^^"_DO_"^^"_$P(ND0,U,21)_U_U_U_($P(ND0,U,9)="P"&($P(ND0,U,24)="R"))_U_U_$G(RNWDT)
- I PROVIDER S ^TMP("PS",$J,"P",0)=PROVIDER_"^"_$P($G(^VA(200,PROVIDER,0)),"^")
- S ^TMP("PS",$J,"MDR",0)=MR]"" S:MR]"" ^TMP("PS",$J,"MDR",1,0)=MR
- S ^TMP("PS",$J,"SCH",0)=SCH]"" S:SCH]"" ^TMP("PS",$J,"SCH",1,0)=SCH
- I ON["P" S:$P(ND0,U,7)]"" ^TMP("PS",$J,"SCH",0)=1,$P(^TMP("PS",$J,"SCH",1,0),U,2)=$$GTSCHT($P(ND0,U,7))_"^"_$P(ND0,U,7)
- S ^TMP("PS",$J,"SIG",0)=INST]"" S:INST]"" ^TMP("PS",$J,"SIG",1,0)=INST
- S ^TMP("PS",$J,"ADM",0)=ADM]"" S:ADM]"" ^TMP("PS",$J,"ADM",1,0)=ADM
- S ^TMP("PS",$J,"SIO",0)=SIO]"" S:SIO]"" ^TMP("PS",$J,"SIO",1,0)=SIO
- I $G(IVLIM)]"" S ^TMP("PS",$J,"IVLIM",0)=$G(IVLIM)
- Q
- ;
- MR(X) ;RETURN MED ROUTE ABBR. IF THE ABBR="" RETURN MED ROUTE'S NAME.
- S X=$G(^PS(51.2,X,0))
- Q $S($P(X,U,3)]"":$P(X,U,3),1:$P(X,U))
- ;
- GTSTAT(X) ;
- Q $S(X="A":"ACTIVE",X="D":"DISCONTINUED",X="I":"INCOMPLETE",X="N":"NON-VERFIED",X="U":"UNRELEASED",X="P":"PENDING",X="DE":"DISCONTINUED (EDIT)",X="O":"ON CALL",1:"NOT FOUND")
- ;
- VA200(X) ;Return the IEN for the user.
- ; X = User name
- NEW DIC,Y S DIC="^VA(200,",DIC(0)="NZ" D ^DIC
- I +Y=-1 Q ""
- Q $P(Y,U)
- GTSCHT(X) ;
- Q $S(X="C":"CONTINUOUS",X="O":"ONE TIME",X="P":"PRN",X="R":"FILL ON REQUEST",X="OC":"ON CALL",1:"NOT FOUND")
- PSJORRE1 ;BIR/MV-RETURN INPATIENT ACTIVE MEDS (EXPANDED) ;29 Jan 99 / 8:49 AM
- +1 ;;5.0; INPATIENT MEDICATIONS ;**22,51,50,58,81,91,110,111,134**;16 DEC 97;Build 124
- +2 ;
- +3 ; Reference to ^PS(51.2 is supported by DBIA 2178.
- +4 ; Reference to ^PS(52.6 is supported by DBIA 1231.
- +5 ; Reference to ^PS(52.7 is supported by DBIA 2173.
- +6 ; Reference to ^PS(55 is supported by DBIA 2191.
- +7 ; Reference to ^PSDRUG is supported by DBIA 2192.
- +8 ; Reference to ^TMP("PS" is documented in DBIA #2384.
- +9 ;
- OEL(DFN,ON) ; return list of expanded inpat meds
- +1 KILL ^TMP("PS",$JOB)
- +2 NEW ADM,CNT,DN,DO,F,INFUS,INST,MR,ND,ND0,ND2,ND2P5,ND6,NDOI,SCH,SIO,START,STAT,STOP,TYP,UNITS,X,Y
- +3 SET F=$SELECT(ON["P":"^PS(53.1,",ON["U":"^PS(55,DFN,5,",1:"^PS(55,"_DFN_",""IV"",")
- +4 IF ON'["P"
- IF '$DATA(@(F_+ON_")"))
- QUIT
- +5 IF ON["P"
- SET X=$GET(^PS(53.1,+ON,0))
- IF $PIECE(X,U,15)'=DFN
- QUIT
- SET TYP=$PIECE(X,U,4)
- DO @$SELECT(TYP="U":"UDTMP",1:"IVTMP")
- +6 IF ON'["P"
- DO @$SELECT(ON["U":"UDTMP",1:"IVTMP")
- +7 SET Y=$SELECT(ON["V":5,1:12)
- SET CNT=0
- +8 IF $ORDER(@(F_+ON_","_Y_",0)"))
- Begin DoDot:1
- +9 FOR X=0:0
- SET X=$ORDER(@(F_+ON_","_Y_","_X_")"))
- IF 'X
- QUIT
- Begin DoDot:2
- +10 SET CNT=CNT+1
- SET ND=$GET(@(F_+ON_","_Y_","_X_",0)"))
- SET ^TMP("PS",$JOB,"PC",CNT,0)=ND
- End DoDot:2
- End DoDot:1
- +11 SET ^TMP("PS",$JOB,"PC",0)=CNT
- +12 QUIT
- +13 ;
- UDTMP ;*** Set ^TMP for Unit dose orders.
- +1 NEW DO,DN,INST,X,Y,PROVIDER,NOTGIVEN,RNWDT
- +2 SET (MR,SCH,INST)=""
- +3 SET ND2=$GET(@(F_+ON_",2)"))
- SET ND0=$GET(@(F_+ON_",0)"))
- +4 SET ND6=$PIECE($GET(@(F_+ON_",6)")),"^")
- +5 SET RNWDT=$$LASTREN^PSJLMPRI(DFN,ON)
- IF RNWDT
- SET RNWDT=+RNWDT
- +6 SET STAT=$$CODES^PSIVUTL($PIECE(ND0,U,9),$SELECT(ON["P":53.1,1:55.06),28)
- +7 SET NDOI=$GET(@(F_+ON_",.2)"))
- SET DO=$PIECE(NDOI,U,2)
- +8 SET DN(1)=$$OIDF^PSJLMUT1(NDOI)
- IF DN(1)=""
- KILL DN
- DO DRGDISP^PSJLMUT1(DFN,ON,40,0,.DN,1)
- +9 SET UNITS=""
- IF '$ORDER(@(F_+ON_",1,1)"))
- SET UNITS=$PIECE($GET(@(F_+ON_",1,1,0)")),U,2)
- IF (ON["U")&(UNITS="")
- SET UNITS=1
- +10 SET MR=$$MR(+$PIECE(ND0,U,3))
- SET INST=$GET(@(F_+ON_",.3)"))
- +11 SET NOTGIVEN=$SELECT(ON["U":$PIECE($GET(^PS(55,DFN,5,+ON,0)),"^",22),1:"")
- +12 SET ^TMP("PS",$JOB,0)=DN(1)_"^^"_$PIECE(ND2,U,4)_"^^"_$PIECE(ND2,U,2)_U_STAT_"^^^"_DO_U_UNITS_U_$PIECE(ND0,U,21)_U_U_NOTGIVEN_U_($PIECE(ND0,U,9)="P"&($PIECE(ND0,U,24)="R"))_U_U_$GET(RNWDT)
- +13 SET PROVIDER=$PIECE($GET(@(F_+ON_",0)")),"^",2)
- +14 IF PROVIDER
- SET ^TMP("PS",$JOB,"P",0)=PROVIDER_"^"_$PIECE($GET(^VA(200,PROVIDER,0)),"^")
- +15 SET ^TMP("PS",$JOB,"MDR",0)=MR]""
- IF MR]""
- SET ^TMP("PS",$JOB,"MDR",1,0)=MR
- +16 SET ^TMP("PS",$JOB,"SCH",0)=$PIECE(ND2,U)]""
- IF $PIECE(ND2,U)]""
- SET ^TMP("PS",$JOB,"SCH",1,0)=$PIECE(ND2,U)
- +17 IF $PIECE(ND0,U,7)]""
- SET ^TMP("PS",$JOB,"SCH",0)=1
- SET $PIECE(^TMP("PS",$JOB,"SCH",1,0),U,2)=$$GTSCHT($PIECE(ND0,U,7))_"^"_$PIECE(ND0,U,7)
- +18 SET ^TMP("PS",$JOB,"SIG",0)=INST]""
- IF INST]""
- SET ^TMP("PS",$JOB,"SIG",1,0)=INST
- +19 SET ^TMP("PS",$JOB,"ADM",0)=$PIECE(ND2,U,5)]""
- IF $PIECE(ND2,U,5)]""
- SET ^TMP("PS",$JOB,"ADM",1,0)=$PIECE(ND2,U,5)
- +20 SET ^TMP("PS",$JOB,"SIO",0)=ND6]""
- IF ND6]""
- SET ^TMP("PS",$JOB,"SIO",1,0)=ND6
- +21 NEW VERPHARM
- IF ON["U"
- SET VERPHARM=$PIECE($GET(@(F_+ON_",4)")),U,3)
- +22 IF +$GET(VERPHARM)
- SET $PIECE(^TMP("PS",$JOB,"RXN",0),U,5)=VERPHARM
- +23 NEW PSJDD,INACTDT,NDDD,OUTOI,PSJOUT
- SET CNT=0
- +24 FOR PSJDD=0:0
- SET PSJDD=$ORDER(@(F_+ON_",1,PSJDD)"))
- IF 'PSJDD
- QUIT
- Begin DoDot:1
- +25 SET NDDD=@(F_+ON_",1,PSJDD,0)")
- +26 IF $PIECE(NDDD,U,3)]""
- IF ($PIECE(NDDD,U,3)'>DT)
- QUIT
- +27 SET PSJOUT=$PIECE($GET(^PSDRUG(+NDDD,8)),U,5)
- +28 IF +PSJOUT
- Begin DoDot:2
- +29 SET INACTDT=$GET(^PSDRUG(+PSJOUT,"I"))
- SET OUTOI=+$GET(^PSDRUG(+PSJOUT,2))
- +30 IF INACTDT]""
- IF (INACTDT'>DT)
- SET (PSJOUT,OUTOI)=""
- End DoDot:2
- +31 IF '+PSJOUT
- IF ($PIECE($GET(^PSDRUG(+NDDD,2)),U,3)["O")
- Begin DoDot:2
- +32 SET PSJOUT=+NDDD
- SET OUTOI=+NDOI
- +33 SET INACTDT=$GET(^PSDRUG(+NDDD,"I"))
- +34 IF INACTDT]""
- IF (INACTDT'>DT)
- SET (PSJOUT,OUTOI)=""
- End DoDot:2
- +35 SET UNITS=$PIECE(NDDD,U,2)
- IF (ON["U")&(UNITS="")
- SET UNITS=1
- +36 SET CNT=CNT+1
- SET ^TMP("PS",$JOB,"DD",CNT,0)=+NDDD_U_UNITS_U_PSJOUT_U_$GET(OUTOI)
- End DoDot:1
- +37 SET ^TMP("PS",$JOB,"DD",0)=CNT
- +38 QUIT
- +39 ;
- IVTMP ;*** Set ^TMP for IV orders.
- +1 NEW PROVIDER,RNWDT,IVLIM
- SET ND0=$GET(@(F_+ON_",0)"))
- SET CNT=0
- +2 FOR X=0:0
- SET X=$ORDER(@(F_+ON_",""AD"","_X_")"))
- IF 'X
- QUIT
- SET ND=$GET(@(F_+ON_",""AD"","_X_",0)"))
- SET DN=$PIECE($GET(^PS(52.6,+ND,0)),U)
- SET Y=DN_U_$PIECE(ND,U,2)
- IF $PIECE(ND,U,3)
- SET Y=Y_U_$PIECE(ND,U,3)
- SET CNT=CNT+1
- SET ^TMP("PS",$JOB,"A",CNT,0)=Y
- +3 SET RNWDT=$$LASTREN^PSJLMPRI(DFN,ON)
- IF RNWDT
- SET RNWDT=+RNWDT
- +4 SET ^TMP("PS",$JOB,"A",0)=CNT
- SET CNT=0
- +5 FOR X=0:0
- SET X=$ORDER(@(F_+ON_",""SOL"","_X_")"))
- IF 'X
- QUIT
- SET ND=$GET(@(F_+ON_",""SOL"","_X_",0)"))
- SET DN=$GET(^PS(52.7,+ND,0))
- SET CNT=CNT+1
- SET ^TMP("PS",$JOB,"B",CNT,0)=$PIECE(DN,U)_U_$PIECE(ND,U,2)_U_$PIECE(DN,U,4)
- +6 SET ^TMP("PS",$JOB,"B",0)=CNT
- +7 SET INST=$GET(@(F_+ON_",.3)"))
- +8 IF ON["P"
- Begin DoDot:1
- +9 SET SCH=$PIECE($GET(^PS(53.1,+ON,2)),U)
- +10 SET PROVIDER=$PIECE(ND0,U,2)
- +11 SET MR=$$MR(+$PIECE(ND0,U,3))
- SET STAT=$$CODES^PSIVUTL($PIECE(ND0,U,9),53.1,28)
- +12 SET INFUS=$PIECE($GET(^PS(53.1,+ON,8)),U,5)
- +13 SET ND2=$GET(@(F_+ON_",2)"))
- SET START=$PIECE(ND2,U,2)
- SET STOP=$PIECE(ND2,U,4)
- +14 SET ADM=$PIECE(ND2,U,5)
- SET SIO=$PIECE($GET(@(F_+ON_",6)")),"^")
- +15 SET ND2P5=$GET(@(F_+ON_",2.5)"))
- SET IVLIM=$PIECE(ND2P5,U,4)
- IF $EXTRACT(IVLIM)="a"
- SET IVLIM="doses"_$PIECE(IVLIM,"a",2)
- +16 IF IVLIM=""
- SET IVLIM=$PIECE(ND2P5,U,2)
- IF (IVLIM'["d")&(IVLIM'["h")
- SET IVLIM=""
- End DoDot:1
- +17 IF ON'["P"
- Begin DoDot:1
- +18 SET PROVIDER=$PIECE(ND0,U,6)
- +19 SET SCH=$PIECE(ND0,U,9)
- SET INFUS=$PIECE(ND0,U,8)
- SET STAT=$$CODES^PSIVUTL($PIECE(ND0,U,17),55.01,100)
- +20 SET MR=$$MR(+$PIECE($GET(^PS(55,DFN,"IV",+ON,.2)),U,3))
- +21 SET START=$PIECE(ND0,U,2)
- SET STOP=$PIECE(ND0,U,3)
- +22 SET ADM=$PIECE(ND0,U,11)
- SET SIO=$PIECE($GET(@(F_+ON_",3)")),"^")
- +23 NEW VERPHARM
- SET VERPHARM=$PIECE($GET(^PS(55,DFN,"IV",+ON,4)),U,4)
- +24 IF +VERPHARM
- SET $PIECE(^TMP("PS",$JOB,"RXN",0),U,5)=VERPHARM
- +25 SET ND2P5=$GET(@(F_+ON_",2.5)"))
- SET IVLIM=$PIECE(ND2P5,U,4)
- IF IVLIM=""
- SET IVLIM=$PIECE(ND2P5,U,2)
- IF (IVLIM'["d")&(IVLIM'["h")
- SET IVLIM=""
- End DoDot:1
- +26 SET DN=$GET(@(F_+ON_",.2)"))
- SET DO=$PIECE(DN,U,2)
- +27 SET DN=$SELECT(+$PIECE(DN,U):$$OIDF^PSJLMUT1($PIECE(DN,U)),1:"")
- +28 SET ^TMP("PS",$JOB,0)=DN_U_INFUS_U_STOP_"^^"_START_U_STAT_"^^^"_DO_"^^"_$PIECE(ND0,U,21)_U_U_U_($PIECE(ND0,U,9)="P"&($PIECE(ND0,U,24)="R"))_U_U_$GET(RNWDT)
- +29 IF PROVIDER
- SET ^TMP("PS",$JOB,"P",0)=PROVIDER_"^"_$PIECE($GET(^VA(200,PROVIDER,0)),"^")
- +30 SET ^TMP("PS",$JOB,"MDR",0)=MR]""
- IF MR]""
- SET ^TMP("PS",$JOB,"MDR",1,0)=MR
- +31 SET ^TMP("PS",$JOB,"SCH",0)=SCH]""
- IF SCH]""
- SET ^TMP("PS",$JOB,"SCH",1,0)=SCH
- +32 IF ON["P"
- IF $PIECE(ND0,U,7)]""
- SET ^TMP("PS",$JOB,"SCH",0)=1
- SET $PIECE(^TMP("PS",$JOB,"SCH",1,0),U,2)=$$GTSCHT($PIECE(ND0,U,7))_"^"_$PIECE(ND0,U,7)
- +33 SET ^TMP("PS",$JOB,"SIG",0)=INST]""
- IF INST]""
- SET ^TMP("PS",$JOB,"SIG",1,0)=INST
- +34 SET ^TMP("PS",$JOB,"ADM",0)=ADM]""
- IF ADM]""
- SET ^TMP("PS",$JOB,"ADM",1,0)=ADM
- +35 SET ^TMP("PS",$JOB,"SIO",0)=SIO]""
- IF SIO]""
- SET ^TMP("PS",$JOB,"SIO",1,0)=SIO
- +36 IF $GET(IVLIM)]""
- SET ^TMP("PS",$JOB,"IVLIM",0)=$GET(IVLIM)
- +37 QUIT
- +38 ;
- MR(X) ;RETURN MED ROUTE ABBR. IF THE ABBR="" RETURN MED ROUTE'S NAME.
- +1 SET X=$GET(^PS(51.2,X,0))
- +2 QUIT $SELECT($PIECE(X,U,3)]"":$PIECE(X,U,3),1:$PIECE(X,U))
- +3 ;
- GTSTAT(X) ;
- +1 QUIT $SELECT(X="A":"ACTIVE",X="D":"DISCONTINUED",X="I":"INCOMPLETE",X="N":"NON-VERFIED",X="U":"UNRELEASED",X="P":"PENDING",X="DE":"DISCONTINUED (EDIT)",X="O":"ON CALL",1:"NOT FOUND")
- +2 ;
- VA200(X) ;Return the IEN for the user.
- +1 ; X = User name
- +2 NEW DIC,Y
- SET DIC="^VA(200,"
- SET DIC(0)="NZ"
- DO ^DIC
- +3 IF +Y=-1
- QUIT ""
- +4 QUIT $PIECE(Y,U)
- GTSCHT(X) ;
- +1 QUIT $SELECT(X="C":"CONTINUOUS",X="O":"ONE TIME",X="P":"PRN",X="R":"FILL ON REQUEST",X="OC":"ON CALL",1:"NOT FOUND")