- RA97PST ;;HINES/RVD Post-init for BI-RADS and File 79.4 ; 10/10/08
- ;;5.0;Radiology/Nuclear Medicine;**97**;Mar 16, 1998;Build 6
- ; This is the post-install routine for patch RA*5.0*97
- ;
- ; Supported IA's
- ; BMES^XPDUTL = 10141
- ; KSP^XUPARAM = 2541
- ; UPDATE^DIE = 2053
- ; GET1^DIQ = 2056
- ; ^XMD = 10070
- ;
- ; Private IA's
- ; Set Identifier "WRITE" node = 5418
- ; Insert "I" in ^RA(78.3,0), piece 2 = 5419
- ;
- ;1. Add records to file 78.3
- ; If there are no IENs 1100 thru 1106 and 1200 thru 1202
- ; then this routine will add records to file #78.3 using
- ; these IENs and set the 3rd piece of ^RA(78.3,0) to the
- ; highest IEN under IEN 999.
- ;
- ;2. Set the Identifier "WRITE" node for file 78.3's field 6
- ;
- ;3. Insert "I" into ^RA(78.3,0), piece 2, after file number
- Q
- CRE ;create BI-RADS entry in file 78.3
- I '$D(DUZ)#2 D BMES^XPDUTL("*** Missing DUZ. Post-init not done. ***") Q
- N RAIEN,RALEX,RAERR,RA,RAI,RAFLG,RAFDA,RAFAC,RANXT,RAD,RAPA,RAPAPG
- N RA1,RA2,RA3,RAAA,RACT,RATXT,RAX
- D BMES^XPDUTL("*** ADDING BI-RADS to file #78.3.")
- D BIR^RA97PST1("MAMMOGRAM",.RA,"","BIR","MQSA","MAMMOGRAPHY ASSESSMENT CATEGORIES")
- ;check to see if the facility has records within the
- ;1100 thru 1106 and 1200 thru 1202 IEN range within file #78.3,
- ;the DIAGNOSTIC CODES file.
- ;If there are, proceed with the install any way
- ;but:
- ;1) DO NOT alter the data (change pointers) in the file at the facility
- ;2) Send an email to an Outlook mail group identifying the facility
- ; where the conflict occurs.
- ;If there is no conflict, then add the IEN records to file 78.3
- ;RAFLG=1 means a record already exist in file 78.3 for the
- ;range 1100 thru 1106 and 1200 thru 1202.
- S RAFLG=0,RANXT=0
- S RACT=0 ;counts number of successfully added records
- ;
- ;example:
- ; check range 1100 thru 1106 and build RAD array
- ; ra(3)="84^Benign ^Category 2" <-- in
- ;rad(1102)="84^Benign ^CATEGORY 2" <-- out
- ;
- F RAI=1100:1:1106 D Q:RAFLG=1
- .S RANXT=$O(RA(RANXT))
- .I $D(^RA(78.3,RAI,0)) S RAFLG=1 Q
- .S RAD(RAI)=RA(RANXT)
- .S $P(RAD(RAI),U,3)=$$UP^XLFSTR($P(RAD(RAI),U,3))
- .;remove trailing blank from piece 2
- .S RAX=$P(RAD(RAI),U,2),RA2=$L(RAX)
- .S:$E(RAX,RA2)=" " $P(RAD(RAI),U,2)=$E(RAX,1,RA2-1)
- .Q
- ; check range 1200 thru 1202
- I 'RAFLG F RAI=1200:1:1202 D Q:RAFLG=1
- .I $D(^RA(78.3,RAI,0)) S RAFLG=1 Q
- .Q
- ;
- ;if RAFLG=1 email Outlook mail group, skip to ID section
- I RAFLG=1 D G ID
- .S RAFAC=$$GET1^DIQ(4,+$$KSP^XUPARAM("INST"),.01)
- .N XMDUZ,XMSUB,XMTEXT,XMY,XMZ S XMDUZ=.5
- .S RATXT(1)=RAFAC_" has a conflict with one or more IENS in file 78.3,"
- .S RATXT(2)="DIAGNOSTIC CODES, in the range 1100-1106 and 1200-1202."
- .S XMSUB="DIAGNOSTIC CODES file IEN issue @ "_RAFAC,XMTEXT="RATXT("
- .S XMY(DUZ)="" ;send Vista email of problem to the patch installer
- .; Define Outlook mail group to receive email of problem
- .S XMY("VAOITVHITRadiologyFacilityLevelApplicationIssues@domain.ext")=""
- .NEW DIFROM
- .D ^XMD,BMES^XPDUTL(.RATXT)
- .Q
- ;
- ; Set up RAAA() for the Abdominal Aortic Aneurysm codes
- ;raaa(IEN file 78.3)=field .01^field 2^fields 3 and 4
- F RAI=1:1 S RAX=$T(AAACODE+RAI) Q:RAX="" D
- .S RAX=$P(RAX,";;",2) ;redefine RAX
- .S RA1=$P(RAX,U,1),RA2=$P(RAX,U,2),RA3=$P(RAX,U,3)
- .S:RA2=1 $P(RAAA(RA1),U,1)=RA3
- .S:RA2=2 $P(RAAA(RA1),U,2)=RA3
- .S:RA2=3 $P(RAAA(RA1),U,3)=RA3
- .Q
- ;
- ;Add the BI-RADS codes to file 78.3
- D
- .S RAI=0 F S RAI=$O(RAD(RAI)) Q:RAI="" D
- ..S RAPA=$P($P(RAD(RAI),U,3),"CATEGORY ",2)
- ..;categories 0,3,4,5,6 have alerts
- ..S RAPAPG="n" S:"^0^3^4^5^6^"[("^"_RAPA_"^") RAPAPG="y"
- ..S RAFDA(78.3,"+1,",.01)="BI-RADS "_$P(RAD(RAI),U,3)
- ..S RAFDA(78.3,"+1,",2)=$E($P(RAD(RAI),U,2),1,80)
- ..S RAFDA(78.3,"+1,",3)=$$UP^XLFSTR(RAPAPG)
- ..S RAFDA(78.3,"+1,",4)=RAPAPG
- ..S RAFDA(78.3,"+1,",6)=$P(RAD(RAI),U,1)
- ..S RAIEN(1)=RAI
- ..D UPDATE^DIE("","RAFDA","RAIEN","RAERR")
- ..I $D(RAERR)#2 D
- ...S RATXT(1)="",RATXT(2)="Error adding "_$P(RAD(RAI),U,3)_" to the"
- ...S RATXT(3)="local DIAGNOSTIC CODES file #78.3." D BMES^XPDUTL(.RATXT)
- ..E S RACT=RACT+1
- ..K RAFDA,RAIEN,RAERR
- ..Q
- .Q
- ;
- ; Add the AAA codes to file 78.3
- D
- .S RA1=0 F S RA1=$O(RAAA(RA1)) Q:RA1="" D
- ..S RAPAPG=$P(RAAA(RA1),U,3)
- ..S RAFDA(78.3,"+1,",.01)=$P(RAAA(RA1),U,1)
- ..S RAFDA(78.3,"+1,",2)=$P(RAAA(RA1),U,2)
- ..S RAFDA(78.3,"+1,",3)=$$UP^XLFSTR(RAPAPG)
- ..S RAFDA(78.3,"+1,",4)=RAPAPG
- ..S RAIEN(1)=RA1
- ..D UPDATE^DIE("","RAFDA","RAIEN","RAERR")
- ..I $D(RAERR)#2 D
- ...S RATXT(1)=""
- ...S RATXT(2)="Error adding "_$P(RAAA(RA1),U,1)_" to the"
- ...S RATXT(3)="local DIAGNOSTIC CODES file #78.3." D BMES^XPDUTL(.RATXT)
- ..E S RACT=RACT+1
- ..K RAFDA,RAIEN,RAERR
- K RATXT
- S RATXT(1)=""
- S RATXT(2)="*** "_RACT_" of 10 BI-RADS and Abdominal Aortic Aneurysm codes"
- S RATXT(3)="have been successfully added to the DIAGNOSTIC CODES file #78.3. ***"
- D BMES^XPDUTL(.RATXT)
- ;put 3rd piece of ^RA(78.3,0) to highest value but under 999
- S RA1=$O(^RA(78.3,999),-1)
- S $P(^RA(78.3,0),U,3)=RA1
- ID ;set Identifier "WRITE" node and insert "I"
- I '$D(^DD(78.3,0,"ID","WRITE")) D
- .S ^DD(78.3,0,"ID","WRITE")="D EN^DDIOL($$EN1^RABIRAD,"""",""?33"")"
- .D BMES^XPDUTL("*** Identifier ""WRITE"" has been added to file #78.3.")
- ; set "I" after file number in ^RA(78.3,0)
- S RA1=$P(^RA(78.3,0),U,2) I RA1=78.3 D
- .S $P(^RA(78.3,0),U,2)=RA1_"I"
- .D BMES^XPDUTL("*** ""I"" has been inserted to ^RA(78.3,0).")
- Q
- AAACODE ; Abdominal Aortic Aneurysm codes
- ;;1200^1^ABDOMINAL AORTIC ANEURYSM NOT PRESENT
- ;;1200^2^The maximum width of the infrarenal aorta is less than three centimeters.
- ;;1200^3^n
- ;;1201^1^ABDOMINAL AORTIC ANEURYSM PRESENT
- ;;1201^2^The maximum width of the infrarenal aorta is at least three centimeters.
- ;;1201^3^y
- ;;1202^1^DOES NOT SATISFY SCREEN FOR AAA
- ;;1202^2^Exam is not technically adequate for AAA screening.
- ;;1202^3^n
- --- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HRA97PST 5971 printed Mar 13, 2025@21:38:24 Page 2
- RA97PST ;;HINES/RVD Post-init for BI-RADS and File 79.4 ; 10/10/08
- +1 ;;5.0;Radiology/Nuclear Medicine;**97**;Mar 16, 1998;Build 6
- +2 ; This is the post-install routine for patch RA*5.0*97
- +3 ;
- +4 ; Supported IA's
- +5 ; BMES^XPDUTL = 10141
- +6 ; KSP^XUPARAM = 2541
- +7 ; UPDATE^DIE = 2053
- +8 ; GET1^DIQ = 2056
- +9 ; ^XMD = 10070
- +10 ;
- +11 ; Private IA's
- +12 ; Set Identifier "WRITE" node = 5418
- +13 ; Insert "I" in ^RA(78.3,0), piece 2 = 5419
- +14 ;
- +15 ;1. Add records to file 78.3
- +16 ; If there are no IENs 1100 thru 1106 and 1200 thru 1202
- +17 ; then this routine will add records to file #78.3 using
- +18 ; these IENs and set the 3rd piece of ^RA(78.3,0) to the
- +19 ; highest IEN under IEN 999.
- +20 ;
- +21 ;2. Set the Identifier "WRITE" node for file 78.3's field 6
- +22 ;
- +23 ;3. Insert "I" into ^RA(78.3,0), piece 2, after file number
- +24 QUIT
- CRE ;create BI-RADS entry in file 78.3
- +1 IF '$DATA(DUZ)#2
- DO BMES^XPDUTL("*** Missing DUZ. Post-init not done. ***")
- QUIT
- +2 NEW RAIEN,RALEX,RAERR,RA,RAI,RAFLG,RAFDA,RAFAC,RANXT,RAD,RAPA,RAPAPG
- +3 NEW RA1,RA2,RA3,RAAA,RACT,RATXT,RAX
- +4 DO BMES^XPDUTL("*** ADDING BI-RADS to file #78.3.")
- +5 DO BIR^RA97PST1("MAMMOGRAM",.RA,"","BIR","MQSA","MAMMOGRAPHY ASSESSMENT CATEGORIES")
- +6 ;check to see if the facility has records within the
- +7 ;1100 thru 1106 and 1200 thru 1202 IEN range within file #78.3,
- +8 ;the DIAGNOSTIC CODES file.
- +9 ;If there are, proceed with the install any way
- +10 ;but:
- +11 ;1) DO NOT alter the data (change pointers) in the file at the facility
- +12 ;2) Send an email to an Outlook mail group identifying the facility
- +13 ; where the conflict occurs.
- +14 ;If there is no conflict, then add the IEN records to file 78.3
- +15 ;RAFLG=1 means a record already exist in file 78.3 for the
- +16 ;range 1100 thru 1106 and 1200 thru 1202.
- +17 SET RAFLG=0
- SET RANXT=0
- +18 ;counts number of successfully added records
- SET RACT=0
- +19 ;
- +20 ;example:
- +21 ; check range 1100 thru 1106 and build RAD array
- +22 ; ra(3)="84^Benign ^Category 2" <-- in
- +23 ;rad(1102)="84^Benign ^CATEGORY 2" <-- out
- +24 ;
- +25 FOR RAI=1100:1:1106
- Begin DoDot:1
- +26 SET RANXT=$ORDER(RA(RANXT))
- +27 IF $DATA(^RA(78.3,RAI,0))
- SET RAFLG=1
- QUIT
- +28 SET RAD(RAI)=RA(RANXT)
- +29 SET $PIECE(RAD(RAI),U,3)=$$UP^XLFSTR($PIECE(RAD(RAI),U,3))
- +30 ;remove trailing blank from piece 2
- +31 SET RAX=$PIECE(RAD(RAI),U,2)
- SET RA2=$LENGTH(RAX)
- +32 if $EXTRACT(RAX,RA2)=" "
- SET $PIECE(RAD(RAI),U,2)=$EXTRACT(RAX,1,RA2-1)
- +33 QUIT
- End DoDot:1
- if RAFLG=1
- QUIT
- +34 ; check range 1200 thru 1202
- +35 IF 'RAFLG
- FOR RAI=1200:1:1202
- Begin DoDot:1
- +36 IF $DATA(^RA(78.3,RAI,0))
- SET RAFLG=1
- QUIT
- +37 QUIT
- End DoDot:1
- if RAFLG=1
- QUIT
- +38 ;
- +39 ;if RAFLG=1 email Outlook mail group, skip to ID section
- +40 IF RAFLG=1
- Begin DoDot:1
- +41 SET RAFAC=$$GET1^DIQ(4,+$$KSP^XUPARAM("INST"),.01)
- +42 NEW XMDUZ,XMSUB,XMTEXT,XMY,XMZ
- SET XMDUZ=.5
- +43 SET RATXT(1)=RAFAC_" has a conflict with one or more IENS in file 78.3,"
- +44 SET RATXT(2)="DIAGNOSTIC CODES, in the range 1100-1106 and 1200-1202."
- +45 SET XMSUB="DIAGNOSTIC CODES file IEN issue @ "_RAFAC
- SET XMTEXT="RATXT("
- +46 ;send Vista email of problem to the patch installer
- SET XMY(DUZ)=""
- +47 ; Define Outlook mail group to receive email of problem
- +48 SET XMY("VAOITVHITRadiologyFacilityLevelApplicationIssues@domain.ext")=""
- +49 NEW DIFROM
- +50 DO ^XMD
- DO BMES^XPDUTL(.RATXT)
- +51 QUIT
- End DoDot:1
- GOTO ID
- +52 ;
- +53 ; Set up RAAA() for the Abdominal Aortic Aneurysm codes
- +54 ;raaa(IEN file 78.3)=field .01^field 2^fields 3 and 4
- +55 FOR RAI=1:1
- SET RAX=$TEXT(AAACODE+RAI)
- if RAX=""
- QUIT
- Begin DoDot:1
- +56 ;redefine RAX
- SET RAX=$PIECE(RAX,";;",2)
- +57 SET RA1=$PIECE(RAX,U,1)
- SET RA2=$PIECE(RAX,U,2)
- SET RA3=$PIECE(RAX,U,3)
- +58 if RA2=1
- SET $PIECE(RAAA(RA1),U,1)=RA3
- +59 if RA2=2
- SET $PIECE(RAAA(RA1),U,2)=RA3
- +60 if RA2=3
- SET $PIECE(RAAA(RA1),U,3)=RA3
- +61 QUIT
- End DoDot:1
- +62 ;
- +63 ;Add the BI-RADS codes to file 78.3
- +64 Begin DoDot:1
- +65 SET RAI=0
- FOR
- SET RAI=$ORDER(RAD(RAI))
- if RAI=""
- QUIT
- Begin DoDot:2
- +66 SET RAPA=$PIECE($PIECE(RAD(RAI),U,3),"CATEGORY ",2)
- +67 ;categories 0,3,4,5,6 have alerts
- +68 SET RAPAPG="n"
- if "^0^3^4^5^6^"[("^"_RAPA_"^")
- SET RAPAPG="y"
- +69 SET RAFDA(78.3,"+1,",.01)="BI-RADS "_$PIECE(RAD(RAI),U,3)
- +70 SET RAFDA(78.3,"+1,",2)=$EXTRACT($PIECE(RAD(RAI),U,2),1,80)
- +71 SET RAFDA(78.3,"+1,",3)=$$UP^XLFSTR(RAPAPG)
- +72 SET RAFDA(78.3,"+1,",4)=RAPAPG
- +73 SET RAFDA(78.3,"+1,",6)=$PIECE(RAD(RAI),U,1)
- +74 SET RAIEN(1)=RAI
- +75 DO UPDATE^DIE("","RAFDA","RAIEN","RAERR")
- +76 IF $DATA(RAERR)#2
- Begin DoDot:3
- +77 SET RATXT(1)=""
- SET RATXT(2)="Error adding "_$PIECE(RAD(RAI),U,3)_" to the"
- +78 SET RATXT(3)="local DIAGNOSTIC CODES file #78.3."
- DO BMES^XPDUTL(.RATXT)
- End DoDot:3
- +79 IF '$TEST
- SET RACT=RACT+1
- +80 KILL RAFDA,RAIEN,RAERR
- +81 QUIT
- End DoDot:2
- +82 QUIT
- End DoDot:1
- +83 ;
- +84 ; Add the AAA codes to file 78.3
- +85 Begin DoDot:1
- +86 SET RA1=0
- FOR
- SET RA1=$ORDER(RAAA(RA1))
- if RA1=""
- QUIT
- Begin DoDot:2
- +87 SET RAPAPG=$PIECE(RAAA(RA1),U,3)
- +88 SET RAFDA(78.3,"+1,",.01)=$PIECE(RAAA(RA1),U,1)
- +89 SET RAFDA(78.3,"+1,",2)=$PIECE(RAAA(RA1),U,2)
- +90 SET RAFDA(78.3,"+1,",3)=$$UP^XLFSTR(RAPAPG)
- +91 SET RAFDA(78.3,"+1,",4)=RAPAPG
- +92 SET RAIEN(1)=RA1
- +93 DO UPDATE^DIE("","RAFDA","RAIEN","RAERR")
- +94 IF $DATA(RAERR)#2
- Begin DoDot:3
- +95 SET RATXT(1)=""
- +96 SET RATXT(2)="Error adding "_$PIECE(RAAA(RA1),U,1)_" to the"
- +97 SET RATXT(3)="local DIAGNOSTIC CODES file #78.3."
- DO BMES^XPDUTL(.RATXT)
- End DoDot:3
- +98 IF '$TEST
- SET RACT=RACT+1
- +99 KILL RAFDA,RAIEN,RAERR
- End DoDot:2
- End DoDot:1
- +100 KILL RATXT
- +101 SET RATXT(1)=""
- +102 SET RATXT(2)="*** "_RACT_" of 10 BI-RADS and Abdominal Aortic Aneurysm codes"
- +103 SET RATXT(3)="have been successfully added to the DIAGNOSTIC CODES file #78.3. ***"
- +104 DO BMES^XPDUTL(.RATXT)
- +105 ;put 3rd piece of ^RA(78.3,0) to highest value but under 999
- +106 SET RA1=$ORDER(^RA(78.3,999),-1)
- +107 SET $PIECE(^RA(78.3,0),U,3)=RA1
- ID ;set Identifier "WRITE" node and insert "I"
- +1 IF '$DATA(^DD(78.3,0,"ID","WRITE"))
- Begin DoDot:1
- +2 SET ^DD(78.3,0,"ID","WRITE")="D EN^DDIOL($$EN1^RABIRAD,"""",""?33"")"
- +3 DO BMES^XPDUTL("*** Identifier ""WRITE"" has been added to file #78.3.")
- End DoDot:1
- +4 ; set "I" after file number in ^RA(78.3,0)
- +5 SET RA1=$PIECE(^RA(78.3,0),U,2)
- IF RA1=78.3
- Begin DoDot:1
- +6 SET $PIECE(^RA(78.3,0),U,2)=RA1_"I"
- +7 DO BMES^XPDUTL("*** ""I"" has been inserted to ^RA(78.3,0).")
- End DoDot:1
- +8 QUIT
- AAACODE ; Abdominal Aortic Aneurysm codes
- +1 ;;1200^1^ABDOMINAL AORTIC ANEURYSM NOT PRESENT
- +2 ;;1200^2^The maximum width of the infrarenal aorta is less than three centimeters.
- +3 ;;1200^3^n
- +4 ;;1201^1^ABDOMINAL AORTIC ANEURYSM PRESENT
- +5 ;;1201^2^The maximum width of the infrarenal aorta is at least three centimeters.
- +6 ;;1201^3^y
- +7 ;;1202^1^DOES NOT SATISFY SCREEN FOR AAA
- +8 ;;1202^2^Exam is not technically adequate for AAA screening.
- +9 ;;1202^3^n