RTDPA ;TROY ISC/MJK - Record File Look-up ; 5/19/87 11:21 AM ; 5/23/03 4:41am
;;2.0;Record Tracking;**22,39,41**;10/22/91
S DIC("S")="I $P(^(0),U,4)=+RTAPL,$S('$D(RTTY):1,$P(^RT(+Y,0),U,3)=+RTTY:1,1:0)"
RT K RTESC,RTESC,RTE,RT S:$D(DIC("A")) RTDC("A")=DIC("A") S:$D(DIC("B")) RTDC("B")=DIC("B")
S DIC="^RT(",RTDC(0)=DIC(0) S:$D(DIC("S")) RTDC("S")=DIC("S") S X1=DIC(0),DIC(0)=$P(X1,"L")_$P(X1,"L",2,99) G RT1:DIC(0)'["A"
ASK W !!,$S($D(RTDC("A")):RTDC("A"),1:"Select Record: ") W:$D(RTDC("B")) RTDC("B"),"// " R X:DTIME I $T,X="",$D(RTDC("B")) S X=RTDC("B")
RT1 K RT1 S RTBCIFN="n",RTXR=X I "^"[$E(X) S RTESC="" G Q1
I X?.AN1"/"1N.ANP S W=$E(X,1,$L(X)-1),RTOLD=$O(^RT("AOLDBC",W,0)) D CHAR,BCINVLD G Q:Y<0!(C'=$E(X,$L(X))) S RTSN=+W,Y=$S('RTOLD:+$P(W,"/",2),1:RTOLD),RTBCIFN="y" K:RTOLD RTSN K W,RTOLD G NUM
I X=" " G Q:'$D(^DISV($S($D(DUZ)'[0:DUZ,1:0),"^RT(")) S Y=+^("^RT(") G NUM
I $E(X)="?" S DIC(0)="IEQ",DIC="^RT(" S:$D(RTDC("S")) DIC("S")=RTDC("S") D ^DIC K DIC G Q
I X?1N.N!(X?1"`"1N.N),X'?4N S Y=$S($E(X)="`":+$P(X,"`",2),1:X) G NUM
I RTDC(0)["M",$E(X,1,2)="B."!($E(X,1,2)="b.") S X=$E(X,3,99) G BOR
K DIC S RTA=+RTAPL D IN^RTB K RTA,DIC G Q:Y<0 S RTE=X
FIND G Q:'$D(RTE) S Y=RTE D NAME^RTB S RTSEL("A")="Select "_Y_"'s Record" D ^RTUTL2 K RTSEL("A") I $D(RTY),RTC=1 S RT=RTY(1) G RTC
I $D(RTY),RTSEL["S"!(RTSEL["A") G Q1
I '$D(RTY),$D(RT1) G ASK:RTDC(0)["A",Q1 ;No laygo attempted if there is at least 1 volume for application or type of record
K RTY,RTC G Q:RTDC(0)'["L"
I $S($D(DLAYGO):190-(DLAYGO\1),1:1),DUZ(0)'="@",$D(^DIC(190,0,"LAYGO")) F %=1:1 I DUZ(0)[$E(^("LAYGO"),%) G Q:%>$L(^("LAYGO")) Q
G SET:'$D(RTSHOW) S Y=RTE D NAME^RTB
S RTRD(1)="Yes^create a new record",RTRD(2)="No^do not create a new record",RTRD(0)="S",RTRD("B")=2,RTRD("A")="Do you want to create a new record for '"_Y_"' ? " D SET^RTRD K RTRD S X=$E(X) G Q:X="N"!(X="^")
SET D TYPE1^RTDPA1:$D(RTTY) I '$D(RTTY) S RTTY=+$P(RTAPL,"^",10) D TYPE^RTDPA1:'$D(^DIC(195.2,RTTY,0)) I $D(^DIC(195.2,RTTY,0)) S Y=RTTY D TYPE1^RTUTL,TYPE1^RTDPA1:$D(RTTY) K RTTY
G FIND:$D(RT),Q
;
NUM I $D(^RT(Y,0)),$S('$D(RTSN):1,RTSN=+$P(^RT(Y,0),"^",2):1,1:0) D SCR I Y S RT=Y,Y=$P(^RT(RT,0),"^") I RTDC(0)["E" D NAME^RTB W " ",Y," " S Y=RT X ^DD(190,0,"ID","WRITE")
G Q:'$D(RT)
;
RTC S RTC=1,(RTY(1),^DISV($S($D(DUZ)'[0:DUZ,1:0),"^RT("))=RT
S Y=RT_"^"_$P(^RT(RT,0),"^") S:RTDC(0)["Z" Y(0)=^(0)
Q I '$D(RT) W:RTXR'["?"&(RTDC(0)["Q") *7," ??" G ASK:RTDC(0)["A"
Q1 S:'$D(RT) Y=-1 S X=RTXR K RTXR,RTE,RTSN,RT1,RTS,DIC,RTDC Q
;
CHAR S C=0,Z="0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ-. $/+%" F I=1:1:$L(W) S Y=$F(Z,$E(W,I))-2 Q:Y<0 S C=C+Y
S C=$S(Y'<0:$E(Z,(C#43)+1),1:"") K Z Q
;
BCINVLD Q:Y<0!(C=$E(X,$L(X)))
N Y
S Y=$P(W,"/",2) Q:'$D(^RT(Y,0))
Q:$P(W,"/",1)'=$P(^RT(Y,0),U,2)
I $D(^RT("AOLDBC",W)) S $P(X,"/",2)=$O(^RT("AOLDBC",W,0))_C Q
I $D(^RT(Y,0)),$S('$D(RTSN):1,RTSN=+$P(^(0),"^",2):1,1:0) D
.W !,?9,"NAME:" S RT=Y,Y=$P(^RT(RT,0),"^") I RTDC(0)["E" D NAME^RTB W " ",Y," " S Y=RT X ^DD(190,0,"ID","WRITE")
.W !,?3,*7,"...Please verify the Patient Information.",!?3,*7,"...The BAR CODE ",X," does not match the system.",!,?3,*7,"...Is this the correct Patient?"
.N % S %=2 D YN^DICN
.I %=1 N DIE,DR,DA S DIE="^RT(",DA=Y,DR="300////"_W D ^DIE S X=W_C W @IOF,"Select Record:"
Q
;
BOR K DIC S DIC="^RTV(195.9,",DIC("A")="Select Borrower: ",DIC(0)="IEMLQ",DIC("DR")="3////"_+RTAPL,DIC("S")="I $P(^(0),U,3)="_+RTAPL D ^DIC K DIC I Y<0 G ASK:RTDC(0)["A",Q1
S:$D(RTB) RTZZ("RTB")=RTB S RTZZ("RTSEL")=RTSEL K RTB
S RTB=+Y,RTASK="",RTSEL=$S(RTSEL["S":"S",1:"") D START^RTRPT2 S:$D(RTZZ("RTB")) RTB=RTZZ("RTB") S RTSEL=RTZZ("RTSEL") K RTZZ I '$D(RTY) G ASK:RTDC(0)["A",Q1
I RTC=1,$D(RTY(1)) S RT=+RTY(1) G RTC
G Q1
;
SCR I $D(^DD(190,0,"SCR")) S S=^("SCR") I $D(^RT(Y,0)) X S S:'$T Y=0 K S
I Y,$D(RTDC("S")),$D(^RT(Y,0)) X RTDC("S") S:'$T Y=0
Q
;
BC ; called from 7.5 node of RECORDS file for pre-look-up massage
; picks up IEN for consolidated sites based on "AOLDBC" x-ref
N RTOLD,W,C
S W=$E(X,1,$L(X)-1),RTOLD=$O(^RT("AOLDBC",W,0))
D CHAR
I Y,C=$E(X,$L(X)) S X="`"_$S('RTOLD:+$P(X,"/",2),1:RTOLD)
Q
;
BCDFN ; called from 7.5 node of PATIENT file for pre-look-up massage
; picks up IEN for consolidated sites based on "AOLDBC" x-ref
; of RECORDS file #190.
N RTOLD,W,C,IEN,DFN
S W=$E(X,1,$L(X)-1),RTOLD=$O(^RT("AOLDBC",W,0))
D CHAR
I Y,C=$E(X,$L(X)) D
. S X="`"_$S('RTOLD:+$P(X,"/",2),1:RTOLD)
. S IEN=$P(X,"`",2)
. Q:'IEN
. S DFN=$P($G(^RT(IEN,0)),U,9)
. S:DFN X="`"_DFN
Q
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HRTDPA 4568 printed Dec 13, 2024@02:33:50 Page 2
RTDPA ;TROY ISC/MJK - Record File Look-up ; 5/19/87 11:21 AM ; 5/23/03 4:41am
+1 ;;2.0;Record Tracking;**22,39,41**;10/22/91
+2 SET DIC("S")="I $P(^(0),U,4)=+RTAPL,$S('$D(RTTY):1,$P(^RT(+Y,0),U,3)=+RTTY:1,1:0)"
RT KILL RTESC,RTESC,RTE,RT
if $DATA(DIC("A"))
SET RTDC("A")=DIC("A")
if $DATA(DIC("B"))
SET RTDC("B")=DIC("B")
+1 SET DIC="^RT("
SET RTDC(0)=DIC(0)
if $DATA(DIC("S"))
SET RTDC("S")=DIC("S")
SET X1=DIC(0)
SET DIC(0)=$PIECE(X1,"L")_$PIECE(X1,"L",2,99)
if DIC(0)'["A"
GOTO RT1
ASK WRITE !!,$SELECT($DATA(RTDC("A")):RTDC("A"),1:"Select Record: ")
if $DATA(RTDC("B"))
WRITE RTDC("B"),"// "
READ X:DTIME
IF $TEST
IF X=""
IF $DATA(RTDC("B"))
SET X=RTDC("B")
RT1 KILL RT1
SET RTBCIFN="n"
SET RTXR=X
IF "^"[$EXTRACT(X)
SET RTESC=""
GOTO Q1
+1 IF X?.AN1"/"1N.ANP
SET W=$EXTRACT(X,1,$LENGTH(X)-1)
SET RTOLD=$ORDER(^RT("AOLDBC",W,0))
DO CHAR
DO BCINVLD
if Y<0!(C'=$EXTRACT(X,$LENGTH(X)))
GOTO Q
SET RTSN=+W
SET Y=$SELECT('RTOLD:+$PIECE(W,"/",2),1:RTOLD)
SET RTBCIFN="y"
if RTOLD
KILL RTSN
KILL W,RTOLD
GOTO NUM
+2 IF X=" "
if '$DATA(^DISV($SELECT($DATA(DUZ)'[0:DUZ,1:0),"^RT("))
GOTO Q
SET Y=+^("^RT(")
GOTO NUM
+3 IF $EXTRACT(X)="?"
SET DIC(0)="IEQ"
SET DIC="^RT("
if $DATA(RTDC("S"))
SET DIC("S")=RTDC("S")
DO ^DIC
KILL DIC
GOTO Q
+4 IF X?1N.N!(X?1"`"1N.N)
IF X'?4N
SET Y=$SELECT($EXTRACT(X)="`":+$PIECE(X,"`",2),1:X)
GOTO NUM
+5 IF RTDC(0)["M"
IF $EXTRACT(X,1,2)="B."!($EXTRACT(X,1,2)="b.")
SET X=$EXTRACT(X,3,99)
GOTO BOR
+6 KILL DIC
SET RTA=+RTAPL
DO IN^RTB
KILL RTA,DIC
if Y<0
GOTO Q
SET RTE=X
FIND if '$DATA(RTE)
GOTO Q
SET Y=RTE
DO NAME^RTB
SET RTSEL("A")="Select "_Y_"'s Record"
DO ^RTUTL2
KILL RTSEL("A")
IF $DATA(RTY)
IF RTC=1
SET RT=RTY(1)
GOTO RTC
+1 IF $DATA(RTY)
IF RTSEL["S"!(RTSEL["A")
GOTO Q1
+2 ;No laygo attempted if there is at least 1 volume for application or type of record
IF '$DATA(RTY)
IF $DATA(RT1)
if RTDC(0)["A"
GOTO ASK
GOTO Q1
+3 KILL RTY,RTC
if RTDC(0)'["L"
GOTO Q
+4 IF $SELECT($DATA(DLAYGO):190-(DLAYGO\1),1:1)
IF DUZ(0)'="@"
IF $DATA(^DIC(190,0,"LAYGO"))
FOR %=1:1
IF DUZ(0)[$EXTRACT(^("LAYGO"),%)
if %>$LENGTH(^("LAYGO"))
GOTO Q
QUIT
+5 if '$DATA(RTSHOW)
GOTO SET
SET Y=RTE
DO NAME^RTB
+6 SET RTRD(1)="Yes^create a new record"
SET RTRD(2)="No^do not create a new record"
SET RTRD(0)="S"
SET RTRD("B")=2
SET RTRD("A")="Do you want to create a new record for '"_Y_"' ? "
DO SET^RTRD
KILL RTRD
SET X=$EXTRACT(X)
if X="N"!(X="^")
GOTO Q
SET if $DATA(RTTY)
DO TYPE1^RTDPA1
IF '$DATA(RTTY)
SET RTTY=+$PIECE(RTAPL,"^",10)
if '$DATA(^DIC(195.2,RTTY,0))
DO TYPE^RTDPA1
IF $DATA(^DIC(195.2,RTTY,0))
SET Y=RTTY
DO TYPE1^RTUTL
if $DATA(RTTY)
DO TYPE1^RTDPA1
KILL RTTY
+1 if $DATA(RT)
GOTO FIND
GOTO Q
+2 ;
NUM IF $DATA(^RT(Y,0))
IF $SELECT('$DATA(RTSN):1,RTSN=+$PIECE(^RT(Y,0),"^",2):1,1:0)
DO SCR
IF Y
SET RT=Y
SET Y=$PIECE(^RT(RT,0),"^")
IF RTDC(0)["E"
DO NAME^RTB
WRITE " ",Y," "
SET Y=RT
XECUTE ^DD(190,0,"ID","WRITE")
+1 if '$DATA(RT)
GOTO Q
+2 ;
RTC SET RTC=1
SET (RTY(1),^DISV($SELECT($DATA(DUZ)'[0:DUZ,1:0),"^RT("))=RT
+1 SET Y=RT_"^"_$PIECE(^RT(RT,0),"^")
if RTDC(0)["Z"
SET Y(0)=^(0)
Q IF '$DATA(RT)
if RTXR'["?"&(RTDC(0)["Q")
WRITE *7," ??"
if RTDC(0)["A"
GOTO ASK
Q1 if '$DATA(RT)
SET Y=-1
SET X=RTXR
KILL RTXR,RTE,RTSN,RT1,RTS,DIC,RTDC
QUIT
+1 ;
CHAR SET C=0
SET Z="0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ-. $/+%"
FOR I=1:1:$LENGTH(W)
SET Y=$FIND(Z,$EXTRACT(W,I))-2
if Y<0
QUIT
SET C=C+Y
+1 SET C=$SELECT(Y'<0:$EXTRACT(Z,(C#43)+1),1:"")
KILL Z
QUIT
+2 ;
BCINVLD if Y<0!(C=$EXTRACT(X,$LENGTH(X)))
QUIT
+1 NEW Y
+2 SET Y=$PIECE(W,"/",2)
if '$DATA(^RT(Y,0))
QUIT
+3 if $PIECE(W,"/",1)'=$PIECE(^RT(Y,0),U,2)
QUIT
+4 IF $DATA(^RT("AOLDBC",W))
SET $PIECE(X,"/",2)=$ORDER(^RT("AOLDBC",W,0))_C
QUIT
+5 IF $DATA(^RT(Y,0))
IF $SELECT('$DATA(RTSN):1,RTSN=+$PIECE(^(0),"^",2):1,1:0)
Begin DoDot:1
+6 WRITE !,?9,"NAME:"
SET RT=Y
SET Y=$PIECE(^RT(RT,0),"^")
IF RTDC(0)["E"
DO NAME^RTB
WRITE " ",Y," "
SET Y=RT
XECUTE ^DD(190,0,"ID","WRITE")
+7 WRITE !,?3,*7,"...Please verify the Patient Information.",!?3,*7,"...The BAR CODE ",X," does not match the system.",!,?3,*7,"...Is this the correct Patient?"
+8 NEW %
SET %=2
DO YN^DICN
+9 IF %=1
NEW DIE,DR,DA
SET DIE="^RT("
SET DA=Y
SET DR="300////"_W
DO ^DIE
SET X=W_C
WRITE @IOF,"Select Record:"
End DoDot:1
+10 QUIT
+11 ;
BOR KILL DIC
SET DIC="^RTV(195.9,"
SET DIC("A")="Select Borrower: "
SET DIC(0)="IEMLQ"
SET DIC("DR")="3////"_+RTAPL
SET DIC("S")="I $P(^(0),U,3)="_+RTAPL
DO ^DIC
KILL DIC
IF Y<0
if RTDC(0)["A"
GOTO ASK
GOTO Q1
+1 if $DATA(RTB)
SET RTZZ("RTB")=RTB
SET RTZZ("RTSEL")=RTSEL
KILL RTB
+2 SET RTB=+Y
SET RTASK=""
SET RTSEL=$SELECT(RTSEL["S":"S",1:"")
DO START^RTRPT2
if $DATA(RTZZ("RTB"))
SET RTB=RTZZ("RTB")
SET RTSEL=RTZZ("RTSEL")
KILL RTZZ
IF '$DATA(RTY)
if RTDC(0)["A"
GOTO ASK
GOTO Q1
+3 IF RTC=1
IF $DATA(RTY(1))
SET RT=+RTY(1)
GOTO RTC
+4 GOTO Q1
+5 ;
SCR IF $DATA(^DD(190,0,"SCR"))
SET S=^("SCR")
IF $DATA(^RT(Y,0))
XECUTE S
if '$TEST
SET Y=0
KILL S
+1 IF Y
IF $DATA(RTDC("S"))
IF $DATA(^RT(Y,0))
XECUTE RTDC("S")
if '$TEST
SET Y=0
+2 QUIT
+3 ;
BC ; called from 7.5 node of RECORDS file for pre-look-up massage
+1 ; picks up IEN for consolidated sites based on "AOLDBC" x-ref
+2 NEW RTOLD,W,C
+3 SET W=$EXTRACT(X,1,$LENGTH(X)-1)
SET RTOLD=$ORDER(^RT("AOLDBC",W,0))
+4 DO CHAR
+5 IF Y
IF C=$EXTRACT(X,$LENGTH(X))
SET X="`"_$SELECT('RTOLD:+$PIECE(X,"/",2),1:RTOLD)
+6 QUIT
+7 ;
BCDFN ; called from 7.5 node of PATIENT file for pre-look-up massage
+1 ; picks up IEN for consolidated sites based on "AOLDBC" x-ref
+2 ; of RECORDS file #190.
+3 NEW RTOLD,W,C,IEN,DFN
+4 SET W=$EXTRACT(X,1,$LENGTH(X)-1)
SET RTOLD=$ORDER(^RT("AOLDBC",W,0))
+5 DO CHAR
+6 IF Y
IF C=$EXTRACT(X,$LENGTH(X))
Begin DoDot:1
+7 SET X="`"_$SELECT('RTOLD:+$PIECE(X,"/",2),1:RTOLD)
+8 SET IEN=$PIECE(X,"`",2)
+9 if 'IEN
QUIT
+10 SET DFN=$PIECE($GET(^RT(IEN,0)),U,9)
+11 if DFN
SET X="`"_DFN
End DoDot:1
+12 QUIT