BWPATCH8 ;IHS/CMI/LAB - BW PATCH 8 ;30-Jun-2003 22:42;PLS
;;2.0;WOMEN'S HEALTH;**8**;MAY 16, 1996
;
;
ENV ; Check for duplicate RACE file entries
; The following line prevents the "Disable Options..." and "Move
; Routines..." questions from being asked during the install.
S XPDENV=1,(XPDDIQ("XPZ1"),XPDDIQ("XPZ2"))=0
N RVAL,IEN,DUP
S RVAL=0 F S RVAL=$O(^DIC(10,"B",RVAL)) Q:RVAL="" D
.S IEN=$O(^DIC(10,"B",RVAL,0))
.S:$O(^DIC(10,"B",RVAL,IEN))>0 DUP=1
D:$G(DUP) MES("THERE ARE DUPLICATE RACE VALUES IN THE RACE FILE!",1)
Q
;
PRE ;
N DIK,DA
S XPDENV=1,(XPDDIQ("XPZ1"),XPDDIQ("XPZ2"))=0
; Set Wise Woman Flag
; If flag =0 the fix in the post-init will not be run.
S @XPDGREF@("WW")=$D(^BWPN(39,0))
; Purge entries in BW General Retrieval Items File
D MES("Preparing BW GENERAL RETRIEVAL ITEMS File for new entries...")
S DIK="^BWGRI("
S DA=0 F S DA=$O(^BWGRI(DA)) Q:'DA D
.D ^DIK
D MES("Preparing BW RACE (NBCCEDP) for updates...")
S DIK="^BWRACE("
S DA=0 F S DA=$O(^BWRACE(DA)) Q:'DA D
.D ^DIK
Q
POST ; Converts (seeds) the new field CDC RESULTS OF PAP TEST (2001) (#.241) based on the existing
; field CDC RESULTS OF PAP TEST (1991) (#.24) (old field name CDC EQUIV SCREENING PAP DX) in
; file BW RESULTS/DIAGNOSIS (#9002086.31) to handle 2001 Bethesda System Categories.
;
N FDA,BWDA,BWDIE,X,Y,TXT,BWRIEN
D MES("Resolving Race File Pointers in BW RACE MAPPINGS (NBCCEDP) File.")
K ^BWRACE("B")
S BWRIEN=0
F S BWRIEN=$O(@XPDGREF@("RACEPTRS",BWRIEN)) Q:BWRIEN<1 D
.S TXT=@XPDGREF@("RACEPTRS",BWRIEN)
.D MES("Processing entry: "_BWRIEN_" = "_TXT)
.S $P(^BWRACE(BWRIEN,0),U)=$O(^DIC(10,"B",TXT,0))
; Re-index "B" x-ref of BW RACE MAPPINGS File
S DIK="^BWRACE(",DIK(1)=".01^B" D ENALL^DIK
;
S BWDA=0
F S BWDA=$O(^BWDIAG(BWDA)) Q:'BWDA D
. S X=+$P(^BWDIAG(BWDA,0),"^",24)
. I X<1 Q
. S Y=$S(X=2:1,X=3:2,X=4:3,X=7:8,X=14:7,1:X)
. S FDA(1,9002086.31,BWDA_",",.241)=Y
. D FILE^DIE("","FDA(1)","BWDIE(1)")
. D CLEAN^DILF
;
; Set Bethesda 1991 (#.51) and 2001 (#.52) start dates in BW SITE file.
; Set MDE version to 4.1 if no value is defined.
S BWDA=0
F S BWDA=$O(^BWSITE(BWDA)) Q:'BWDA D
. S X=$P(^BWSITE(BWDA,0),"^",17)
. I X<1 S X=2910101
. S FDA(2,9002086.02,BWDA_",",.51)=X
. S FDA(2,9002086.02,BWDA_",",.52)=3021001
. S:'$$GET1^DIQ(9002086.02,BWDA,.18,"I") FDA(2,9002086.02,BWDA_",",.18)=41
. D FILE^DIE("","FDA(2)","BWDIE(2)")
. D CLEAN^DILF
; Importing Race into BW Patient File
D MES("Importing Patient Race...")
D START^BWUCVRC
; Add procedure type to existing Wise Woman Procedures if needed
Q:'@XPDGREF@("WW") ;Site has not WW Procedures to correct
D MES("Repairing Wise Woman procedures...")
S BWDA=0
F S BWDA=$O(^BWPCD(BWDA)) Q:'BWDA D
.Q:'$D(^BWPCD(BWDA,4)) ; Not a Wise Woman procedure
.W "."
.I '$P(^BWPCD(BWDA,0),U,4) D
..W ":"
..S $P(^BWPCD(BWDA,0),U,4)=39
Q
; Display message in MSG and optionally set quit flag to QUIT
MES(MSG,QUIT) ;
D BMES^XPDUTL(" "_$G(MSG))
S:$G(QUIT) XPDQUIT=QUIT
Q
; Pre-Transport global for BW RACE file mappings
PRETRAN ;
N IEN,VAL,TXT
S IEN=0
F S IEN=$O(^BWRACE(IEN)) Q:IEN<1 D
.S VAL=$P(^BWRACE(IEN,0),U),TXT=$$GET1^DIQ(10,VAL,.01,"E")
.S @XPDGREF@("RACEPTRS",IEN)=TXT
Q
BWPATCH8 ;IHS/CMI/LAB - BW PATCH 8 ;30-Jun-2003 22:42;PLS
+1 ;;2.0;WOMEN'S HEALTH;**8**;MAY 16, 1996
+2 ;
+3 ;
ENV ; Check for duplicate RACE file entries
+1 ; The following line prevents the "Disable Options..." and "Move
+2 ; Routines..." questions from being asked during the install.
+3 SET XPDENV=1
SET (XPDDIQ("XPZ1"),XPDDIQ("XPZ2"))=0
+4 NEW RVAL,IEN,DUP
+5 SET RVAL=0
FOR
SET RVAL=$ORDER(^DIC(10,"B",RVAL))
IF RVAL=""
QUIT
Begin DoDot:1
+6 SET IEN=$ORDER(^DIC(10,"B",RVAL,0))
+7 IF $ORDER(^DIC(10,"B",RVAL,IEN))>0
SET DUP=1
End DoDot:1
+8 IF $GET(DUP)
DO MES("THERE ARE DUPLICATE RACE VALUES IN THE RACE FILE!",1)
+9 QUIT
+10 ;
PRE ;
+1 NEW DIK,DA
+2 SET XPDENV=1
SET (XPDDIQ("XPZ1"),XPDDIQ("XPZ2"))=0
+3 ; Set Wise Woman Flag
+4 ; If flag =0 the fix in the post-init will not be run.
+5 SET @XPDGREF@("WW")=$DATA(^BWPN(39,0))
+6 ; Purge entries in BW General Retrieval Items File
+7 DO MES("Preparing BW GENERAL RETRIEVAL ITEMS File for new entries...")
+8 SET DIK="^BWGRI("
+9 SET DA=0
FOR
SET DA=$ORDER(^BWGRI(DA))
IF 'DA
QUIT
Begin DoDot:1
+10 DO ^DIK
End DoDot:1
+11 DO MES("Preparing BW RACE (NBCCEDP) for updates...")
+12 SET DIK="^BWRACE("
+13 SET DA=0
FOR
SET DA=$ORDER(^BWRACE(DA))
IF 'DA
QUIT
Begin DoDot:1
+14 DO ^DIK
End DoDot:1
+15 QUIT
POST ; Converts (seeds) the new field CDC RESULTS OF PAP TEST (2001) (#.241) based on the existing
+1 ; field CDC RESULTS OF PAP TEST (1991) (#.24) (old field name CDC EQUIV SCREENING PAP DX) in
+2 ; file BW RESULTS/DIAGNOSIS (#9002086.31) to handle 2001 Bethesda System Categories.
+3 ;
+4 NEW FDA,BWDA,BWDIE,X,Y,TXT,BWRIEN
+5 DO MES("Resolving Race File Pointers in BW RACE MAPPINGS (NBCCEDP) File.")
+6 KILL ^BWRACE("B")
+7 SET BWRIEN=0
+8 FOR
SET BWRIEN=$ORDER(@XPDGREF@("RACEPTRS",BWRIEN))
IF BWRIEN<1
QUIT
Begin DoDot:1
+9 SET TXT=@XPDGREF@("RACEPTRS",BWRIEN)
+10 DO MES("Processing entry: "_BWRIEN_" = "_TXT)
+11 SET $PIECE(^BWRACE(BWRIEN,0),U)=$ORDER(^DIC(10,"B",TXT,0))
End DoDot:1
+12 ; Re-index "B" x-ref of BW RACE MAPPINGS File
+13 SET DIK="^BWRACE("
SET DIK(1)=".01^B"
DO ENALL^DIK
+14 ;
+15 SET BWDA=0
+16 FOR
SET BWDA=$ORDER(^BWDIAG(BWDA))
IF 'BWDA
QUIT
Begin DoDot:1
+17 SET X=+$PIECE(^BWDIAG(BWDA,0),"^",24)
+18 IF X<1
QUIT
+19 SET Y=$SELECT(X=2:1,X=3:2,X=4:3,X=7:8,X=14:7,1:X)
+20 SET FDA(1,9002086.31,BWDA_",",.241)=Y
+21 DO FILE^DIE("","FDA(1)","BWDIE(1)")
+22 DO CLEAN^DILF
End DoDot:1
+23 ;
+24 ; Set Bethesda 1991 (#.51) and 2001 (#.52) start dates in BW SITE file.
+25 ; Set MDE version to 4.1 if no value is defined.
+26 SET BWDA=0
+27 FOR
SET BWDA=$ORDER(^BWSITE(BWDA))
IF 'BWDA
QUIT
Begin DoDot:1
+28 SET X=$PIECE(^BWSITE(BWDA,0),"^",17)
+29 IF X<1
SET X=2910101
+30 SET FDA(2,9002086.02,BWDA_",",.51)=X
+31 SET FDA(2,9002086.02,BWDA_",",.52)=3021001
+32 IF '$$GET1^DIQ(9002086.02,BWDA,.18,"I")
SET FDA(2,9002086.02,BWDA_",",.18)=41
+33 DO FILE^DIE("","FDA(2)","BWDIE(2)")
+34 DO CLEAN^DILF
End DoDot:1
+35 ; Importing Race into BW Patient File
+36 DO MES("Importing Patient Race...")
+37 DO START^BWUCVRC
+38 ; Add procedure type to existing Wise Woman Procedures if needed
+39 ;Site has not WW Procedures to correct
IF '@XPDGREF@("WW")
QUIT
+40 DO MES("Repairing Wise Woman procedures...")
+41 SET BWDA=0
+42 FOR
SET BWDA=$ORDER(^BWPCD(BWDA))
IF 'BWDA
QUIT
Begin DoDot:1
+43 ; Not a Wise Woman procedure
IF '$DATA(^BWPCD(BWDA,4))
QUIT
+44 WRITE "."
+45 IF '$PIECE(^BWPCD(BWDA,0),U,4)
Begin DoDot:2
+46 WRITE ":"
+47 SET $PIECE(^BWPCD(BWDA,0),U,4)=39
End DoDot:2
End DoDot:1
+48 QUIT
+49 ; Display message in MSG and optionally set quit flag to QUIT
MES(MSG,QUIT) ;
+1 DO BMES^XPDUTL(" "_$GET(MSG))
+2 IF $GET(QUIT)
SET XPDQUIT=QUIT
+3 QUIT
+4 ; Pre-Transport global for BW RACE file mappings
PRETRAN ;
+1 NEW IEN,VAL,TXT
+2 SET IEN=0
+3 FOR
SET IEN=$ORDER(^BWRACE(IEN))
IF IEN<1
QUIT
Begin DoDot:1
+4 SET VAL=$PIECE(^BWRACE(IEN,0),U)
SET TXT=$$GET1^DIQ(10,VAL,.01,"E")
+5 SET @XPDGREF@("RACEPTRS",IEN)=TXT
End DoDot:1
+6 QUIT