ACHS31P9 ;IHS/SET/JVK - ACHS 3.1 PATCH 9 ; [ 03/02/2004 10:16 AM ]
;;3.1;CONTRACT HEALTH MGMT SYSTEM;**9**;JUNE 11, 2001
; IHS/SET/JVK ACHS*3.1*8 2/23/2004;ORIGINAL MOD FOR P9
;
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)_" Patch "_$P($T(+2),";",5)_".",IOM)
;
NEW IORVON,IORVOFF
S X="IORVON;IORVOFF"
D ENDR^%ZISS
;
I $$VCHK("ACHS","3.1",2,"'=")
;
NEW DA,DIC
S X="ACHS",DIC="^DIC(9.4,",DIC(0)="",D="C"
D IX^DIC
I Y<0,$D(^DIC(9.4,"C","ACHS")) D
. W !!,*7,*7,$$CJ^XLFSTR("You Have More Than One Entry In The",IOM),!,$$CJ^XLFSTR("PACKAGE File with an ""ACHS"" prefix.",IOM)
. W !,$$CJ^XLFSTR(IORVON_"One entry needs to be deleted."_IORVOFF,IOM)
. D SORRY(2)
.Q
;
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","ACHS31P9")
I '$$DIR^XBDIR("E","","","","","",1) D SORRY(2) Q
;
I $G(XPDENV)=1 S (XPDDIQ("XPZ1"),XPDDIQ("XPZ2"))=0 D HELP^XBHELP("INTROI","ACHS31P9") 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(ACHSPRE,ACHSVER,ACHSQUIT,ACHSCOMP) ; Check versions needed.
;
NEW ACHSV
S ACHSV=$$VERSION^XPDUTL(ACHSPRE)
W !,$$CJ^XLFSTR("Need "_$S(ACHSCOMP="<":"at least ",1:"")_ACHSPRE_" v "_ACHSVER_"....."_ACHSPRE_" v "_ACHSV_" Present",IOM)
I @(ACHSV_ACHSCOMP_ACHSVER) D SORRY(ACHSQUIT) Q 0
Q 1
;
PRE ;EP - From KIDS.
I $$NEWCP^XPDUTL("PRE1","AUDS^ACHS31P9")
Q
;
POST ;EP - From KIDS.
; ---Patches 3,4,5,6 & 7 Checks installs are done in Install Questions.
; ---Question for 3 was removed, need "C" index for lookup of non-registered patients.
S %="P4^ACHS31P9"
I $$NEWCP^XPDUTL("POS4-"_%,%)
S %="P5^ACHS31P9"
I $$NEWCP^XPDUTL("POS5-"_%,%)
;
S %="P6^ACHS31P9"
I $$NEWCP^XPDUTL("POS6-"_%,%)
;
S %="P7^ACHS31P9"
I $$NEWCP^XPDUTL("POS7-"_%,%)
;
S %="P8^ACHS31P9"
I $$NEWCP^XPDUTL("POS8-"_%,%)
;
; --- Restore dd audit settings.
S %="AUDR^ACHS31P9"
I $$NEWCP^XPDUTL("POS14-"_%,%)
;
; --- Send mail message of install.
S %="MAIL^ACHS31P9"
I $$NEWCP^XPDUTL("POS15-"_%,%)
;
Q
MAIL ;
D BMES^XPDUTL("BEGIN Delivering MailMan message to select users.")
NEW DIFROM,XMSUB,XMDUZ,XMTEXT,XMY
KILL ^TMP("ACHS31P9",$J)
D RSLT(" --- ACHS v 3.1 Patch 9, 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(""ACHS31P9"",$J,",XMY(1)="",XMY(DUZ)=""
F %="ACHSZMENU","XUMGR","XUPROG","XUPROGMODE" D SINGLE(%)
D ^XMD
KILL ^TMP("ACHS31P9",$J)
D MES^XPDUTL("END Delivering MailMan message to select users.")
Q
;
RSLT(%) S ^(0)=$G(^TMP("ACHS31P9",$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) Routine ACHSUUP modified to fix undef of ACHSTTYP
;;###
;
INTROI ; Intro text during KIDS Install.
;;A standard message will be produced by this update.
;;
;;If you run interactively, results are displayed on your screen,
;;in the mail message and 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
;;,
;;direct questions to the Help Desk,
;;refer to patch "ACHS*3.1*8".
;;
;;###;NOTE: This line 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("ACHS31P9",0)=$$FMADD^XLFDT(DT,10)_"^"_DT_"^"_$P($P($T(+1),";",2)," ",3,99)
NEW ACHS
S ACHS=0
F S ACHS=$O(^XTMP("XPDI",XPDA,"FIA",ACHS)) Q:'ACHS D
. I '$D(^XTMP("ACHS31P9",ACHS,"DDA")) S ^XTMP("ACHS31P9",ACHS,"DDA")=$G(^DD(ACHS,0,"DDA"))
. D MES^XPDUTL(" File "_$$RJ^XLFSTR(ACHS,12)_" - "_$$LJ^XLFSTR(^XTMP("XPDI",XPDA,"FIA",ACHS),30)_"- DD audit was '"_$G(^XTMP("ACHS31P9",ACHS,"DDA"))_"'"),MES^XPDUTL($$RJ^XLFSTR("Set to 'Y'",69))
. S ^DD(ACHS,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 ACHS
S ACHS=0
F S ACHS=$O(^XTMP("ACHS31P9",ACHS)) Q:'ACHS D
. S ^DD(ACHS,0,"DDA")=^XTMP("ACHS31P9",ACHS,"DDA")
. D MES^XPDUTL(" File "_$$RJ^XLFSTR(ACHS,12)_" - "_$$LJ^XLFSTR($$GET1^DID(ACHS,"","","NAME"),30)_"- DD AUDIT Set to '"_^DD(ACHS,0,"DDA")_"'")
.Q
KILL ^XTMP("ACHS31P9")
D MES^XPDUTL("DD AUDIT settings restored.")
Q
; -----------------------------------------------------
;
INSTALLD(ACHS) ; Determine if patch ACHS was installed, where ACHS is
; the name of the INSTALL. E.g "AVA*93.2*12".
;
NEW DIC,X,Y
; lookup package.
S X=$P(ACHS,"*",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(ACHS,"*",2)
D ^DIC
I Y<1 Q 0
; lookup patch.
S DIC=DIC_+Y_",""PAH"",",X=$P(ACHS,"*",3)
D ^DIC
Q $S(Y<1:0,1:1)
;
; -----------------------------------------------------
; Fields to be deleted.
;File#^FileName^Field#^FieldName
DELFLD ;
;;9002069^CHS DATA CONTROL^1^*RESERVED-1
;;9002069^CHS DATA CONTROL^3^*BUDGET INDIVIDUAL ACCOU
;;9002069.03^PIGGYBACK FACILITIES^.01^PIGGYBACK FACILITIES
;;9002069^CHS DATA CONTROL^9^*PIGGYBACK FACILITIES
;;9002071.63^* DIAGNOSIS (APC) COMMENT^.01^* DIAGNOSIS (APC) COMMENT
;;9002071.06^* DIAGNOSIS (APC)^.01^* DIAGNOSIS (APC)
;;9002071.06^* DIAGNOSIS (APC)^2^* DIAGNOSIS (APC) NARRATIVE
;;9002071.06^* DIAGNOSIS (APC)^3^* DIAGNOSIS (APC) COMMENT
;;9002071.01^DENIAL NUMBER^600^* DIAGNOSIS (APC)
;;9002080^CHS FACILITY^14.1^*PROCESS PAT FOR AREA NC
;;9002080^CHS FACILITY^14.13^*PROCESS DOCUMENT RECS F
;;9002080.01^DOCUMENT^13.66^* VEND AGR NUMB (NOT USE
;;9002080.01^DOCUMENT^77^*DENTAL SERVICES
;;END
; Note: above line is a loop ender.
D BMES^XPDUTL("BEGIN Removing deleted fields from CHS data dictionaries.")
NEW DA,DIK
F ACHS=1:1 S X=$P($T(DELFLD+ACHS),";",3) Q:X="END" D
. D MES^XPDUTL($J("",5)_"Deleting '"_$$LJ^XLFSTR($P(X,U,4),30,".")_"' from '"_$P(X,U,2)_"'")
. S DIK="^DD("_$P(X,U,1)_",",DA(1)=$P(X,U,1),DA=$P(X,U,3)
. D ^DIK
. Q
. ; KILL ^DD(9999999.3911) ; 4 of the 0th nodes aren't KILL'd by ^DIK.
.Q
D MES^XPDUTL("END Removing deleted fields from CHS data dictionaries.")
Q
;
DENOPT ; check for 638 facility, and add options if 638
D BMES^XPDUTL("BEGIN Checking for 638 facility.")
NEW ACHS
S ACHS=0
F S ACHS=$O(^ACHSF(ACHS)) Q:'ACHS I $P(^ACHSF(ACHS,0),U,8)="Y" D Q
. I $$ADD^XPDMENU("ACHS DEFDEN MENU PARM","ACHSDENPARM","P638") D MES^XPDUTL($J("",5)_"Denial parameter menu option added for 638 facility")
. I $$ADD^XPDMENU("ACHSDENPARM","ACHSDENPARMREA","AREA") D MES^XPDUTL($J("",5)_"Denial parameter menu option added for 638 facility")
.Q
D MES^XPDUTL("END Checking for 638 facility.")
Q
;
M278 ;
D BMES^XPDUTL("BEGIN Attaching 278 menu.")
I $$ADD^XPDMENU("ACHSAA","ACHS 278 MENU","278") D MES^XPDUTL($J("",5)_"278 Menu added to Document Generation menu."),MES^XPDUTL($J("",5)_"Note that the security lock was *NOT* allocated.") I 1
E D MES^XPDUTL($J("",5)_"ERROR: 278 menu attachment FAILED.")
D MES^XPDUTL("END Attaching 278 menu.")
Q
;
NONREG ;EP - from KIDS.
D BMES^XPDUTL("BEGIN Re-index of Patient Name in Denials.")
NEW ACHS,DA,DIK
S ACHS=0
F S ACHS=$O(^ACHSDEN(ACHS)) Q:'ACHS D
. KILL ^ACHSDEN(ACHS,"D","C"),^ACHSDEN(ACHS,"D","N")
. S DIK="^ACHSDEN("_ACHS_",""D"""_",",DA(1)=ACHS
. F DIK(1)="7^C","10^C" D ENALL^DIK
.Q
D MES^XPDUTL("END Re-index of Patient Name in Denials.")
Q
DENREV ;EP - From KIDS.
;SETS DENIAL STATUS IF DENIAL WAS REVERSED
NEW ACHS
S ACHSASTA=0,ACHSDA=0,ACHS=0
S ACHSASTA=$O(^ACHSDENA("B","REVERSED AFTER APPEAL",ACHSASTA))
F S ACHS=$O(^ACHSDEN(ACHS)) Q:ACHS'?1N.N D
. S ACHSDA=0
.F S ACHSDA=$O(^ACHSDEN(ACHS,"D",ACHSDA)) Q:ACHSDA'?1N.N D
.. S ACHSDSTA=$P(^ACHSDEN(ACHS,"D",ACHSDA,0),U,8)
.. Q:'$D(^ACHSDEN(ACHS,"D",ACHSDA,400,0))
.. I ACHSDSTA["R" S $P(^ACHSDEN(ACHS,"D",ACHSDA,400,0),U,3)=ACHSASTA
K ACHSASTA,ACHSDA
Q
V145DD ;EP - From KIDS
;GETS RID OF VERSION 1.45 DD'S LEFT BEHINDE
K ^UTILITY("XBDSET",$J)
F XBBPI=1:1 S XBBPIX=$P($T(LIST+XBBPI),";;",2) Q:XBBPIX="END" S XBBPIY=$P(XBBPIX,"=",2,99),XBBPIX=$P(XBBPIX,"=",1) S @XBBPIX=XBBPIY
K XBBPI,XBBPIX,XBBPIY D EN2^XBKD
Q
LIST ;
;;^UTILITY("XBDSET",$J,1803100)=S^S
;;^UTILITY("XBDSET",$J,1803101)=S^S
;;^UTILITY("XBDSET",$J,1803102)=S^S
;;^UTILITY("XBDSET",$J,1803103)=S^S
;;^UTILITY("XBDSET",$J,1803104)=S^S
;;^UTILITY("XBDSET",$J,1803107)=S^S
;;^UTILITY("XBDSET",$J,1803109)=S^S
;;^UTILITY("XBDSET",$J,1803110)=S^S
;;^UTILITY("XBDSET",$J,1803111)=S^S
;;^UTILITY("XBDSET",$J,1803112)=S^S
;;^UTILITY("XBDSET",$J,1803113)=S^S
;;^UTILITY("XBDSET",$J,1803114)=S^S
;;^UTILITY("XBDSET",$J,1803115)=S^S
;;END
;Note above line ends loop
P7OPT ;EP -FROM KIDS
;ADD NEW OPTIONS FOR PATCH 7, ELECTRONIC SIGNATURE AND ELECTRONIC
;SIGNATURE REPORTS
D BMES^XPDUTL("Adding new options.")
I $$ADD^XPDMENU("ACHSMENU","ACHS E-SIG MENU","EMNU") D MES^XPDUTL($J("",5)_"Electronic Signature Authorization Menu to main CHS Menu")
I $$ADD^XPDMENU("ACHS E-SIG MENU","ACHS E-SIG AUTHORIZING OFC.","SIGA")
I $$ADD^XPDMENU("ACHS E-SIG MENU","ACHS E-SIG ORDERING OFC.","SIGO") D MES^XPDUTL($J("",5)_"Electronic Signature for Authorizing Official, Electronic Signature for Ordering Official")
I $$ADD^XPDMENU("ACHSREPORTS","ACHS E-SIG REPORTS","ERPT")
I $$ADD^XPDMENU("ACHS E-SIG REPORTS","ACHS E-SIG APPROVED REPORT","ESAP")
I $$ADD^XPDMENU("ACHS E-SIG REPORTS","ACHS E-SIG PENDING SIG REPORT","ESPD")
D MES^XPDUTL($J("",5)_"Options in E-Signature Reports added")
I $$ADD^XPDMENU("ACHSMGPAR","ACHS E-SIG ADD EDIT USERS","EOFF")
I $$ADD^XPDMENU("ACHSMGPAR","ACHS E-SIG SITE PARAMETER","ESIT") D MES^XPDUTL($J("",5)_"Option for adding Authorized E-Signature users and E-Site Paramaters added to facility management options")
I $$ADD^XPDMENU("ACHSMGR","ACHSMGPAR") D MES^XPDUTL($J("",5)_"Attach E-Sig to facility Management")
D MES^XPDUTL("Key for E-Sig Menu is ACHSZESIG,for Adding authorized users is ACHSZPARM.")
D MES^XPDUTL("END updating options.")
Q
;
P6OPT ;EP - FROM KIDS.
;ADD NEW OPTIONS FOR PATCH 6, DENIAL APPEAL,EDITS AND CANCEL, FI FIELD
D BMES^XPDUTL("Begin adding new options.")
I $$ADD^XPDMENU("ACHSAA","ACHSFIM","FIM") D MES^XPDUTL($J("",5)_"Send approval Message to FI added to Document Generation Menu")
I $$ADD^XPDMENU("ACHS DEFDEN MENU","ACHS DEN APPEAL MENU","APP") D MES^XPDUTL($J("",5)_"Denial Appeal menu option added to CHS Denial/Deferred ServciesMenu")
D MES^XPDUTL("END updating options.")
Q
;
P4 ;EP - from KIDS.
Q:'$G(XPDQUES("POS4"))
D BMES^XPDUTL("BEGIN Re-index of Patient Name in Deferred Services.")
NEW ACHS,DA,DIK
S ACHS=0
F S ACHS=$O(^ACHSDEF(ACHS)) Q:'ACHS D
. KILL ^ACHSDEF(ACHS,"D","C"),^ACHSDEF(ACHS,"D","N")
. S DIK="^ACHSDEF("_ACHS_",""D"""_",",DA(1)=ACHS
. F DIK(1)="6^C","7^N" D ENALL^DIK
.Q
D MES^XPDUTL("END Re-index of Patient Name in Deferred Services.")
Q
;
P5 ;EP - from KIDS
Q:'$G(XPDQUES("POS5"))
;
; --- Atch Denial ltr edit option at 638 sites.
S %="DENOPT^ACHS31P9"
I $$NEWCP^XPDUTL("POS5-"_%,%)
;
; --- Delete fields in CHS files marked for deletion.
S %="DELFLD^ACHS31P9"
I $$NEWCP^XPDUTL("POS6-"_%,%)
;
; --- Atch 278 menu to Doc edit option.
S %="M278^ACHS31P9"
I $$NEWCP^XPDUTL("POS7-"_%,%)
;
; --- Remove non-standard option auditing from CHS options.
S %="POS^ACHS31P0"
I $$NEWCP^XPDUTL("POS8-"_%,%)
Q
P6 ;EP - from KIDS
Q:'$G(XPDQUES("POS6"))
;
; --- Atch Denial APPEAL option.
S %="P6OPT^ACHS31P9"
I $$NEWCP^XPDUTL("POS9-"_%,%)
;
; --- Re-index non-registered patient name.
S %="NONREG^ACHS31P9"
I $$NEWCP^XPDUTL("POS10-"_%,%)
;
; --- Set appeal status if denial reversed.
S %="DENREV^ACHS31P9"
I $$NEWCP^XPDUTL("POS11-"_%,%)
Q
;
P7 ;EP-from KIDS
Q:'$G(XPDQUES("POS7"))
;
; --REMOVE OLD DD STUFF LEFT FROM VERSION 1.45
S %="V145DD^ACHS31P9"
I $$NEWCP^XPDUTL("POS12-"_%,%)
;
; ---ATTACH E SIG OPTIONS---
S %="P7OPT^ACHS31P9"
I $$NEWCP^XPDUTL("POS13-"_%,%)
Q
P8 ;EP-from KIDS
Q:'$G(XPDQUES("POS8"))
;--ONLY HAD ROUTINES IN THIS PATCH
Q
ACHS31P9 ;IHS/SET/JVK - ACHS 3.1 PATCH 9 ; [ 03/02/2004 10:16 AM ]
+1 ;;3.1;CONTRACT HEALTH MGMT SYSTEM;**9**;JUNE 11, 2001
+2 ; IHS/SET/JVK ACHS*3.1*8 2/23/2004;ORIGINAL MOD FOR P9
+3 ;
+4 IF '$GET(IOM)
DO HOME^%ZIS
+5 IF '$GET(DUZ)
WRITE !,"DUZ UNDEFINED OR 0."
DO SORRY(2)
QUIT
+6 IF '$LENGTH($GET(DUZ(0)))
WRITE !,"DUZ(0) UNDEFINED OR NULL."
DO SORRY(2)
QUIT
+7 IF '(DUZ(0)["@")
IF '$DATA(ZTQUEUED)
WRITE !,"DUZ(0) DOES NOT CONTAIN AN '@'."
DO SORRY(2)
QUIT
+8 ;
+9 SET X=$$GET1^DIQ(200,DUZ,.01)
+10 WRITE !!,$$CJ^XLFSTR("Hello, "_$PIECE(X,",",2)_" "_$PIECE(X,","),IOM)
+11 WRITE !!,$$CJ^XLFSTR("Checking Environment for "_$PIECE($TEXT(+2),";",4)_" V "_$PIECE($TEXT(+2),";",3)_" Patch "_$PIECE($TEXT(+2),";",5)_".",IOM)
+12 ;
+13 NEW IORVON,IORVOFF
+14 SET X="IORVON;IORVOFF"
+15 DO ENDR^%ZISS
+16 ;
+17 IF $$VCHK("ACHS","3.1",2,"'=")
+18 ;
+19 NEW DA,DIC
+20 SET X="ACHS"
SET DIC="^DIC(9.4,"
SET DIC(0)=""
SET D="C"
+21 DO IX^DIC
+22 IF Y<0
IF $DATA(^DIC(9.4,"C","ACHS"))
Begin DoDot:1
+23 WRITE !!,*7,*7,$$CJ^XLFSTR("You Have More Than One Entry In The",IOM),!,$$CJ^XLFSTR("PACKAGE File with an ""ACHS"" prefix.",IOM)
+24 WRITE !,$$CJ^XLFSTR(IORVON_"One entry needs to be deleted."_IORVOFF,IOM)
+25 DO SORRY(2)
+26 QUIT
End DoDot:1
+27 ;
+28 IF $GET(XPDQUIT)
WRITE !,$$CJ^XLFSTR(IORVON_"FIX IT! Before Proceeding."_IORVOFF,IOM),!!,*7,*7,*7
QUIT
+29 ;
+30 WRITE !!,$$CJ^XLFSTR("ENVIRONMENT OK.",IOM)
+31 ;
+32 DO HELP^XBHELP("INTROE","ACHS31P9")
+33 IF '$$DIR^XBDIR("E","","","","","",1)
DO SORRY(2)
QUIT
+34 ;
+35 IF $GET(XPDENV)=1
SET (XPDDIQ("XPZ1"),XPDDIQ("XPZ2"))=0
DO HELP^XBHELP("INTROI","ACHS31P9")
IF '$$DIR^XBDIR("E","","","","","",1)
DO SORRY(2)
+36 ;
+37 QUIT
+38 ;
SORRY(X) ;
+1 KILL DIFQ
+2 SET XPDQUIT=X
+3 WRITE *7,!,$$CJ^XLFSTR("Sorry....FIX IT!",IOM)
+4 QUIT
+5 ;
VCHK(ACHSPRE,ACHSVER,ACHSQUIT,ACHSCOMP) ; Check versions needed.
+1 ;
+2 NEW ACHSV
+3 SET ACHSV=$$VERSION^XPDUTL(ACHSPRE)
+4 WRITE !,$$CJ^XLFSTR("Need "_$SELECT(ACHSCOMP="<":"at least ",1:"")_ACHSPRE_" v "_ACHSVER_"....."_ACHSPRE_" v "_ACHSV_" Present",IOM)
+5 IF @(ACHSV_ACHSCOMP_ACHSVER)
DO SORRY(ACHSQUIT)
QUIT 0
+6 QUIT 1
+7 ;
PRE ;EP - From KIDS.
+1 IF $$NEWCP^XPDUTL("PRE1","AUDS^ACHS31P9")
+2 QUIT
+3 ;
POST ;EP - From KIDS.
+1 ; ---Patches 3,4,5,6 & 7 Checks installs are done in Install Questions.
+2 ; ---Question for 3 was removed, need "C" index for lookup of non-registered patients.
+3 SET %="P4^ACHS31P9"
+4 IF $$NEWCP^XPDUTL("POS4-"_%,%)
+5 SET %="P5^ACHS31P9"
+6 IF $$NEWCP^XPDUTL("POS5-"_%,%)
+7 ;
+8 SET %="P6^ACHS31P9"
+9 IF $$NEWCP^XPDUTL("POS6-"_%,%)
+10 ;
+11 SET %="P7^ACHS31P9"
+12 IF $$NEWCP^XPDUTL("POS7-"_%,%)
+13 ;
+14 SET %="P8^ACHS31P9"
+15 IF $$NEWCP^XPDUTL("POS8-"_%,%)
+16 ;
+17 ; --- Restore dd audit settings.
+18 SET %="AUDR^ACHS31P9"
+19 IF $$NEWCP^XPDUTL("POS14-"_%,%)
+20 ;
+21 ; --- Send mail message of install.
+22 SET %="MAIL^ACHS31P9"
+23 IF $$NEWCP^XPDUTL("POS15-"_%,%)
+24 ;
+25 QUIT
MAIL ;
+1 DO BMES^XPDUTL("BEGIN Delivering MailMan message to select users.")
+2 NEW DIFROM,XMSUB,XMDUZ,XMTEXT,XMY
+3 KILL ^TMP("ACHS31P9",$JOB)
+4 DO RSLT(" --- ACHS v 3.1 Patch 9, 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(""ACHS31P9"",$J,"
SET XMY(1)=""
SET XMY(DUZ)=""
+9 FOR %="ACHSZMENU","XUMGR","XUPROG","XUPROGMODE"
DO SINGLE(%)
+10 DO ^XMD
+11 KILL ^TMP("ACHS31P9",$JOB)
+12 DO MES^XPDUTL("END Delivering MailMan message to select users.")
+13 QUIT
+14 ;
RSLT(%) SET ^(0)=$GET(^TMP("ACHS31P9",$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) Routine ACHSUUP modified to fix undef of ACHSTTYP
+3 ;;###
+4 ;
INTROI ; Intro text during KIDS Install.
+1 ;;A standard message will be produced by this update.
+2 ;;
+3 ;;If you run interactively, results are displayed on your screen,
+4 ;;in the mail message and 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 ;;direct questions to the Help Desk,
+13 ;;refer to patch "ACHS*3.1*8".
+14 ;;
+15 ;;###;NOTE: This line end of text in this message.
+16 ;
+17 ; -----------------------------------------------------
+18 ; The global location for dictionary audit is:
+19 ; ^DD(FILE,0,"DDA")
+20 ; If the valuey is "Y", dd audit is on. Any other value, or the
+21 ; absence of the node, means dd audit is off.
+22 ; -----------------------------------------------------
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("ACHS31P9",0)=$$FMADD^XLFDT(DT,10)_"^"_DT_"^"_$PIECE($PIECE($TEXT(+1),";",2)," ",3,99)
+4 NEW ACHS
+5 SET ACHS=0
+6 FOR
SET ACHS=$ORDER(^XTMP("XPDI",XPDA,"FIA",ACHS))
IF 'ACHS
QUIT
Begin DoDot:1
+7 IF '$DATA(^XTMP("ACHS31P9",ACHS,"DDA"))
SET ^XTMP("ACHS31P9",ACHS,"DDA")=$GET(^DD(ACHS,0,"DDA"))
+8 DO MES^XPDUTL(" File "_$$RJ^XLFSTR(ACHS,12)_" - "_$$LJ^XLFSTR(^XTMP("XPDI",XPDA,"FIA",ACHS),30)_"- DD audit was '"_$GET(^XTMP("ACHS31P9",ACHS,"DDA"))_"'")
DO MES^XPDUTL($$RJ^XLFSTR("Set to 'Y'",69))
+9 SET ^DD(ACHS,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 ACHS
+3 SET ACHS=0
+4 FOR
SET ACHS=$ORDER(^XTMP("ACHS31P9",ACHS))
IF 'ACHS
QUIT
Begin DoDot:1
+5 SET ^DD(ACHS,0,"DDA")=^XTMP("ACHS31P9",ACHS,"DDA")
+6 DO MES^XPDUTL(" File "_$$RJ^XLFSTR(ACHS,12)_" - "_$$LJ^XLFSTR($$GET1^DID(ACHS,"","","NAME"),30)_"- DD AUDIT Set to '"_^DD(ACHS,0,"DDA")_"'")
+7 QUIT
End DoDot:1
+8 KILL ^XTMP("ACHS31P9")
+9 DO MES^XPDUTL("DD AUDIT settings restored.")
+10 QUIT
+11 ; -----------------------------------------------------
+12 ;
INSTALLD(ACHS) ; Determine if patch ACHS was installed, where ACHS 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(ACHS,"*",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(ACHS,"*",2)
+11 DO ^DIC
+12 IF Y<1
QUIT 0
+13 ; lookup patch.
+14 SET DIC=DIC_+Y_",""PAH"","
SET X=$PIECE(ACHS,"*",3)
+15 DO ^DIC
+16 QUIT $SELECT(Y<1:0,1:1)
+17 ;
+18 ; -----------------------------------------------------
+19 ; Fields to be deleted.
+20 ;File#^FileName^Field#^FieldName
DELFLD ;
+1 ;;9002069^CHS DATA CONTROL^1^*RESERVED-1
+2 ;;9002069^CHS DATA CONTROL^3^*BUDGET INDIVIDUAL ACCOU
+3 ;;9002069.03^PIGGYBACK FACILITIES^.01^PIGGYBACK FACILITIES
+4 ;;9002069^CHS DATA CONTROL^9^*PIGGYBACK FACILITIES
+5 ;;9002071.63^* DIAGNOSIS (APC) COMMENT^.01^* DIAGNOSIS (APC) COMMENT
+6 ;;9002071.06^* DIAGNOSIS (APC)^.01^* DIAGNOSIS (APC)
+7 ;;9002071.06^* DIAGNOSIS (APC)^2^* DIAGNOSIS (APC) NARRATIVE
+8 ;;9002071.06^* DIAGNOSIS (APC)^3^* DIAGNOSIS (APC) COMMENT
+9 ;;9002071.01^DENIAL NUMBER^600^* DIAGNOSIS (APC)
+10 ;;9002080^CHS FACILITY^14.1^*PROCESS PAT FOR AREA NC
+11 ;;9002080^CHS FACILITY^14.13^*PROCESS DOCUMENT RECS F
+12 ;;9002080.01^DOCUMENT^13.66^* VEND AGR NUMB (NOT USE
+13 ;;9002080.01^DOCUMENT^77^*DENTAL SERVICES
+14 ;;END
+15 ; Note: above line is a loop ender.
+16 DO BMES^XPDUTL("BEGIN Removing deleted fields from CHS data dictionaries.")
+17 NEW DA,DIK
+18 FOR ACHS=1:1
SET X=$PIECE($TEXT(DELFLD+ACHS),";",3)
IF X="END"
QUIT
Begin DoDot:1
+19 DO MES^XPDUTL($JUSTIFY("",5)_"Deleting '"_$$LJ^XLFSTR($PIECE(X,U,4),30,".")_"' from '"_$PIECE(X,U,2)_"'")
+20 SET DIK="^DD("_$PIECE(X,U,1)_","
SET DA(1)=$PIECE(X,U,1)
SET DA=$PIECE(X,U,3)
+21 DO ^DIK
+22 QUIT
+23 ; KILL ^DD(9999999.3911) ; 4 of the 0th nodes aren't KILL'd by ^DIK.
+24 QUIT
End DoDot:1
+25 DO MES^XPDUTL("END Removing deleted fields from CHS data dictionaries.")
+26 QUIT
+27 ;
DENOPT ; check for 638 facility, and add options if 638
+1 DO BMES^XPDUTL("BEGIN Checking for 638 facility.")
+2 NEW ACHS
+3 SET ACHS=0
+4 FOR
SET ACHS=$ORDER(^ACHSF(ACHS))
IF 'ACHS
QUIT
IF $PIECE(^ACHSF(ACHS,0),U,8)="Y"
Begin DoDot:1
+5 IF $$ADD^XPDMENU("ACHS DEFDEN MENU PARM","ACHSDENPARM","P638")
DO MES^XPDUTL($JUSTIFY("",5)_"Denial parameter menu option added for 638 facility")
+6 IF $$ADD^XPDMENU("ACHSDENPARM","ACHSDENPARMREA","AREA")
DO MES^XPDUTL($JUSTIFY("",5)_"Denial parameter menu option added for 638 facility")
+7 QUIT
End DoDot:1
QUIT
+8 DO MES^XPDUTL("END Checking for 638 facility.")
+9 QUIT
+10 ;
M278 ;
+1 DO BMES^XPDUTL("BEGIN Attaching 278 menu.")
+2 IF $$ADD^XPDMENU("ACHSAA","ACHS 278 MENU","278")
DO MES^XPDUTL($JUSTIFY("",5)_"278 Menu added to Document Generation menu.")
DO MES^XPDUTL($JUSTIFY("",5)_"Note that the security lock was *NOT* allocated.")
IF 1
+3 IF '$TEST
DO MES^XPDUTL($JUSTIFY("",5)_"ERROR: 278 menu attachment FAILED.")
+4 DO MES^XPDUTL("END Attaching 278 menu.")
+5 QUIT
+6 ;
NONREG ;EP - from KIDS.
+1 DO BMES^XPDUTL("BEGIN Re-index of Patient Name in Denials.")
+2 NEW ACHS,DA,DIK
+3 SET ACHS=0
+4 FOR
SET ACHS=$ORDER(^ACHSDEN(ACHS))
IF 'ACHS
QUIT
Begin DoDot:1
+5 KILL ^ACHSDEN(ACHS,"D","C"),^ACHSDEN(ACHS,"D","N")
+6 SET DIK="^ACHSDEN("_ACHS_",""D"""_","
SET DA(1)=ACHS
+7 FOR DIK(1)="7^C","10^C"
DO ENALL^DIK
+8 QUIT
End DoDot:1
+9 DO MES^XPDUTL("END Re-index of Patient Name in Denials.")
+10 QUIT
DENREV ;EP - From KIDS.
+1 ;SETS DENIAL STATUS IF DENIAL WAS REVERSED
+2 NEW ACHS
+3 SET ACHSASTA=0
SET ACHSDA=0
SET ACHS=0
+4 SET ACHSASTA=$ORDER(^ACHSDENA("B","REVERSED AFTER APPEAL",ACHSASTA))
+5 FOR
SET ACHS=$ORDER(^ACHSDEN(ACHS))
IF ACHS'?1N.N
QUIT
Begin DoDot:1
+6 SET ACHSDA=0
+7 FOR
SET ACHSDA=$ORDER(^ACHSDEN(ACHS,"D",ACHSDA))
IF ACHSDA'?1N.N
QUIT
Begin DoDot:2
+8 SET ACHSDSTA=$PIECE(^ACHSDEN(ACHS,"D",ACHSDA,0),U,8)
+9 IF '$DATA(^ACHSDEN(ACHS,"D",ACHSDA,400,0))
QUIT
+10 IF ACHSDSTA["R"
SET $PIECE(^ACHSDEN(ACHS,"D",ACHSDA,400,0),U,3)=ACHSASTA
End DoDot:2
End DoDot:1
+11 KILL ACHSASTA,ACHSDA
+12 QUIT
V145DD ;EP - From KIDS
+1 ;GETS RID OF VERSION 1.45 DD'S LEFT BEHINDE
+2 KILL ^UTILITY("XBDSET",$JOB)
+3 FOR XBBPI=1:1
SET XBBPIX=$PIECE($TEXT(LIST+XBBPI),";;",2)
IF XBBPIX="END"
QUIT
SET XBBPIY=$PIECE(XBBPIX,"=",2,99)
SET XBBPIX=$PIECE(XBBPIX,"=",1)
SET @XBBPIX=XBBPIY
+4 KILL XBBPI,XBBPIX,XBBPIY
DO EN2^XBKD
+5 QUIT
LIST ;
+1 ;;^UTILITY("XBDSET",$J,1803100)=S^S
+2 ;;^UTILITY("XBDSET",$J,1803101)=S^S
+3 ;;^UTILITY("XBDSET",$J,1803102)=S^S
+4 ;;^UTILITY("XBDSET",$J,1803103)=S^S
+5 ;;^UTILITY("XBDSET",$J,1803104)=S^S
+6 ;;^UTILITY("XBDSET",$J,1803107)=S^S
+7 ;;^UTILITY("XBDSET",$J,1803109)=S^S
+8 ;;^UTILITY("XBDSET",$J,1803110)=S^S
+9 ;;^UTILITY("XBDSET",$J,1803111)=S^S
+10 ;;^UTILITY("XBDSET",$J,1803112)=S^S
+11 ;;^UTILITY("XBDSET",$J,1803113)=S^S
+12 ;;^UTILITY("XBDSET",$J,1803114)=S^S
+13 ;;^UTILITY("XBDSET",$J,1803115)=S^S
+14 ;;END
+15 ;Note above line ends loop
P7OPT ;EP -FROM KIDS
+1 ;ADD NEW OPTIONS FOR PATCH 7, ELECTRONIC SIGNATURE AND ELECTRONIC
+2 ;SIGNATURE REPORTS
+3 DO BMES^XPDUTL("Adding new options.")
+4 IF $$ADD^XPDMENU("ACHSMENU","ACHS E-SIG MENU","EMNU")
DO MES^XPDUTL($JUSTIFY("",5)_"Electronic Signature Authorization Menu to main CHS Menu")
+5 IF $$ADD^XPDMENU("ACHS E-SIG MENU","ACHS E-SIG AUTHORIZING OFC.","SIGA")
+6 IF $$ADD^XPDMENU("ACHS E-SIG MENU","ACHS E-SIG ORDERING OFC.","SIGO")
DO MES^XPDUTL($JUSTIFY("",5)_"Electronic Signature for Authorizing Official, Electronic Signature for Ordering Official")
+7 IF $$ADD^XPDMENU("ACHSREPORTS","ACHS E-SIG REPORTS","ERPT")
+8 IF $$ADD^XPDMENU("ACHS E-SIG REPORTS","ACHS E-SIG APPROVED REPORT","ESAP")
+9 IF $$ADD^XPDMENU("ACHS E-SIG REPORTS","ACHS E-SIG PENDING SIG REPORT","ESPD")
+10 DO MES^XPDUTL($JUSTIFY("",5)_"Options in E-Signature Reports added")
+11 IF $$ADD^XPDMENU("ACHSMGPAR","ACHS E-SIG ADD EDIT USERS","EOFF")
+12 IF $$ADD^XPDMENU("ACHSMGPAR","ACHS E-SIG SITE PARAMETER","ESIT")
DO MES^XPDUTL($JUSTIFY("",5)_"Option for adding Authorized E-Signature users and E-Site Paramaters added to facility management options")
+13 IF $$ADD^XPDMENU("ACHSMGR","ACHSMGPAR")
DO MES^XPDUTL($JUSTIFY("",5)_"Attach E-Sig to facility Management")
+14 DO MES^XPDUTL("Key for E-Sig Menu is ACHSZESIG,for Adding authorized users is ACHSZPARM.")
+15 DO MES^XPDUTL("END updating options.")
+16 QUIT
+17 ;
P6OPT ;EP - FROM KIDS.
+1 ;ADD NEW OPTIONS FOR PATCH 6, DENIAL APPEAL,EDITS AND CANCEL, FI FIELD
+2 DO BMES^XPDUTL("Begin adding new options.")
+3 IF $$ADD^XPDMENU("ACHSAA","ACHSFIM","FIM")
DO MES^XPDUTL($JUSTIFY("",5)_"Send approval Message to FI added to Document Generation Menu")
+4 IF $$ADD^XPDMENU("ACHS DEFDEN MENU","ACHS DEN APPEAL MENU","APP")
DO MES^XPDUTL($JUSTIFY("",5)_"Denial Appeal menu option added to CHS Denial/Deferred ServciesMenu")
+5 DO MES^XPDUTL("END updating options.")
+6 QUIT
+7 ;
P4 ;EP - from KIDS.
+1 IF '$GET(XPDQUES("POS4"))
QUIT
+2 DO BMES^XPDUTL("BEGIN Re-index of Patient Name in Deferred Services.")
+3 NEW ACHS,DA,DIK
+4 SET ACHS=0
+5 FOR
SET ACHS=$ORDER(^ACHSDEF(ACHS))
IF 'ACHS
QUIT
Begin DoDot:1
+6 KILL ^ACHSDEF(ACHS,"D","C"),^ACHSDEF(ACHS,"D","N")
+7 SET DIK="^ACHSDEF("_ACHS_",""D"""_","
SET DA(1)=ACHS
+8 FOR DIK(1)="6^C","7^N"
DO ENALL^DIK
+9 QUIT
End DoDot:1
+10 DO MES^XPDUTL("END Re-index of Patient Name in Deferred Services.")
+11 QUIT
+12 ;
P5 ;EP - from KIDS
+1 IF '$GET(XPDQUES("POS5"))
QUIT
+2 ;
+3 ; --- Atch Denial ltr edit option at 638 sites.
+4 SET %="DENOPT^ACHS31P9"
+5 IF $$NEWCP^XPDUTL("POS5-"_%,%)
+6 ;
+7 ; --- Delete fields in CHS files marked for deletion.
+8 SET %="DELFLD^ACHS31P9"
+9 IF $$NEWCP^XPDUTL("POS6-"_%,%)
+10 ;
+11 ; --- Atch 278 menu to Doc edit option.
+12 SET %="M278^ACHS31P9"
+13 IF $$NEWCP^XPDUTL("POS7-"_%,%)
+14 ;
+15 ; --- Remove non-standard option auditing from CHS options.
+16 SET %="POS^ACHS31P0"
+17 IF $$NEWCP^XPDUTL("POS8-"_%,%)
+18 QUIT
P6 ;EP - from KIDS
+1 IF '$GET(XPDQUES("POS6"))
QUIT
+2 ;
+3 ; --- Atch Denial APPEAL option.
+4 SET %="P6OPT^ACHS31P9"
+5 IF $$NEWCP^XPDUTL("POS9-"_%,%)
+6 ;
+7 ; --- Re-index non-registered patient name.
+8 SET %="NONREG^ACHS31P9"
+9 IF $$NEWCP^XPDUTL("POS10-"_%,%)
+10 ;
+11 ; --- Set appeal status if denial reversed.
+12 SET %="DENREV^ACHS31P9"
+13 IF $$NEWCP^XPDUTL("POS11-"_%,%)
+14 QUIT
+15 ;
P7 ;EP-from KIDS
+1 IF '$GET(XPDQUES("POS7"))
QUIT
+2 ;
+3 ; --REMOVE OLD DD STUFF LEFT FROM VERSION 1.45
+4 SET %="V145DD^ACHS31P9"
+5 IF $$NEWCP^XPDUTL("POS12-"_%,%)
+6 ;
+7 ; ---ATTACH E SIG OPTIONS---
+8 SET %="P7OPT^ACHS31P9"
+9 IF $$NEWCP^XPDUTL("POS13-"_%,%)
+10 QUIT
P8 ;EP-from KIDS
+1 IF '$GET(XPDQUES("POS8"))
QUIT
+2 ;--ONLY HAD ROUTINES IN THIS PATCH
+3 QUIT