RAUTL10 ;HISC/CAH,FPT,GJC-Utility Routine ;7/23/97 11:05
;;5.0;Radiology/Nuclear Medicine;**28**;Mar 16, 1998
;
UPDLOC ;Update Pt Loc Info, file 74.4
;RAY3= 0 node of 74.4, RAB= IEN of 74.3, RARDIFN= IEN of 74.4
N RAY I '$D(^RARPT(RARPT,0)) Q
I $P(^RARPT(RARPT,0),U,11) S RAPRTOK=1 Q
S RAI="",RAI1=$S($D(^DPT(RADFN,.1)):^(.1),1:0) S:RAI1="" RAI1=0 S RAI=$O(^DIC(42,"B",RAI1,0)) S:'$D(RABTY) RABTY="ALL"
I '$P(RAY3,U,6),'$P(RAY3,U,8),RAB=$$DQ("FILE ROOM") S RAPRTOK=1 G SET
I $P(RAY3,U,6),$P(RAY3,U,6)=RAI S RAPRTOK=1 G SET
I $P(RAY3,U,8),'RAI S RAPRTOK=1 G SET
I $P(RAY3,U,6),'RAI S $P(RAY3,U,6)="" S RAY=$$DQ("FILE ROOM") D:'$D(RAFL) UP2(0) S:'RAY RAPRTOK=1 S:RAY=RAB&((RAI1=RABTY)!(RABTY="ALL")) RAPRTOK=1 G SET
I $P(RAY3,U,6),$P(RAY3,U,6)'=RAI S $P(RAY3,U,6)=RAI D:'$D(RAFL) UP2(1) S:RAI1=RABTY!(RABTY="ALL") RAPRTOK=1 G SET
I $P(RAY3,U,8),RAI S $P(RAY3,U,8)="",$P(RAY3,U,6)=RAI S RAY=$$DQ("WARD REPORTS") D:'$D(RAFL) UP2(2) S:RAY=RAB!('RAY) RAPRTOK=1
SET I $D(RAPRTF),$D(RAPRTOK) S $P(^RARPT(RARPT,0),U,11)=DT
K RAI,RAI1 Q
;
UP2(RAX) ;update file - 74.4
;INPUT: RAX (required)
; If RAX=0, inpt to outpt/RAX=1, ward transfer/RAX=2, outpt to inpt
;OUTPUT: If being called from RARTST2 and patient has been discharged,
; the variable RARTST2I will be defined and will contain the IEN of
; the altered File Room record in file 74.4.
N RABI,RABTCH,RADQ,DA,DIE,DR,DC S (RADQ("FROM"),RADQ("TO"))=0
S:RAX=0 RADQ("FROM")=$$DQ("WARD REPORTS"),RADQ("TO")=$$DQ("FILE ROOM")
S:RAX=2 RADQ("FROM")=$$DQ("CLINIC REPORTS"),RADQ("TO")=$$DQ("WARD REPORTS")
I RAX'=1 S RABI=0 F S RABI=$O(^RABTCH(74.4,"B",RARPT,RABI)) Q:'RABI S RABTCH=+$P($G(^RABTCH(74.4,RABI,0)),U,11) S:RABTCH=RADQ("FROM") $P(RADQ("FROM"),U,2)=RABI S:RABTCH=RADQ("TO") $P(RADQ("TO"),U,2)=RABI
I RAX=0,$P(RADQ("FROM"),U,2),$P(RADQ("TO"),U,2) S DIK="^RABTCH(74.4,",DA=$P(RADQ("TO"),U,2) D ^DIK K DIK I $D(RARTST2) D
.;If file room entry in file 74.4 was deleted, and this is a discharged
.;patient (i.e. RAX=0), and UPDLOC is being called from RARTST2 (i.e.
.;RARTST2 is defined), set RARTST2I to IEN of remaining 74.4 entry that
.;will be edited below to point to File Room.
.;This fix was added so RARTST2 can properly update 'Date Printed' on
.;the 74.4 entry for File Room for discharged patients. Otherwise,
.;File Room entries would print twice before being removed from queue.
. I $$DQ("FILE ROOM")=$P(RADQ("TO"),U,1),'$D(^RABTCH(74.4,+$P(RADQ("TO"),U,2),0)) S RARTST2I=+$P(RADQ("FROM"),U,2)
I RAX=2,'+RADQ("TO"),$P(RADQ("FROM"),U,2) S DIK="^RABTCH(74.4,",DA=$P(RADQ("FROM"),U,2) D ^DIK K DIK
S DR=$S(+RADQ("TO")&($P(RADQ("FROM"),U,2)):"11////^S X=+RADQ(""TO"")",1:"")
S DIE="^RABTCH(74.4,",DR="I RAX>0 S Y=""@1"";6///@;S Y=""@2"";@1;6////^S X=RAI;@2;S:RAX=0 Y=""@3"" S:RAX=1 Y="""";8///@;@3;S:DA'=$P($G(RADQ(""FROM"")),U,2) Y="""";"_DR
S DA=0 F S DA=$O(^RABTCH(74.4,"B",RARPT,DA)) Q:'DA D LOCK,^DIE L -^RABTCH(74.4,DA,0)
K DA,DIE,DR,DE,DQ Q
DQ(X) ;distr queue
;INPUT: queue name
;OUTPUT: IEN in distr queue (74.3) or 0
S X=+$O(^RABTCH(74.3,"B",X,0))
Q $S('X:0,+$G(^RABTCH(74.3,X,"I")):0,1:X)
LOCK L +^RABTCH(74.4,DA,0):2 I '$T G LOCK
Q
STR70(RA0,RA1,RA2,RA3) ;
S RA0=""
Q:'$O(^RADPT(RA1,"DT",RA2,"P",RA3,"M","B",0))
M RA0=^RADPT(RA1,"DT",RA2,"P",RA3,"M","B")
D STR(.RA0)
Q
STR751(RA0,RAOIFN) ;
S RA0=""
Q:'$O(^RAO(75.1,RAOIFN,"M","B",0))
M RA0=^RAO(75.1,RAOIFN,"M","B")
D STR(.RA0)
Q
STR(RA0) ;
N I S I=""
F S I=$O(RA0(I)) Q:'I S RA0=RA0_I_","
Q
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HRAUTL10 3534 printed Oct 16, 2024@18:40:44 Page 2
RAUTL10 ;HISC/CAH,FPT,GJC-Utility Routine ;7/23/97 11:05
+1 ;;5.0;Radiology/Nuclear Medicine;**28**;Mar 16, 1998
+2 ;
UPDLOC ;Update Pt Loc Info, file 74.4
+1 ;RAY3= 0 node of 74.4, RAB= IEN of 74.3, RARDIFN= IEN of 74.4
+2 NEW RAY
IF '$DATA(^RARPT(RARPT,0))
QUIT
+3 IF $PIECE(^RARPT(RARPT,0),U,11)
SET RAPRTOK=1
QUIT
+4 SET RAI=""
SET RAI1=$SELECT($DATA(^DPT(RADFN,.1)):^(.1),1:0)
if RAI1=""
SET RAI1=0
SET RAI=$ORDER(^DIC(42,"B",RAI1,0))
if '$DATA(RABTY)
SET RABTY="ALL"
+5 IF '$PIECE(RAY3,U,6)
IF '$PIECE(RAY3,U,8)
IF RAB=$$DQ("FILE ROOM")
SET RAPRTOK=1
GOTO SET
+6 IF $PIECE(RAY3,U,6)
IF $PIECE(RAY3,U,6)=RAI
SET RAPRTOK=1
GOTO SET
+7 IF $PIECE(RAY3,U,8)
IF 'RAI
SET RAPRTOK=1
GOTO SET
+8 IF $PIECE(RAY3,U,6)
IF 'RAI
SET $PIECE(RAY3,U,6)=""
SET RAY=$$DQ("FILE ROOM")
if '$DATA(RAFL)
DO UP2(0)
if 'RAY
SET RAPRTOK=1
if RAY=RAB&((RAI1=RABTY)!(RABTY="ALL"))
SET RAPRTOK=1
GOTO SET
+9 IF $PIECE(RAY3,U,6)
IF $PIECE(RAY3,U,6)'=RAI
SET $PIECE(RAY3,U,6)=RAI
if '$DATA(RAFL)
DO UP2(1)
if RAI1=RABTY!(RABTY="ALL")
SET RAPRTOK=1
GOTO SET
+10 IF $PIECE(RAY3,U,8)
IF RAI
SET $PIECE(RAY3,U,8)=""
SET $PIECE(RAY3,U,6)=RAI
SET RAY=$$DQ("WARD REPORTS")
if '$DATA(RAFL)
DO UP2(2)
if RAY=RAB!('RAY)
SET RAPRTOK=1
SET IF $DATA(RAPRTF)
IF $DATA(RAPRTOK)
SET $PIECE(^RARPT(RARPT,0),U,11)=DT
+1 KILL RAI,RAI1
QUIT
+2 ;
UP2(RAX) ;update file - 74.4
+1 ;INPUT: RAX (required)
+2 ; If RAX=0, inpt to outpt/RAX=1, ward transfer/RAX=2, outpt to inpt
+3 ;OUTPUT: If being called from RARTST2 and patient has been discharged,
+4 ; the variable RARTST2I will be defined and will contain the IEN of
+5 ; the altered File Room record in file 74.4.
+6 NEW RABI,RABTCH,RADQ,DA,DIE,DR,DC
SET (RADQ("FROM"),RADQ("TO"))=0
+7 if RAX=0
SET RADQ("FROM")=$$DQ("WARD REPORTS")
SET RADQ("TO")=$$DQ("FILE ROOM")
+8 if RAX=2
SET RADQ("FROM")=$$DQ("CLINIC REPORTS")
SET RADQ("TO")=$$DQ("WARD REPORTS")
+9 IF RAX'=1
SET RABI=0
FOR
SET RABI=$ORDER(^RABTCH(74.4,"B",RARPT,RABI))
if 'RABI
QUIT
SET RABTCH=+$PIECE($GET(^RABTCH(74.4,RABI,0)),U,11)
if RABTCH=RADQ("FROM")
SET $PIECE(RADQ("FROM"),U,2)=RABI
if RABTCH=RADQ("TO")
SET $PIECE(RADQ("TO"),U,2)=RABI
+10 IF RAX=0
IF $PIECE(RADQ("FROM"),U,2)
IF $PIECE(RADQ("TO"),U,2)
SET DIK="^RABTCH(74.4,"
SET DA=$PIECE(RADQ("TO"),U,2)
DO ^DIK
KILL DIK
IF $DATA(RARTST2)
Begin DoDot:1
+11 ;If file room entry in file 74.4 was deleted, and this is a discharged
+12 ;patient (i.e. RAX=0), and UPDLOC is being called from RARTST2 (i.e.
+13 ;RARTST2 is defined), set RARTST2I to IEN of remaining 74.4 entry that
+14 ;will be edited below to point to File Room.
+15 ;This fix was added so RARTST2 can properly update 'Date Printed' on
+16 ;the 74.4 entry for File Room for discharged patients. Otherwise,
+17 ;File Room entries would print twice before being removed from queue.
+18 IF $$DQ("FILE ROOM")=$PIECE(RADQ("TO"),U,1)
IF '$DATA(^RABTCH(74.4,+$PIECE(RADQ("TO"),U,2),0))
SET RARTST2I=+$PIECE(RADQ("FROM"),U,2)
End DoDot:1
+19 IF RAX=2
IF '+RADQ("TO")
IF $PIECE(RADQ("FROM"),U,2)
SET DIK="^RABTCH(74.4,"
SET DA=$PIECE(RADQ("FROM"),U,2)
DO ^DIK
KILL DIK
+20 SET DR=$SELECT(+RADQ("TO")&($PIECE(RADQ("FROM"),U,2)):"11////^S X=+RADQ(""TO"")",1:"")
+21 SET DIE="^RABTCH(74.4,"
SET DR="I RAX>0 S Y=""@1"";6///@;S Y=""@2"";@1;6////^S X=RAI;@2;S:RAX=0 Y=""@3"" S:RAX=1 Y="""";8///@;@3;S:DA'=$P($G(RADQ(""FROM"")),U,2) Y="""";"_DR
+22 SET DA=0
FOR
SET DA=$ORDER(^RABTCH(74.4,"B",RARPT,DA))
if 'DA
QUIT
DO LOCK
DO ^DIE
LOCK -^RABTCH(74.4,DA,0)
+23 KILL DA,DIE,DR,DE,DQ
QUIT
DQ(X) ;distr queue
+1 ;INPUT: queue name
+2 ;OUTPUT: IEN in distr queue (74.3) or 0
+3 SET X=+$ORDER(^RABTCH(74.3,"B",X,0))
+4 QUIT $SELECT('X:0,+$GET(^RABTCH(74.3,X,"I")):0,1:X)
LOCK LOCK +^RABTCH(74.4,DA,0):2
IF '$TEST
GOTO LOCK
+1 QUIT
STR70(RA0,RA1,RA2,RA3) ;
+1 SET RA0=""
+2 if '$ORDER(^RADPT(RA1,"DT",RA2,"P",RA3,"M","B",0))
QUIT
+3 MERGE RA0=^RADPT(RA1,"DT",RA2,"P",RA3,"M","B")
+4 DO STR(.RA0)
+5 QUIT
STR751(RA0,RAOIFN) ;
+1 SET RA0=""
+2 if '$ORDER(^RAO(75.1,RAOIFN,"M","B",0))
QUIT
+3 MERGE RA0=^RAO(75.1,RAOIFN,"M","B")
+4 DO STR(.RA0)
+5 QUIT
STR(RA0) ;
+1 NEW I
SET I=""
+2 FOR
SET I=$ORDER(RA0(I))
if 'I
QUIT
SET RA0=RA0_I_","
+3 QUIT