- RAMAINU ;HISC/GJC-Radiology Utility File Maintenance (utility)
- ;;5.0;Radiology/Nuclear Medicine;**45**;Mar 16, 1998
- ;Note: new routine with the release of RA*5*45
- ;
- CPT(DA,RAX) ;Ask for CPT Code when the 'Procedure Enter/Edit' option
- ;is exercised. Called from input template: RA PROCEDURE EDIT
- ;Input: DA=ien of new record being edited & RAX=procedure name
- N DIR,DIROUT,DIRUT,DTOUT,DUOUT,RAFDA,RAYN,X,Y S RAYN=0
- F D Q:+RAYN!($D(DIRUT)#2)
- .K X,Y S DIR(0)="71,9" D ^DIR Q:$D(DIRUT)#2
- .;Y=N^S where N=record ien & S=.01 value of the record
- .W !!,"Note: If an erroneous CPT Code is accepted it cannot be changed; the",!,"procedure must be inactivated."
- .W !!,"Are you adding '"_$P(Y,U,2)_"' as the CPT Code for the new Rad/Nuc Med Procedure",!,"'"_RAX_"'? NO// "
- .R RAYN:DTIME
- .I '$T!(RAYN["^") S RAYN=-1 Q
- .S RAYN=$E(RAYN) S:RAYN="" RAYN="N"
- .I "YyNn"'[RAYN W !?3,"Enter 'Y' to accept the CPT Code, or 'N' to reject the CPT Code or '^' to",!?3,"exit without selecting a CPT Code."
- .I W !?5,"Note: If an erroneous CPT Code is accepted it cannot be changed; the",!?5,"procedure must be inactivated."
- .S:"Yy"[RAYN RAYN="1^Y"
- .S:"Nn"[RAYN RAYN=0
- .Q
- I $P(RAYN,U,2)="Y" S RAFDA(71,DA_",",9)=$P(Y,U) D FILE^DIE("","RAFDA")
- Q
- ;
- TRKCMB(DA,RACMB4) ;Contrast Medium/Media is used with this procedure.
- ;Track the editing of this data. This subroutine saves off the 'before'
- ;values in a local variable. The 'before' and 'after' values will be
- ;compared. If they differ, then the 'before' value will be filed in
- ;the audit log.
- ; input: DA=IEN of the Rad/Nuc Med Procedure record
- ;output: RACMB4=CM definitions for this procedure before edit
- N I S I=0,RACMB4=""
- F S I=$O(^RAMIS(71,DA,"CM",I)) Q:'I D
- .S RACMB4=RACMB4_$P($G(^RAMIS(71,DA,"CM",I,0)),U)
- .Q
- Q
- ;
- TRK70CMB(RADFN,RADTI,RACNI,RACMB4) ;Contrast Medium/Media is used with
- ;this procedure. Track the editing of this data. This subroutine saves
- ;off the 'before' values in a local variable. The 'before' and 'after'
- ;values will be compared. If they differ, then the 'before' value will
- ;be filed in the audit log.
- ;input: RADFN=DFN of the Rad/Nuc Med patient (file 2)
- ; RADTI=exam date/time (inverse)
- ; RACNI=ien of exam record (examinations sub-file 70.03)
- ;output: RACMB4=CM definitions for this procedure before edit
- N I S I=0,RACMB4=""
- F S I=$O(^RADPT(RADFN,"DT",RADTI,"P",RACNI,"CM",I)) Q:'I D
- .S RACMB4=RACMB4_$P($G(^RADPT(RADFN,"DT",RADTI,"P",RACNI,"CM",I,0)),U)
- .Q
- Q
- ;
- TRKCMA(DA,RATRKCMB,RATRKCMA,RACMDIF) ;Contrast Medium/Media is used with this
- ;procedure. Tracks the editing of this data. This subroutine saves
- ;off the 'before' values.
- ; input: DA=IEN of the Rad/Nuc Med Procedure record
- ; RATRKCMB=CM definitions for this procedure before edit
- ;return: RATRKCMA=CM definitions for this procedure after edit
- ; RACMDIF=if before & after CM values differ, set to 1 else 0
- N I,J S (I,RACMDIF)=0,RATRKCMA=""
- F S I=$O(^RAMIS(71,DA,"CM",I)) Q:'I D
- .S RATRKCMA=RATRKCMA_$P($G(^RAMIS(71,DA,"CM",I,0)),U)
- .Q
- ;
- ;If the before & after values are null, no CM definitions exist.
- I $L(RATRKCMB)=0,$L(RATRKCMA)=0 S RACMDIF=0 Q
- ;
- ;If the before value is null and the after value is not null file
- ;the after value
- I $L(RATRKCMB)=0,($L(RATRKCMA)>0) D Q
- .S RACMDIF=1 D FILEAU^RAMAINU1(DA,RATRKCMA)
- .Q
- ;
- ;If the before value is not null and the after value is null file
- ;the after value (indicates that CM data has been deleted)
- I $L(RATRKCMB)>0,($L(RATRKCMA)=0) D Q
- .S RACMDIF=1 D FILEAU^RAMAINU1(DA,RATRKCMA)
- .Q
- ;
- ;If the before and after values are non-null and the number of
- ;characters differ between strings, store the after value and exit.
- I $L(RATRKCMB)'=$L(RATRKCMA) S RACMDIF=1 D FILEAU^RAMAINU1(DA,RATRKCMA) Q
- ;
- ;If the before and after values have definition (non-null) and are of
- ;the same length, check to see if they have the same characters in
- ;their respective strings (character position not important). Only if
- ;characters differ between the two strings do we file the after data.
- F I=1:1:$L(RATRKCMB) D Q:RACMDIF
- .S J=$E(RATRKCMB,I) S:RATRKCMA'[J RACMDIF=1
- .Q
- D:RACMDIF FILEAU^RAMAINU1(DA,RATRKCMA)
- Q
- ;
- TRK70CMA(RADFN,RADTI,RACNI,RATRKCMB) ;Contrast Medium/Media is used with
- ;this exam.
- ;Tracks the editing of this data. This subroutine saves off the
- ;'before' values.
- ;input: RADFN=DFN of the Rad/Nuc Med patient (file 2)
- ; RADTI=exam date/time (inverse)
- ; RACNI=ien of exam record (examinations sub-file 70.03)
- ; RATRKCMB=the before contrast media definition
- N I,J,K S (I,K)=0,RATRKCMA=""
- F S I=$O(^RADPT(RADFN,"DT",RADTI,"P",RACNI,"CM",I)) Q:'I D
- .S RATRKCMA=RATRKCMA_$P($G(^RADPT(RADFN,"DT",RADTI,"P",RACNI,"CM",I,0)),U)
- .Q
- ;
- ;If the before & after values are null, no CM definitions exist.
- I $L(RATRKCMB)=0,$L(RATRKCMA)=0 Q
- ;
- ;If the before value is null and the after value is not null file
- ;the after value
- I $L(RATRKCMB)=0,($L(RATRKCMA)>0) D AUD70^RAMAINU1(RADFN,RADTI,RACNI,RATRKCMA) Q
- ;
- ;If the before value is not null and the after value is null file
- ;the after value (indicates that CM data has been deleted)
- I $L(RATRKCMB)>0,($L(RATRKCMA)=0) D AUD70^RAMAINU1(RADFN,RADTI,RACNI,RATRKCMA) Q
- ;
- ;If the before and after values are non-null and the number of
- ;characters differ between strings, store the after value and exit.
- I $L(RATRKCMB)'=$L(RATRKCMA) D AUD70^RAMAINU1(RADFN,RADTI,RACNI,RATRKCMA) Q
- ;
- ;If the before and after values have definition (non-null) and are of
- ;the same length, check to see if they have the same characters in
- ;their respective strings (character position not important). Only if
- ;characters differ between the two strings do we file the after data.
- F I=1:1:$L(RATRKCMB) D Q:K
- .S J=$E(RATRKCMB,I) S:RATRKCMA'[J K=1
- .Q
- D:K AUD70^RAMAINU1(RADFN,RADTI,RACNI,RATRKCMA)
- Q
- ;
- PRGCM(DA) ;Purge contrast media data related to an exam when the user
- ;answers 'No' to the 'CONTRAST MEDIA USED?' field (#10) prompt when
- ;'CONTRAST MEDIA USED?' is presented to the user by the 'RA EXAM EDIT'
- ;& 'RA STATUS CHANGE' input templates.
- ;
- ;input: DA=expressed as DA(2), DA(1), & DA IENs for file and sub-files
- ;returns: placeholder for input template
- ;
- I +$O(^RADPT(DA(2),"DT",DA(1),"P",DA,"CM",0)) D
- .W !?3,$C(7),"Deleting contrast media data associated with this exam.",!
- .K ^RADPT(DA(2),"DT",DA(1),"P",DA,"CM") ;'B' xrefs deleted too!
- .Q
- Q "@225"
- ;
- UPXCM(DA,X) ;set the 'CONTRAST MEDIA USED?' (#10) field to 'No' if contrast
- ;media data is not associated with this exam.
- ;called from the 'RA EXAM EDIT' & 'RA STATUS CHANGE' input templates.
- ;
- ;input: DA=expressed as DA(2), DA(1), & DA IENs for file and sub-files
- ; X='Y' for 'Yes', 'N' for 'No'
- ;
- K RASFM S RAIENS=DA_","_DA(1)_","_DA(2)_","
- S RASFM(70.03,RAIENS,10)=X D UPDATE^DIE("","RASFM","RAIENS")
- K RAIENS,RASFM
- Q
- ;
- STUFCM70(DA,RAPRI) ;If the exam record indicates that a contrast medium
- ;or media was used, and the exam record does not identify the CM,
- ;assume the CM definition of the procedure and stuff the exam
- ;record (usually done initially while editing the exam record for the
- ;first time).
- ;
- ;Called from the following input templates:
- ; RA EXAM EDIT & RA STATUS CHANGE
- ;
- ;input: DA array; DA(2)-RADFN, DA(1)-RADTI, & DA-RACNI
- ; RAPRI: IEN of the procedure being performed
- ;
- N I K RAD3,RAIENS,RASFM
- S I=0 F S I=$O(^RAMIS(71,RAPRI,"CM",I)) Q:'I D
- .S RAD3=$O(^RADPT(RADFN,"DT",RADTI,"P",RACNI,"CM",$C(32)),-1)+1
- .S RAIENS="+"_RAD3_","_DA_","_DA(1)_","_DA(2)_","
- .S RASFM(70.3225,RAIENS,.01)=$P($G(^RAMIS(71,RAPRI,"CM",I,0)),U)
- .D UPDATE^DIE("","RASFM","RAD3") K RAD3,RAIENS,RASFM
- .Q
- Q
- ;
- RAMAINU ;HISC/GJC-Radiology Utility File Maintenance (utility)
- +1 ;;5.0;Radiology/Nuclear Medicine;**45**;Mar 16, 1998
- +2 ;Note: new routine with the release of RA*5*45
- +3 ;
- CPT(DA,RAX) ;Ask for CPT Code when the 'Procedure Enter/Edit' option
- +1 ;is exercised. Called from input template: RA PROCEDURE EDIT
- +2 ;Input: DA=ien of new record being edited & RAX=procedure name
- +3 NEW DIR,DIROUT,DIRUT,DTOUT,DUOUT,RAFDA,RAYN,X,Y
- SET RAYN=0
- +4 FOR
- Begin DoDot:1
- +5 KILL X,Y
- SET DIR(0)="71,9"
- DO ^DIR
- IF $DATA(DIRUT)#2
- QUIT
- +6 ;Y=N^S where N=record ien & S=.01 value of the record
- +7 WRITE !!,"Note: If an erroneous CPT Code is accepted it cannot be changed; the",!,"procedure must be inactivated."
- +8 WRITE !!,"Are you adding '"_$PIECE(Y,U,2)_"' as the CPT Code for the new Rad/Nuc Med Procedure",!,"'"_RAX_"'? NO// "
- +9 READ RAYN:DTIME
- +10 IF '$TEST!(RAYN["^")
- SET RAYN=-1
- QUIT
- +11 SET RAYN=$EXTRACT(RAYN)
- IF RAYN=""
- SET RAYN="N"
- +12 IF "YyNn"'[RAYN
- WRITE !?3,"Enter 'Y' to accept the CPT Code, or 'N' to reject the CPT Code or '^' to",!?3,"exit without selecting a CPT Code."
- +13 IF $TEST
- WRITE !?5,"Note: If an erroneous CPT Code is accepted it cannot be changed; the",!?5,"procedure must be inactivated."
- +14 IF "Yy"[RAYN
- SET RAYN="1^Y"
- +15 IF "Nn"[RAYN
- SET RAYN=0
- +16 QUIT
- End DoDot:1
- IF +RAYN!($DATA(DIRUT)#2)
- QUIT
- +17 IF $PIECE(RAYN,U,2)="Y"
- SET RAFDA(71,DA_",",9)=$PIECE(Y,U)
- DO FILE^DIE("","RAFDA")
- +18 QUIT
- +19 ;
- TRKCMB(DA,RACMB4) ;Contrast Medium/Media is used with this procedure.
- +1 ;Track the editing of this data. This subroutine saves off the 'before'
- +2 ;values in a local variable. The 'before' and 'after' values will be
- +3 ;compared. If they differ, then the 'before' value will be filed in
- +4 ;the audit log.
- +5 ; input: DA=IEN of the Rad/Nuc Med Procedure record
- +6 ;output: RACMB4=CM definitions for this procedure before edit
- +7 NEW I
- SET I=0
- SET RACMB4=""
- +8 FOR
- SET I=$ORDER(^RAMIS(71,DA,"CM",I))
- IF 'I
- QUIT
- Begin DoDot:1
- +9 SET RACMB4=RACMB4_$PIECE($GET(^RAMIS(71,DA,"CM",I,0)),U)
- +10 QUIT
- End DoDot:1
- +11 QUIT
- +12 ;
- TRK70CMB(RADFN,RADTI,RACNI,RACMB4) ;Contrast Medium/Media is used with
- +1 ;this procedure. Track the editing of this data. This subroutine saves
- +2 ;off the 'before' values in a local variable. The 'before' and 'after'
- +3 ;values will be compared. If they differ, then the 'before' value will
- +4 ;be filed in the audit log.
- +5 ;input: RADFN=DFN of the Rad/Nuc Med patient (file 2)
- +6 ; RADTI=exam date/time (inverse)
- +7 ; RACNI=ien of exam record (examinations sub-file 70.03)
- +8 ;output: RACMB4=CM definitions for this procedure before edit
- +9 NEW I
- SET I=0
- SET RACMB4=""
- +10 FOR
- SET I=$ORDER(^RADPT(RADFN,"DT",RADTI,"P",RACNI,"CM",I))
- IF 'I
- QUIT
- Begin DoDot:1
- +11 SET RACMB4=RACMB4_$PIECE($GET(^RADPT(RADFN,"DT",RADTI,"P",RACNI,"CM",I,0)),U)
- +12 QUIT
- End DoDot:1
- +13 QUIT
- +14 ;
- TRKCMA(DA,RATRKCMB,RATRKCMA,RACMDIF) ;Contrast Medium/Media is used with this
- +1 ;procedure. Tracks the editing of this data. This subroutine saves
- +2 ;off the 'before' values.
- +3 ; input: DA=IEN of the Rad/Nuc Med Procedure record
- +4 ; RATRKCMB=CM definitions for this procedure before edit
- +5 ;return: RATRKCMA=CM definitions for this procedure after edit
- +6 ; RACMDIF=if before & after CM values differ, set to 1 else 0
- +7 NEW I,J
- SET (I,RACMDIF)=0
- SET RATRKCMA=""
- +8 FOR
- SET I=$ORDER(^RAMIS(71,DA,"CM",I))
- IF 'I
- QUIT
- Begin DoDot:1
- +9 SET RATRKCMA=RATRKCMA_$PIECE($GET(^RAMIS(71,DA,"CM",I,0)),U)
- +10 QUIT
- End DoDot:1
- +11 ;
- +12 ;If the before & after values are null, no CM definitions exist.
- +13 IF $LENGTH(RATRKCMB)=0
- IF $LENGTH(RATRKCMA)=0
- SET RACMDIF=0
- QUIT
- +14 ;
- +15 ;If the before value is null and the after value is not null file
- +16 ;the after value
- +17 IF $LENGTH(RATRKCMB)=0
- IF ($LENGTH(RATRKCMA)>0)
- Begin DoDot:1
- +18 SET RACMDIF=1
- DO FILEAU^RAMAINU1(DA,RATRKCMA)
- +19 QUIT
- End DoDot:1
- QUIT
- +20 ;
- +21 ;If the before value is not null and the after value is null file
- +22 ;the after value (indicates that CM data has been deleted)
- +23 IF $LENGTH(RATRKCMB)>0
- IF ($LENGTH(RATRKCMA)=0)
- Begin DoDot:1
- +24 SET RACMDIF=1
- DO FILEAU^RAMAINU1(DA,RATRKCMA)
- +25 QUIT
- End DoDot:1
- QUIT
- +26 ;
- +27 ;If the before and after values are non-null and the number of
- +28 ;characters differ between strings, store the after value and exit.
- +29 IF $LENGTH(RATRKCMB)'=$LENGTH(RATRKCMA)
- SET RACMDIF=1
- DO FILEAU^RAMAINU1(DA,RATRKCMA)
- QUIT
- +30 ;
- +31 ;If the before and after values have definition (non-null) and are of
- +32 ;the same length, check to see if they have the same characters in
- +33 ;their respective strings (character position not important). Only if
- +34 ;characters differ between the two strings do we file the after data.
- +35 FOR I=1:1:$LENGTH(RATRKCMB)
- Begin DoDot:1
- +36 SET J=$EXTRACT(RATRKCMB,I)
- IF RATRKCMA'[J
- SET RACMDIF=1
- +37 QUIT
- End DoDot:1
- IF RACMDIF
- QUIT
- +38 IF RACMDIF
- DO FILEAU^RAMAINU1(DA,RATRKCMA)
- +39 QUIT
- +40 ;
- TRK70CMA(RADFN,RADTI,RACNI,RATRKCMB) ;Contrast Medium/Media is used with
- +1 ;this exam.
- +2 ;Tracks the editing of this data. This subroutine saves off the
- +3 ;'before' values.
- +4 ;input: RADFN=DFN of the Rad/Nuc Med patient (file 2)
- +5 ; RADTI=exam date/time (inverse)
- +6 ; RACNI=ien of exam record (examinations sub-file 70.03)
- +7 ; RATRKCMB=the before contrast media definition
- +8 NEW I,J,K
- SET (I,K)=0
- SET RATRKCMA=""
- +9 FOR
- SET I=$ORDER(^RADPT(RADFN,"DT",RADTI,"P",RACNI,"CM",I))
- IF 'I
- QUIT
- Begin DoDot:1
- +10 SET RATRKCMA=RATRKCMA_$PIECE($GET(^RADPT(RADFN,"DT",RADTI,"P",RACNI,"CM",I,0)),U)
- +11 QUIT
- End DoDot:1
- +12 ;
- +13 ;If the before & after values are null, no CM definitions exist.
- +14 IF $LENGTH(RATRKCMB)=0
- IF $LENGTH(RATRKCMA)=0
- QUIT
- +15 ;
- +16 ;If the before value is null and the after value is not null file
- +17 ;the after value
- +18 IF $LENGTH(RATRKCMB)=0
- IF ($LENGTH(RATRKCMA)>0)
- DO AUD70^RAMAINU1(RADFN,RADTI,RACNI,RATRKCMA)
- QUIT
- +19 ;
- +20 ;If the before value is not null and the after value is null file
- +21 ;the after value (indicates that CM data has been deleted)
- +22 IF $LENGTH(RATRKCMB)>0
- IF ($LENGTH(RATRKCMA)=0)
- DO AUD70^RAMAINU1(RADFN,RADTI,RACNI,RATRKCMA)
- QUIT
- +23 ;
- +24 ;If the before and after values are non-null and the number of
- +25 ;characters differ between strings, store the after value and exit.
- +26 IF $LENGTH(RATRKCMB)'=$LENGTH(RATRKCMA)
- DO AUD70^RAMAINU1(RADFN,RADTI,RACNI,RATRKCMA)
- QUIT
- +27 ;
- +28 ;If the before and after values have definition (non-null) and are of
- +29 ;the same length, check to see if they have the same characters in
- +30 ;their respective strings (character position not important). Only if
- +31 ;characters differ between the two strings do we file the after data.
- +32 FOR I=1:1:$LENGTH(RATRKCMB)
- Begin DoDot:1
- +33 SET J=$EXTRACT(RATRKCMB,I)
- IF RATRKCMA'[J
- SET K=1
- +34 QUIT
- End DoDot:1
- IF K
- QUIT
- +35 IF K
- DO AUD70^RAMAINU1(RADFN,RADTI,RACNI,RATRKCMA)
- +36 QUIT
- +37 ;
- PRGCM(DA) ;Purge contrast media data related to an exam when the user
- +1 ;answers 'No' to the 'CONTRAST MEDIA USED?' field (#10) prompt when
- +2 ;'CONTRAST MEDIA USED?' is presented to the user by the 'RA EXAM EDIT'
- +3 ;& 'RA STATUS CHANGE' input templates.
- +4 ;
- +5 ;input: DA=expressed as DA(2), DA(1), & DA IENs for file and sub-files
- +6 ;returns: placeholder for input template
- +7 ;
- +8 IF +$ORDER(^RADPT(DA(2),"DT",DA(1),"P",DA,"CM",0))
- Begin DoDot:1
- +9 WRITE !?3,$CHAR(7),"Deleting contrast media data associated with this exam.",!
- +10 ;'B' xrefs deleted too!
- KILL ^RADPT(DA(2),"DT",DA(1),"P",DA,"CM")
- +11 QUIT
- End DoDot:1
- +12 QUIT "@225"
- +13 ;
- UPXCM(DA,X) ;set the 'CONTRAST MEDIA USED?' (#10) field to 'No' if contrast
- +1 ;media data is not associated with this exam.
- +2 ;called from the 'RA EXAM EDIT' & 'RA STATUS CHANGE' input templates.
- +3 ;
- +4 ;input: DA=expressed as DA(2), DA(1), & DA IENs for file and sub-files
- +5 ; X='Y' for 'Yes', 'N' for 'No'
- +6 ;
- +7 KILL RASFM
- SET RAIENS=DA_","_DA(1)_","_DA(2)_","
- +8 SET RASFM(70.03,RAIENS,10)=X
- DO UPDATE^DIE("","RASFM","RAIENS")
- +9 KILL RAIENS,RASFM
- +10 QUIT
- +11 ;
- STUFCM70(DA,RAPRI) ;If the exam record indicates that a contrast medium
- +1 ;or media was used, and the exam record does not identify the CM,
- +2 ;assume the CM definition of the procedure and stuff the exam
- +3 ;record (usually done initially while editing the exam record for the
- +4 ;first time).
- +5 ;
- +6 ;Called from the following input templates:
- +7 ; RA EXAM EDIT & RA STATUS CHANGE
- +8 ;
- +9 ;input: DA array; DA(2)-RADFN, DA(1)-RADTI, & DA-RACNI
- +10 ; RAPRI: IEN of the procedure being performed
- +11 ;
- +12 NEW I
- KILL RAD3,RAIENS,RASFM
- +13 SET I=0
- FOR
- SET I=$ORDER(^RAMIS(71,RAPRI,"CM",I))
- IF 'I
- QUIT
- Begin DoDot:1
- +14 SET RAD3=$ORDER(^RADPT(RADFN,"DT",RADTI,"P",RACNI,"CM",$CHAR(32)),-1)+1
- +15 SET RAIENS="+"_RAD3_","_DA_","_DA(1)_","_DA(2)_","
- +16 SET RASFM(70.3225,RAIENS,.01)=$PIECE($GET(^RAMIS(71,RAPRI,"CM",I,0)),U)
- +17 DO UPDATE^DIE("","RASFM","RAD3")
- KILL RAD3,RAIENS,RASFM
- +18 QUIT
- End DoDot:1
- +19 QUIT
- +20 ;