VistA-WorldVistAEHR/r/AUTOMATED_MED_INFO_EXCHANGE.../DVBA2815.m

116 lines
4.5 KiB
Mathematica

DVBA2815 ;SPH - PATCH DRIVER ; 9/27/06
;;2.7;AMIE;**115**;Apr 10, 1995
;
; Make sure to call each exam name being sent in the patch
; This routine will find existing matching entries and will ensure they're disabled.
; Call as a pre-init or else it'll disable the exams just loaded.
PRE ;
N DVBVERSS,DVBVERSN
S DVBVERSS="115F" ; What the version will be in the incoming file
S DVBVERSN="115" ; What the final version should be named
W !!!,"**** PRE-PROCESSING ****",!!
D DISABLE("ACROMEGALY")
D DISABLE("AMPUTATION")
D DISABLE("RESIDUALS OF AMPUTATIONS")
D DISABLE("COLD INJURY PROTOCOL EXAMINATION")
D DISABLE("CUSHINGS SYNDROME")
D DISABLE("DENTAL AND ORAL")
D DISABLE("ENDOCRINE, MISCELLANEOUS")
D DISABLE("MISCELLANEOUS ENDOCRINE DISEASES")
D DISABLE("HEMIC DISORDERS")
D DISABLE("LYMPHATIC DISORDERS")
D DISABLE("MOUTH, LIPS AND TONGUE")
D DISABLE("MUSCLES")
D DISABLE("PULMONARY TUBERCULOSIS AND MYCOBACTERIAL DISEASES")
D DISABLE("RESPIRATORY DISEASES, MISCELLANEOUS")
D DISABLE("SENSE OF SMELL AND TASTE")
D DISABLE("SOCIAL WORK AND INDUSTRIAL SURVEY")
D DISABLE("SOCIAL AND INDUSTRIAL SURVEY")
D DISABLE("SPINE")
D DISABLE("THYROID AND PARATHYROID DISEASES")
Q
POST ;
N DVBVERSS,DVBVERSN
S DVBVERSS="115F" ; What the version will be in the incoming file
S DVBVERSN="115" ; What the final version should be named
W !!!,"**** POST-PROCESSING ****",!!
D POSTP("ACROMEGALY")
D POSTP("AMPUTATION")
D POSTP("COLD INJURY PROTOCOL EXAMINATION")
D POSTP("CUSHINGS SYNDROME")
D POSTP("DENTAL AND ORAL")
D POSTP("ENDOCRINE, MISCELLANEOUS")
D POSTP("HEMIC DISORDERS")
D POSTP("LYMPHATIC DISORDERS")
D POSTP("MOUTH, LIPS AND TONGUE")
D POSTP("MUSCLES")
D POSTP("PULMONARY TUBERCULOSIS AND MYCOBACTERIAL DISEASES")
D POSTP("RESPIRATORY DISEASES, MISCELLANEOUS")
D POSTP("SENSE OF SMELL AND TASTE")
D POSTP("SOCIAL AND INDUSTRIAL SURVEY")
D POSTP("SPINE")
D POSTP("THYROID AND PARATHYROID DISEASES")
D RBXREF
Q
POSTP(NM) ;
; Rename XXXXXXX~imported version to XXXXXXX~new version
N DVBABCNT,DVBABIEN,DVBABST,DVBACH
N DVBABCN2,DVBABIE2,DVBABS2
S DVBABCNT=0,DVBABIEN=0
F S DVBABIEN=$O(^DVB(396.18,DVBABIEN)) Q:'DVBABIEN D
.S DVBABST=$P($G(^DVB(396.18,DVBABIEN,0)),"^",1)
.I $P(DVBABST,"~",1)=NM I $P(DVBABST,"~",2)=DVBVERSS D
..;Check and be sure the new version isn't in the file yet
..S DVBABCN2=0,DVBABIE2=0,DVBACH=0
..F S DVBABIE2=$O(^DVB(396.18,DVBABIE2)) Q:'DVBABIE2 D
...S DVBABS2=$P($G(^DVB(396.18,DVBABIE2,0)),"^",1)
...I $P(DVBABS2,"~",1)=NM I $P(DVBABS2,"~",2)=DVBVERSN S DVBACH=1
..;If new version is found, delete the import version and don't import
..I DVBACH=1 D
...W "FOUND EXISTING "_NM_". NO MODIFICATIONS MADE.",!
...K ^DVB(396.18,DVBABIEN)
..;If existing version isn't found, go ahead and rename imported entry to new version name
..I DVBACH=0 D
...S $P(^DVB(396.18,DVBABIEN,0),"^",1)=NM_"~"_DVBVERSN
...W "ACTIVATED: "_$P($G(^DVB(396.18,DVBABIEN,0)),"^",1),!
K DVBABCNT,DVBABIEN,DVBABST,DVBACH
Q
RBXREF ;
; Rebuild cross-references
; XRef: B
W !!,"CLEANING UP FILES AND REBUILDING 2 CROSS-REFERENCES.",!,"THIS MAY TAKE A FEW MINUTES.",!
W !!,"REBUILDING 'B' XREF, CAPRI TEMPLATE DEFINITIONS FILE",!
N DA,DIK,REGIEN,ROOT
S ROOT=$$ROOT^DILFD(396.18,,1) K @ROOT@("B")
S REGIEN=0
F S REGIEN=$O(@ROOT@(REGIEN)) Q:'REGIEN D
. S DIK=$$ROOT^DILFD(396.18,","_REGIEN_","),DIK(1)=".01^B"
. S DA(1)=REGIEN D ENALL^DIK
;
; XRef: AV
W !!,"REBUILDING 'AV' XREF, CAPRI TEMPLATE DEFINITIONS FILE",!
N DA,DIK,REGIEN,ROOT
S ROOT=$$ROOT^DILFD(396.18,,1) K @ROOT@("AV")
S REGIEN=0
F S REGIEN=$O(@ROOT@(REGIEN)) Q:'REGIEN D
. S DIK=$$ROOT^DILFD(396.18,","_REGIEN_","),DIK(1)=".01^AV"
. S DA(1)=REGIEN D ENALL^DIK
K DA,DIK,REGIEN,ROOT
Q
DISABLE(NM) ;
; First look for matches and turn off the "selectable by user field"
; This will keep the entry from showing in the list
; Next, look at disabled date. If there's no date, set it to today.
; File is 396.18. Field 3 is de-activation date. Field 7 is selectable by user (0=no)
N DVBABCNT,DVBABIEN,DVBABST,DVBACH
S DVBABCNT=0,DVBABIEN=0
F S DVBABIEN=$O(^DVB(396.18,DVBABIEN)) Q:'DVBABIEN D
.S DVBABST=$P($G(^DVB(396.18,DVBABIEN,0)),"^",1)
.I $P(DVBABST,"~",1)=NM I $P(DVBABST,"~",2)'=DVBVERSN D
..S DVBACH=0
..I $P(^DVB(396.18,DVBABIEN,6),"^",1)'="0" S $P(^DVB(396.18,DVBABIEN,6),"^",1)="0",DVBACH=1
..I $P(^DVB(396.18,DVBABIEN,2),"^",2)="" S $P(^DVB(396.18,DVBABIEN,2),"^",2)=DT,DVBACH=1 ; This is deactivation date
..I DVBACH=1 W "MODIFIED: "_DVBABST,!
K DVBABCNT,DVBABIEN,DVBABST,DVBACH
Q