VistA-FOIAVistA/r/ORDER_ENTRY_RESULTS_REPORTI.../OCXDI02C.m

181 lines
5.0 KiB
Mathematica

OCXDI02C ;SLC/RJS,CLA - OCX PACKAGE DIAGNOSTIC ROUTINES ;SEP 7,1999 at 10:30
;;3.0;ORDER ENTRY/RESULTS REPORTING;**32**;Dec 17,1997
;; ;;ORDER CHECK EXPERT version 1.01 released OCT 29,1998
;
S ;
;
D DOT^OCXDIAG
;
;
K REMOTE,LOCAL,OPCODE,REF
F LINE=1:1:500 S TEXT=$P($T(DATA+LINE),";",2,999) Q:TEXT I $L(TEXT) D Q:QUIT
.S ^TMP("OCXDIAG",$J,$O(^TMP("OCXDIAG",$J,"A"),-1)+1)=TEXT
;
G ^OCXDI02D
;
Q
;
DATA ;
;
;;D^ORDER CHECK DATA CONTEXT
;;R^"863:",.02,"E"
;;D^860.6
;;EOR^
;;EOF^OCXS(863)^1
;;SOF^860.9 ORDER CHECK NATIONAL TERM
;;KEY^860.9:^SERUM CREATININE
;;R^"860.9:",.01,"E"
;;D^SERUM CREATININE
;;R^"860.9:",.02,"E"
;;D^60
;;EOR^
;;KEY^860.9:^SERUM UREA NITROGEN
;;R^"860.9:",.01,"E"
;;D^SERUM UREA NITROGEN
;;R^"860.9:",.02,"E"
;;D^60
;;EOR^
;;KEY^860.9:^DNR
;;R^"860.9:",.01,"E"
;;D^DNR
;;R^"860.9:",.02,"E"
;;D^101.43
;;EOR^
;;KEY^860.9:^PROTHROMBIN TIME
;;R^"860.9:",.01,"E"
;;D^PROTHROMBIN TIME
;;R^"860.9:",.02,"E"
;;D^101.43
;;EOR^
;;KEY^860.9:^NPO
;;R^"860.9:",.01,"E"
;;D^NPO
;;R^"860.9:",.02,"E"
;;D^101.43
;;EOR^
;;KEY^860.9:^SERUM SPECIMEN
;;R^"860.9:",.01,"E"
;;D^SERUM SPECIMEN
;;R^"860.9:",.02,"E"
;;D^61
;;EOR^
;;KEY^860.9:^PARTIAL THROMBOPLASTIN TIME
;;R^"860.9:",.01,"E"
;;D^PARTIAL THROMBOPLASTIN TIME
;;R^"860.9:",.02,"E"
;;D^101.43
;;EOR^
;;KEY^860.9:^ANGIOGRAM (PERIPHERAL)
;;R^"860.9:",.01,"E"
;;D^ANGIOGRAM (PERIPHERAL)
;;R^"860.9:",.02,"E"
;;D^101.43
;;EOR^
;;KEY^860.9:^WBC
;;R^"860.9:",.01,"E"
;;D^WBC
;;R^"860.9:",.02,"E"
;;D^60
;;EOR^
;;KEY^860.9:^BLOOD SPECIMEN
;;R^"860.9:",.01,"E"
;;D^BLOOD SPECIMEN
;;R^"860.9:",.02,"E"
;;D^61
;;EOR^
;;KEY^860.9:^ONE TIME MED
;;R^"860.9:",.01,"E"
;;D^ONE TIME MED
;;R^"860.9:",.02,"E"
;;D^51.1
;;R^"860.9:",2,"E"
;;D^I $E($P(^(0),U,4),1,2)="PS"
;;EOR^
;;EOF^OCXS(860.9)^1
;;SOF^860.8 ORDER CHECK COMPILER FUNCTIONS
;;KEY^860.8:^CONVERT DATE FROM FILEMAN FORMAT TO OCX FORMAT
;;R^"860.8:",.01,"E"
;;D^CONVERT DATE FROM FILEMAN FORMAT TO OCX FORMAT
;;R^"860.8:",.02,"E"
;;D^DT2INT
;;R^"860.8:",1,1
;;D^ ;DT2INT(OCXDT) ; This Local Extrinsic Function converts a date into an integer
;;R^"860.8:",1,2
;;D^ ; ; By taking the Years, Months, Days, Hours and Minutes converting
;;R^"860.8:",1,3
;;D^ ; ; Them into Seconds and then adding them all together into one big integer
;;R^"860.8:",100,1
;;D^ ;DT2INT(OCXDT) ; This Local Extrinsic Function converts a date into an integer
;;R^"860.8:",100,2
;;D^ ; ; By taking the Years, Months, Days, Hours and Minutes converting
;;R^"860.8:",100,3
;;D^ ; ; Them into Seconds and then adding them all together into one big integer
;;R^"860.8:",100,4
;;D^ ; ;
;;R^"860.8:",100,5
;;D^ ; Q:'$L($G(OCXDT)) ""
;;R^"860.8:",100,6
;;D^ ; N OCXVAL S OCXVAL=0
;;R^"860.8:",100,7
;;D^ ; I (OCXDT?5N1","5N) Q (OCXDT*86400+$P(OCXDT,",",2)) ; $H FORMAT
;;R^"860.8:",100,8
;;D^ ; I ($E(OCXDT,1)="T") D Q OCXVAL ; TODAY
;;R^"860.8:",100,9
;;D^ ; .S OCXVAL=$H*86400
;;R^"860.8:",100,10
;;D^ ; .S:(OCXDT["+") OCXVAL=OCXVAL+($P(OCXDT,"+",2)*86400)
;;R^"860.8:",100,11
;;D^ ; .S:(OCXDT["-") OCXVAL=OCXVAL-($P(OCXDT,"-",2)*86400)
;;R^"860.8:",100,12
;;D^ ; I ($E(OCXDT,1)="N") D Q OCXVAL ; NOW
;;R^"860.8:",100,13
;;D^ ; .S OCXVAL=$H*86400+$P($H,",",2)
;;R^"860.8:",100,14
;;D^ ; .S:(OCXDT["+") OCXVAL=OCXVAL+($P(OCXDT,"+",2)*86400)
;;R^"860.8:",100,15
;;D^ ; .S:(OCXDT["-") OCXVAL=OCXVAL-($P(OCXDT,"-",2)*86400)
;;R^"860.8:",100,16
;;D^ ; I +OCXDT,($L(OCXDT\1)=7) S OCXDT=($E(OCXDT,1,3)+1700)_$E(OCXDT,4,7)_$S((OCXDT["."):$P(OCXDT,".",2),1:"") ; CONVERT INTERNAL FILEMAN FORMAT TO HL7 FORMAT
;;R^"860.8:",100,17
;;D^ ; I +OCXDT,($L(OCXDT\1)>7) D Q OCXVAL ; HL7 FORMAT
;;R^"860.8:",100,18
;;D^ ; .S OCXVAL=($E(OCXDT,1,4)-1841*365)+($E(OCXDT,1,4)\4-460)-($E(OCXDT,1,4)\200-9) ; ADJUST FOR LEAP YEARS
;;R^"860.8:",100,19
;;D^ ; .S OCXVAL=OCXVAL+$P("000^031^059^090^120^151^181^212^243^273^304^334",U,$E(OCXDT,5,6)) ; MONTHS TO DAYS
;;R^"860.8:",100,20
;;D^ ; .S OCXVAL=OCXVAL+$E(OCXDT,7,8)-1 ; ADD DAYS
;;R^"860.8:",100,21
;;D^ ; .S OCXVAL=OCXVAL*86400 ; CONVERT TO SECONDS
;;R^"860.8:",100,22
;;D^ ; .S OCXVAL=OCXVAL+($E(OCXDT,9,10)*3600)+($E(OCXDT,11,12)*60)+$E(OCXDT,13,14) ; ADD TIME
;;R^"860.8:",100,23
;;D^ ; Q OCXDT
;;R^"860.8:",100,24
;;D^ ; ;
;;EOR^
;;KEY^860.8:^PTRNODE
;;R^"860.8:",.01,"E"
;;D^PTRNODE
;;R^"860.8:",.02,"E"
;;D^PTRNODE
;;R^"860.8:",1,1
;;D^ ;PTRNODE(OCXFIL,OCXKEY,OCXNODE) ; This Local Extrinsic Function returns the specified Node (OCXNODE)
;;R^"860.8:",1,2
;;D^ ; ; From the specified record (OCXKEY) in a file (OCXFIL).
;;R^"860.8:",1,3
;;D^ ; ;
;;R^"860.8:",100,1
;;D^ ;PTRNODE(OCXFIL,OCXKEY,OCXNODE) ; This Local Extrinsic Function returns the specified Node (OCXNODE)
;;R^"860.8:",100,2
;;D^ ; ; From the specified record (OCXKEY) in a file (OCXFIL).
;;R^"860.8:",100,3
;;D^ ; ;
;;R^"860.8:",100,4
;;D^ ; ;
;;R^"860.8:",100,5
;;D^ ; N OCXDATA,OCXSUB,OCXGL S OCXDATA=0
;;R^"860.8:",100,6
;;D^ ; Q:'$L(OCXFIL) "" Q:'$L($G(OCXKEY)) "" S:'$L($G(OCXNODE)) OCXNODE=0
;1;
;