BMC4P4 ;IHS/OIT/FCJ - BMC 4.0 PATCH 4
;;4.0;REFERRED CARE INFO SYSTEM;**4**;NOV 15, 2008
;
;
I '$G(IOM) D HOME^%ZIS
;
I '$G(DUZ) W !,"DUZ UNDEFINED OR 0." D SORRY(2) Q
;
I '$L($G(DUZ(0))) W !,"DUZ(0) UNDEFINED OR NULL." D SORRY(2) Q
;
I '(DUZ(0)["@") W:'$D(ZTQUEUED) !,"DUZ(0) DOES NOT CONTAIN AN '@'." D SORRY(2) Q
;
S X=$$GET1^DIQ(200,DUZ,.01)
W !!,$$CJ^XLFSTR("Hello, "_$P(X,",",2)_" "_$P(X,","),IOM)
W !!,$$CJ^XLFSTR("Checking Environment for "_$P($T(+2),";",4)_" V "_$P($T(+2),";",3)_".",IOM)
;
NEW IORVON,IORVOFF
S X="IORVON;IORVOFF"
D ENDR^%ZISS
;
I $$VCHK("BMC","4.0",2,"'=")
I $$VCHK("XU","8.0",2,"<")
I $$VCHK("DI","21.0",2,"<")
I $$VCHK("ATX","5.1",2,"<")
I $$VCHK("AUPN","99.1",2,"<")
I $$VCHK("LEX","2.0",2,"<")
I $$VCHK("AICD","3.51",2,"<") W !,$$CJ^XLFSTR("And AICD Patch 7 installed",IOM)
I '$$INSTALLD^BMC4P0("AICD*3.51*7") S BMCQUIT=2 D SORRY(BMCQUIT)
;
NEW DA,DIC
S X="BMC",DIC="^DIC(9.4,",DIC(0)="",D="C"
D IX^DIC
I Y<0,$D(^DIC(9.4,"C","BMC")) D
. W !!,*7,*7,$$CJ^XLFSTR("You Have More Than One Entry In The",IOM),!,$$CJ^XLFSTR("PACKAGE File with an ""BMC"" prefix.",IOM)
. W !,$$CJ^XLFSTR(IORVON_"One entry needs to be deleted."_IORVOFF,IOM)
. D SORRY(2)
;
I $G(XPDQUIT) W !,$$CJ^XLFSTR(IORVON_"FIX IT! Before Proceeding."_IORVOFF,IOM),!!,*7,*7,*7 Q
;
W !!,$$CJ^XLFSTR("ENVIRONMENT OK.",IOM)
;
D HELP^XBHELP("INTROE","BMC4P4")
I '$$DIR^XBDIR("E","","","","","",1) D SORRY(2) Q
;
I $G(XPDENV)=1 S (XPDDIQ("XPZ1"),XPDDIQ("XPZ2"))=0 D HELP^XBHELP("INTROI","BMC4P4") I '$$DIR^XBDIR("E","","","","","",1) D SORRY(2)
;
Q
;
SORRY(X) ;
KILL DIFQ
S XPDQUIT=X
W *7,!,$$CJ^XLFSTR("Sorry....FIX IT!",IOM)
Q
;
VCHK(BMCPRE,BMCVER,BMCQUIT,BMCCOMP) ; Check versions needed.
;
NEW BMCV
S BMCV=$$VERSION^XPDUTL(BMCPRE)
W !,$$CJ^XLFSTR("Need "_$S(BMCCOMP="<":"at least ",1:"")_BMCPRE_" v "_BMCVER_"....."_BMCPRE_" v "_BMCV_" Present",IOM)
I @(BMCV_BMCCOMP_BMCVER) D SORRY(BMCQUIT) Q 0
Q 1
;
PRE ;EP - From KIDS.
I $$NEWCP^XPDUTL("PRE1","AUDS^BMC4P4")
; The following line prevents the "Disable Options..." and "Move
; Routines..." questions from being asked during the install.
I $G(XPDENV)=1 S (XPDDIQ("XPZ1"),XPDDIQ("XPZ2"))=0
;
Q
;
POST ;EP - From KIDS.
;
; --- Restore dd audit settings.
S %="AUDR^BMC4P4"
I $$NEWCP^XPDUTL("POS1-"_%,%)
;
; --- Set new Index "BA" and "BB"
S %="INDX^BMC4P4"
I $$NEWCP^XPDUTL("POS2-"_%,%)
;
; --- Send mail message of install.
S %="MAIL^BMC4P4"
I $$NEWCP^XPDUTL("POS3-"_%,%)
;
Q
;
MAIL ;
D BMES^XPDUTL("BEGIN Delivering MailMan message to select users.")
NEW DIFROM,XMSUB,XMDUZ,XMTEXT,XMY
KILL ^TMP("BMC4P4",$J)
D RSLT(" --- BMC v 4.0 Patch 1, has been installed into this uci ---")
F %=1:1 D RSLT($P($T(GREET+%),";",3)) Q:$P($T(GREET+%+1),";",3)="###"
S %=0
F S %=$O(^XTMP("XPDI",XPDA,"BLD",XPDBLD,1,%)) Q:'% D RSLT(^(%,0))
S XMSUB=$P($P($T(+1),";",2)," ",3,99),XMDUZ=$S($G(DUZ):DUZ,1:.5),XMTEXT="^TMP(""BMC4P4"",$J,",XMY(1)="",XMY(DUZ)=""
F %="BMCZMENU","XUMGR","XUPROG","XUPROGMODE" D SINGLE(%)
D ^XMD
KILL ^TMP("BMC4P4",$J)
D MES^XPDUTL("END Delivering MailMan message to select users.")
Q
;
RSLT(%) S ^(0)=$G(^TMP("BMC4P4",$J,0))+1,^(^(0))=%
Q
;
SINGLE(K) ; Get holders of a single key K.
NEW Y
S Y=0
Q:'$D(^XUSEC(K))
F S Y=$O(^XUSEC(K,Y)) Q:'Y S XMY(Y)=""
Q
;
INTROE ; Intro text during KIDS Environment check.
;;In this distribution:
;;(1) Added API for iCare Package
;;(2) Fixed Alert to pass to EHR notification tab
;;(3) Miscellaneous Changes:
;; a. Changed routines BMCFPRN, BMCFPRN2, BMCFPRN4 AND BMCFPRNC
;; to fix queuing
;; b. Fixed Final DX Code entry in RCIS Report Lister Items File
;; c. Changed routines BNCFDRA and BMCFPRNA to print Sir names
;; on Alternate resource letter
;;
;;###
;
INTROI ; Intro text during KIDS Install.
;;A standard message will be produced by this update.
;;
;;If you run interactively, results will be displayed on your screen,
;;as well as in the mail message and the entry in the INSTALL file.
;;If you queue to TaskMan, please read the mail message for results of
;;this update, and remember not to Q to the HOME device.
;;###
;
GREET ;;To add to mail message.
;;
;;Greetings.
;;
;;Standard data dictionaries on your RPMS system have been updated.
;;
;;You are receiving this message because of the particular RPMS
;;security keys that you hold. This is for your information, only.
;;You need do nothing in response to this message.
;;
;;Questions about this patch, which is a product of the RPMS DBA
;;
;;can be directed to the Help Desk,
;;.
;;Please refer to patch "bmc*4.0*2".
;;
;;###;NOTE: This line indicates the end of text in this message.
;
; -----------------------------------------------------
; The global location for dictionary audit is:
; ^DD(FILE,0,"DDA")
; If the valuey is "Y", dd audit is on. Any other value, or the
; absence of the node, means dd audit is off.
; -----------------------------------------------------
AUDS ;EP - From KIDS.
D BMES^XPDUTL("Saving current DD AUDIT settings for files in this patch")
D MES^XPDUTL("and turning DD AUDIT to 'Y'.")
S ^XTMP("BMC4P4",0)=$$FMADD^XLFDT(DT,10)_"^"_DT_"^"_$P($P($T(+1),";",2)," ",3,99)
NEW BMC
S BMC=0
F S BMC=$O(^XTMP("XPDI",XPDA,"FIA",BMC)) Q:'BMC D
. I '$D(^XTMP("BMC4P4",BMC,"DDA")) S ^XTMP("BMC4P4",BMC,"DDA")=$G(^DD(BMC,0,"DDA"))
. D MES^XPDUTL(" File "_$$RJ^XLFSTR(BMC,12)_" - "_$$LJ^XLFSTR(^XTMP("XPDI",XPDA,"FIA",BMC),30)_"- DD audit was '"_$G(^XTMP("BMC4P4",BMC,"DDA"))_"'"),MES^XPDUTL($$RJ^XLFSTR("Set to 'Y'",69))
. S ^DD(BMC,0,"DDA")="Y"
.Q
D MES^XPDUTL("DD AUDIT settings saved in ^XTMP(.")
Q
; -----------------------------------------------------
AUDR ; Restore the file data audit values to their original values.
D BMES^XPDUTL("Restoring DD AUDIT settings for files in this patch.")
NEW BMC
S BMC=0
F S BMC=$O(^XTMP("BMC4P4",BMC)) Q:'BMC D
. S ^DD(BMC,0,"DDA")=^XTMP("BMC4P4",BMC,"DDA")
. D MES^XPDUTL(" File "_$$RJ^XLFSTR(BMC,12)_" - "_$$LJ^XLFSTR($$GET1^DID(BMC,"","","NAME"),30)_"- DD AUDIT Set to '"_^DD(BMC,0,"DDA")_"'")
.Q
KILL ^XTMP("BMC4P4")
D MES^XPDUTL("DD AUDIT settings restored.")
Q
; -----------------------------------------------------
INDX ;INDEX NEW INDECIES "BA", "BB" AND "CD"
S BMC="BMC*4.0*2" Q:$$INSTALLD^BMC4P0(BMC)
D BMES^XPDUTL("BEGIN Indexing Expected Begining Date of Service.")
S DIK="^BMCREF("
S DIK(1)="1105^BA"
D ENALL^DIK
D BMES^XPDUTL("BEGIN Indexing Actual Appointment/begin DOS.")
S DIK(1)="1106^BB"
D ENALL^DIK
D BMES^XPDUTL("BEGIN Indexing CHS Denial Number.")
S DIK(1)="1128^CD"
D ENALL^DIK
D BMES^XPDUTL("Completed updating new indexes.")
K DA,DIC,DIK,X
Q
; -----------------------------------------------------
INSTALLD(BMC) ; Determine if patch BMC was installed, where BMC is
; the name of the INSTALL. E.g "AVA*93.2*12".
;
NEW DIC,X,Y
; lookup package.
S X=$P(BMC,"*",1)
S DIC="^DIC(9.4,",DIC(0)="FM",D="C"
D IX^DIC
I Y<1 Q 0
; lookup version.
S DIC=DIC_+Y_",22,",X=$P(BMC,"*",2)
D ^DIC
I Y<1 Q 0
; lookup patch.
S DIC=DIC_+Y_",""PAH"",",X=$P(BMC,"*",3)
D ^DIC
Q $S(Y<1:0,1:1)
;
; -----------------------------------------------------
BMC4P4 ;IHS/OIT/FCJ - BMC 4.0 PATCH 4
+1 ;;4.0;REFERRED CARE INFO SYSTEM;**4**;NOV 15, 2008
+2 ;
+3 ;
+4 IF '$GET(IOM)
DO HOME^%ZIS
+5 ;
+6 IF '$GET(DUZ)
WRITE !,"DUZ UNDEFINED OR 0."
DO SORRY(2)
QUIT
+7 ;
+8 IF '$LENGTH($GET(DUZ(0)))
WRITE !,"DUZ(0) UNDEFINED OR NULL."
DO SORRY(2)
QUIT
+9 ;
+10 IF '(DUZ(0)["@")
IF '$DATA(ZTQUEUED)
WRITE !,"DUZ(0) DOES NOT CONTAIN AN '@'."
DO SORRY(2)
QUIT
+11 ;
+12 SET X=$$GET1^DIQ(200,DUZ,.01)
+13 WRITE !!,$$CJ^XLFSTR("Hello, "_$PIECE(X,",",2)_" "_$PIECE(X,","),IOM)
+14 WRITE !!,$$CJ^XLFSTR("Checking Environment for "_$PIECE($TEXT(+2),";",4)_" V "_$PIECE($TEXT(+2),";",3)_".",IOM)
+15 ;
+16 NEW IORVON,IORVOFF
+17 SET X="IORVON;IORVOFF"
+18 DO ENDR^%ZISS
+19 ;
+20 IF $$VCHK("BMC","4.0",2,"'=")
+21 IF $$VCHK("XU","8.0",2,"<")
+22 IF $$VCHK("DI","21.0",2,"<")
+23 IF $$VCHK("ATX","5.1",2,"<")
+24 IF $$VCHK("AUPN","99.1",2,"<")
+25 IF $$VCHK("LEX","2.0",2,"<")
+26 IF $$VCHK("AICD","3.51",2,"<")
WRITE !,$$CJ^XLFSTR("And AICD Patch 7 installed",IOM)
+27 IF '$$INSTALLD^BMC4P0("AICD*3.51*7")
SET BMCQUIT=2
DO SORRY(BMCQUIT)
+28 ;
+29 NEW DA,DIC
+30 SET X="BMC"
SET DIC="^DIC(9.4,"
SET DIC(0)=""
SET D="C"
+31 DO IX^DIC
+32 IF Y<0
IF $DATA(^DIC(9.4,"C","BMC"))
Begin DoDot:1
+33 WRITE !!,*7,*7,$$CJ^XLFSTR("You Have More Than One Entry In The",IOM),!,$$CJ^XLFSTR("PACKAGE File with an ""BMC"" prefix.",IOM)
+34 WRITE !,$$CJ^XLFSTR(IORVON_"One entry needs to be deleted."_IORVOFF,IOM)
+35 DO SORRY(2)
End DoDot:1
+36 ;
+37 IF $GET(XPDQUIT)
WRITE !,$$CJ^XLFSTR(IORVON_"FIX IT! Before Proceeding."_IORVOFF,IOM),!!,*7,*7,*7
QUIT
+38 ;
+39 WRITE !!,$$CJ^XLFSTR("ENVIRONMENT OK.",IOM)
+40 ;
+41 DO HELP^XBHELP("INTROE","BMC4P4")
+42 IF '$$DIR^XBDIR("E","","","","","",1)
DO SORRY(2)
QUIT
+43 ;
+44 IF $GET(XPDENV)=1
SET (XPDDIQ("XPZ1"),XPDDIQ("XPZ2"))=0
DO HELP^XBHELP("INTROI","BMC4P4")
IF '$$DIR^XBDIR("E","","","","","",1)
DO SORRY(2)
+45 ;
+46 QUIT
+47 ;
SORRY(X) ;
+1 KILL DIFQ
+2 SET XPDQUIT=X
+3 WRITE *7,!,$$CJ^XLFSTR("Sorry....FIX IT!",IOM)
+4 QUIT
+5 ;
VCHK(BMCPRE,BMCVER,BMCQUIT,BMCCOMP) ; Check versions needed.
+1 ;
+2 NEW BMCV
+3 SET BMCV=$$VERSION^XPDUTL(BMCPRE)
+4 WRITE !,$$CJ^XLFSTR("Need "_$SELECT(BMCCOMP="<":"at least ",1:"")_BMCPRE_" v "_BMCVER_"....."_BMCPRE_" v "_BMCV_" Present",IOM)
+5 IF @(BMCV_BMCCOMP_BMCVER)
DO SORRY(BMCQUIT)
QUIT 0
+6 QUIT 1
+7 ;
PRE ;EP - From KIDS.
+1 IF $$NEWCP^XPDUTL("PRE1","AUDS^BMC4P4")
+2 ; The following line prevents the "Disable Options..." and "Move
+3 ; Routines..." questions from being asked during the install.
+4 IF $GET(XPDENV)=1
SET (XPDDIQ("XPZ1"),XPDDIQ("XPZ2"))=0
+5 ;
+6 QUIT
+7 ;
POST ;EP - From KIDS.
+1 ;
+2 ; --- Restore dd audit settings.
+3 SET %="AUDR^BMC4P4"
+4 IF $$NEWCP^XPDUTL("POS1-"_%,%)
+5 ;
+6 ; --- Set new Index "BA" and "BB"
+7 SET %="INDX^BMC4P4"
+8 IF $$NEWCP^XPDUTL("POS2-"_%,%)
+9 ;
+10 ; --- Send mail message of install.
+11 SET %="MAIL^BMC4P4"
+12 IF $$NEWCP^XPDUTL("POS3-"_%,%)
+13 ;
+14 QUIT
+15 ;
MAIL ;
+1 DO BMES^XPDUTL("BEGIN Delivering MailMan message to select users.")
+2 NEW DIFROM,XMSUB,XMDUZ,XMTEXT,XMY
+3 KILL ^TMP("BMC4P4",$JOB)
+4 DO RSLT(" --- BMC v 4.0 Patch 1, has been installed into this uci ---")
+5 FOR %=1:1
DO RSLT($PIECE($TEXT(GREET+%),";",3))
IF $PIECE($TEXT(GREET+%+1),";",3)="###"
QUIT
+6 SET %=0
+7 FOR
SET %=$ORDER(^XTMP("XPDI",XPDA,"BLD",XPDBLD,1,%))
IF '%
QUIT
DO RSLT(^(%,0))
+8 SET XMSUB=$PIECE($PIECE($TEXT(+1),";",2)," ",3,99)
SET XMDUZ=$SELECT($GET(DUZ):DUZ,1:.5)
SET XMTEXT="^TMP(""BMC4P4"",$J,"
SET XMY(1)=""
SET XMY(DUZ)=""
+9 FOR %="BMCZMENU","XUMGR","XUPROG","XUPROGMODE"
DO SINGLE(%)
+10 DO ^XMD
+11 KILL ^TMP("BMC4P4",$JOB)
+12 DO MES^XPDUTL("END Delivering MailMan message to select users.")
+13 QUIT
+14 ;
RSLT(%) SET ^(0)=$GET(^TMP("BMC4P4",$JOB,0))+1
SET ^(^(0))=%
+1 QUIT
+2 ;
SINGLE(K) ; Get holders of a single key K.
+1 NEW Y
+2 SET Y=0
+3 IF '$DATA(^XUSEC(K))
QUIT
+4 FOR
SET Y=$ORDER(^XUSEC(K,Y))
IF 'Y
QUIT
SET XMY(Y)=""
+5 QUIT
+6 ;
INTROE ; Intro text during KIDS Environment check.
+1 ;;In this distribution:
+2 ;;(1) Added API for iCare Package
+3 ;;(2) Fixed Alert to pass to EHR notification tab
+4 ;;(3) Miscellaneous Changes:
+5 ;; a. Changed routines BMCFPRN, BMCFPRN2, BMCFPRN4 AND BMCFPRNC
+6 ;; to fix queuing
+7 ;; b. Fixed Final DX Code entry in RCIS Report Lister Items File
+8 ;; c. Changed routines BNCFDRA and BMCFPRNA to print Sir names
+9 ;; on Alternate resource letter
+10 ;;
+11 ;;###
+12 ;
INTROI ; Intro text during KIDS Install.
+1 ;;A standard message will be produced by this update.
+2 ;;
+3 ;;If you run interactively, results will be displayed on your screen,
+4 ;;as well as in the mail message and the entry in the INSTALL file.
+5 ;;If you queue to TaskMan, please read the mail message for results of
+6 ;;this update, and remember not to Q to the HOME device.
+7 ;;###
+8 ;
GREET ;;To add to mail message.
+1 ;;
+2 ;;Greetings.
+3 ;;
+4 ;;Standard data dictionaries on your RPMS system have been updated.
+5 ;;
+6 ;;You are receiving this message because of the particular RPMS
+7 ;;security keys that you hold. This is for your information, only.
+8 ;;You need do nothing in response to this message.
+9 ;;
+10 ;;Questions about this patch, which is a product of the RPMS DBA
+11 ;;
+12 ;;can be directed to the Help Desk,
+13 ;;.
+14 ;;Please refer to patch "bmc*4.0*2".
+15 ;;
+16 ;;###;NOTE: This line indicates the end of text in this message.
+17 ;
+18 ; -----------------------------------------------------
+19 ; The global location for dictionary audit is:
+20 ; ^DD(FILE,0,"DDA")
+21 ; If the valuey is "Y", dd audit is on. Any other value, or the
+22 ; absence of the node, means dd audit is off.
+23 ; -----------------------------------------------------
AUDS ;EP - From KIDS.
+1 DO BMES^XPDUTL("Saving current DD AUDIT settings for files in this patch")
+2 DO MES^XPDUTL("and turning DD AUDIT to 'Y'.")
+3 SET ^XTMP("BMC4P4",0)=$$FMADD^XLFDT(DT,10)_"^"_DT_"^"_$PIECE($PIECE($TEXT(+1),";",2)," ",3,99)
+4 NEW BMC
+5 SET BMC=0
+6 FOR
SET BMC=$ORDER(^XTMP("XPDI",XPDA,"FIA",BMC))
IF 'BMC
QUIT
Begin DoDot:1
+7 IF '$DATA(^XTMP("BMC4P4",BMC,"DDA"))
SET ^XTMP("BMC4P4",BMC,"DDA")=$GET(^DD(BMC,0,"DDA"))
+8 DO MES^XPDUTL(" File "_$$RJ^XLFSTR(BMC,12)_" - "_$$LJ^XLFSTR(^XTMP("XPDI",XPDA,"FIA",BMC),30)_"- DD audit was '"_$GET(^XTMP("BMC4P4",BMC,"DDA"))_"'")
DO MES^XPDUTL($$RJ^XLFSTR("Set to 'Y'",69))
+9 SET ^DD(BMC,0,"DDA")="Y"
+10 QUIT
End DoDot:1
+11 DO MES^XPDUTL("DD AUDIT settings saved in ^XTMP(.")
+12 QUIT
+13 ; -----------------------------------------------------
AUDR ; Restore the file data audit values to their original values.
+1 DO BMES^XPDUTL("Restoring DD AUDIT settings for files in this patch.")
+2 NEW BMC
+3 SET BMC=0
+4 FOR
SET BMC=$ORDER(^XTMP("BMC4P4",BMC))
IF 'BMC
QUIT
Begin DoDot:1
+5 SET ^DD(BMC,0,"DDA")=^XTMP("BMC4P4",BMC,"DDA")
+6 DO MES^XPDUTL(" File "_$$RJ^XLFSTR(BMC,12)_" - "_$$LJ^XLFSTR($$GET1^DID(BMC,"","","NAME"),30)_"- DD AUDIT Set to '"_^DD(BMC,0,"DDA")_"'")
+7 QUIT
End DoDot:1
+8 KILL ^XTMP("BMC4P4")
+9 DO MES^XPDUTL("DD AUDIT settings restored.")
+10 QUIT
+11 ; -----------------------------------------------------
INDX ;INDEX NEW INDECIES "BA", "BB" AND "CD"
+1 SET BMC="BMC*4.0*2"
IF $$INSTALLD^BMC4P0(BMC)
QUIT
+2 DO BMES^XPDUTL("BEGIN Indexing Expected Begining Date of Service.")
+3 SET DIK="^BMCREF("
+4 SET DIK(1)="1105^BA"
+5 DO ENALL^DIK
+6 DO BMES^XPDUTL("BEGIN Indexing Actual Appointment/begin DOS.")
+7 SET DIK(1)="1106^BB"
+8 DO ENALL^DIK
+9 DO BMES^XPDUTL("BEGIN Indexing CHS Denial Number.")
+10 SET DIK(1)="1128^CD"
+11 DO ENALL^DIK
+12 DO BMES^XPDUTL("Completed updating new indexes.")
+13 KILL DA,DIC,DIK,X
+14 QUIT
+15 ; -----------------------------------------------------
INSTALLD(BMC) ; Determine if patch BMC was installed, where BMC is
+1 ; the name of the INSTALL. E.g "AVA*93.2*12".
+2 ;
+3 NEW DIC,X,Y
+4 ; lookup package.
+5 SET X=$PIECE(BMC,"*",1)
+6 SET DIC="^DIC(9.4,"
SET DIC(0)="FM"
SET D="C"
+7 DO IX^DIC
+8 IF Y<1
QUIT 0
+9 ; lookup version.
+10 SET DIC=DIC_+Y_",22,"
SET X=$PIECE(BMC,"*",2)
+11 DO ^DIC
+12 IF Y<1
QUIT 0
+13 ; lookup patch.
+14 SET DIC=DIC_+Y_",""PAH"","
SET X=$PIECE(BMC,"*",3)
+15 DO ^DIC
+16 QUIT $SELECT(Y<1:0,1:1)
+17 ;
+18 ; -----------------------------------------------------