Home   Package List   Routine Alphabetical List   Global Alphabetical List   FileMan Files List   FileMan Sub-Files List   Package Component Lists   Package-Namespace Mapping  
Routine: OCXRU006

OCXRU006.m

Go to the documentation of this file.
  1. OCXRU006 ;SLC/RJS,CLA - OCX PACKAGE RULE TRANSPORT ROUTINE (Delete after Install of OR*3*96) ;JAN 30,2001 at 11:16
  1. ;;3.0;ORDER ENTRY/RESULTS REPORTING;**96**;Dec 17,1997
  1. ;; ;;ORDER CHECK EXPERT version 1.01 released OCT 29,1998
  1. ;
  1. S ;
  1. ;
  1. D DOT^OCXRULE
  1. ;
  1. ;
  1. K REMOTE,LOCAL,OPCODE,REF
  1. F LINE=1:1:500 S TEXT=$P($T(DATA+LINE),";",2,999) Q:TEXT I $L(TEXT) D Q:QUIT
  1. .S ^TMP("OCXRULE",$J,$O(^TMP("OCXRULE",$J,"A"),-1)+1)=TEXT
  1. ;
  1. G ^OCXRU007
  1. ;
  1. Q
  1. ;
  1. DATA ;
  1. ;
  1. ;;R^"863.3:","863.32:1",1,"E"
  1. ;;D^FLAB(|PATIENT IEN|,"SERUM CREATININE^SERUM UREA NITROGEN","SERUM SPECIMEN")
  1. ;;EOR^
  1. ;;EOF^OCXS(863.3)^1
  1. ;;SOF^860.9 ORDER CHECK NATIONAL TERM
  1. ;;KEY^860.9:^ANGIOGRAM (PERIPHERAL)
  1. ;;R^"860.9:",.01,"E"
  1. ;;D^ANGIOGRAM (PERIPHERAL)
  1. ;;R^"860.9:",.02,"E"
  1. ;;D^101.43
  1. ;;EOR^
  1. ;;KEY^860.9:^BLOOD SPECIMEN
  1. ;;R^"860.9:",.01,"E"
  1. ;;D^BLOOD SPECIMEN
  1. ;;R^"860.9:",.02,"E"
  1. ;;D^61
  1. ;;EOR^
  1. ;;KEY^860.9:^DANGEROUS MEDS FOR PTS > 64
  1. ;;R^"860.9:",.01,"E"
  1. ;;D^DANGEROUS MEDS FOR PTS > 64
  1. ;;R^"860.9:",.02,"E"
  1. ;;D^101.43
  1. ;;R^"860.9:",2,"E"
  1. ;;D^I $P($G(^ORD(100.98,$P($G(^ORD(101.43,+Y,0)),U,5),0)),U)="PHARMACY"
  1. ;;EOR^
  1. ;;KEY^860.9:^DNR
  1. ;;R^"860.9:",.01,"E"
  1. ;;D^DNR
  1. ;;R^"860.9:",.02,"E"
  1. ;;D^101.43
  1. ;;EOR^
  1. ;;KEY^860.9:^FOOD-DRUG INTERACTION MED
  1. ;;R^"860.9:",.01,"E"
  1. ;;D^FOOD-DRUG INTERACTION MED
  1. ;;R^"860.9:",.02,"E"
  1. ;;D^101.43
  1. ;;R^"860.9:",2,"E"
  1. ;;D^I $P($G(^ORD(100.98,$P($G(^ORD(101.43,+Y,0)),U,5),0)),U)="PHARMACY"
  1. ;;EOR^
  1. ;;KEY^860.9:^NPO
  1. ;;R^"860.9:",.01,"E"
  1. ;;D^NPO
  1. ;;R^"860.9:",.02,"E"
  1. ;;D^101.43
  1. ;;EOR^
  1. ;;KEY^860.9:^ONE TIME MED
  1. ;;R^"860.9:",.01,"E"
  1. ;;D^ONE TIME MED
  1. ;;R^"860.9:",.02,"E"
  1. ;;D^51.1
  1. ;;R^"860.9:",2,"E"
  1. ;;D^I $E($P(^(0),U,4),1,2)="PS"
  1. ;;EOR^
  1. ;;KEY^860.9:^PARTIAL THROMBOPLASTIN TIME
  1. ;;R^"860.9:",.01,"E"
  1. ;;D^PARTIAL THROMBOPLASTIN TIME
  1. ;;R^"860.9:",.02,"E"
  1. ;;D^101.43
  1. ;;EOR^
  1. ;;KEY^860.9:^PROTHROMBIN TIME
  1. ;;R^"860.9:",.01,"E"
  1. ;;D^PROTHROMBIN TIME
  1. ;;R^"860.9:",.02,"E"
  1. ;;D^101.43
  1. ;;EOR^
  1. ;;KEY^860.9:^SERUM CREATININE
  1. ;;R^"860.9:",.01,"E"
  1. ;;D^SERUM CREATININE
  1. ;;R^"860.9:",.02,"E"
  1. ;;D^60
  1. ;;EOR^
  1. ;;KEY^860.9:^SERUM SPECIMEN
  1. ;;R^"860.9:",.01,"E"
  1. ;;D^SERUM SPECIMEN
  1. ;;R^"860.9:",.02,"E"
  1. ;;D^61
  1. ;;EOR^
  1. ;;KEY^860.9:^SERUM UREA NITROGEN
  1. ;;R^"860.9:",.01,"E"
  1. ;;D^SERUM UREA NITROGEN
  1. ;;R^"860.9:",.02,"E"
  1. ;;D^60
  1. ;;EOR^
  1. ;;KEY^860.9:^WBC
  1. ;;R^"860.9:",.01,"E"
  1. ;;D^WBC
  1. ;;R^"860.9:",.02,"E"
  1. ;;D^60
  1. ;;EOR^
  1. ;;EOF^OCXS(860.9)^1
  1. ;;SOF^860.8 ORDER CHECK COMPILER FUNCTIONS
  1. ;;KEY^860.8:^CONVERT DATE FROM FILEMAN FORMAT TO OCX FORMAT
  1. ;;R^"860.8:",.01,"E"
  1. ;;D^CONVERT DATE FROM FILEMAN FORMAT TO OCX FORMAT
  1. ;;R^"860.8:",.02,"E"
  1. ;;D^DT2INT
  1. ;;R^"860.8:",1,1
  1. ;;D^ ;DT2INT(OCXDT) ; This Local Extrinsic Function converts a date into an integer
  1. ;;R^"860.8:",1,2
  1. ;;D^ ; ; By taking the Years, Months, Days, Hours and Minutes converting
  1. ;;R^"860.8:",1,3
  1. ;;D^ ; ; Them into Seconds and then adding them all together into one big integer
  1. ;;R^"860.8:",100,1
  1. ;;D^ ;DT2INT(OCXDT) ; This Local Extrinsic Function converts a date into an integer
  1. ;;R^"860.8:",100,2
  1. ;;D^ ; ; By taking the Years, Months, Days, Hours and Minutes converting
  1. ;;R^"860.8:",100,3
  1. ;;D^ ; ; Them into Seconds and then adding them all together into one big integer
  1. ;;R^"860.8:",100,4
  1. ;;D^ ; ;
  1. ;;R^"860.8:",100,5
  1. ;;D^ ; Q:'$L($G(OCXDT)) ""
  1. ;;R^"860.8:",100,6
  1. ;;D^ ; N OCXVAL S OCXVAL=0
  1. ;;R^"860.8:",100,7
  1. ;;D^ ; I (OCXDT?5N1","5N) Q (OCXDT*86400+$P(OCXDT,",",2)) ; $H FORMAT
  1. ;;R^"860.8:",100,8
  1. ;;D^ ; I ($E(OCXDT,1)="T") D Q OCXVAL ; TODAY
  1. ;;R^"860.8:",100,9
  1. ;;D^ ; .S OCXVAL=$H*86400
  1. ;;R^"860.8:",100,10
  1. ;;D^ ; .S:(OCXDT["+") OCXVAL=OCXVAL+($P(OCXDT,"+",2)*86400)
  1. ;;R^"860.8:",100,11
  1. ;;D^ ; .S:(OCXDT["-") OCXVAL=OCXVAL-($P(OCXDT,"-",2)*86400)
  1. ;;R^"860.8:",100,12
  1. ;;D^ ; I ($E(OCXDT,1)="N") D Q OCXVAL ; NOW
  1. ;;R^"860.8:",100,13
  1. ;;D^ ; .S OCXVAL=$H*86400+$P($H,",",2)
  1. ;;R^"860.8:",100,14
  1. ;;D^ ; .S:(OCXDT["+") OCXVAL=OCXVAL+($P(OCXDT,"+",2)*86400)
  1. ;;R^"860.8:",100,15
  1. ;;D^ ; .S:(OCXDT["-") OCXVAL=OCXVAL-($P(OCXDT,"-",2)*86400)
  1. ;;R^"860.8:",100,16
  1. ;;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
  1. ;;R^"860.8:",100,17
  1. ;;D^ ; I +OCXDT,($L(OCXDT\1)>7) D Q OCXVAL ; HL7 FORMAT
  1. ;;R^"860.8:",100,18
  1. ;;D^ ; .S OCXVAL=($E(OCXDT,1,4)-1841*365) ; YEARS TO DAYS
  1. ;;R^"860.8:",100,19
  1. ;;D^ ; .S OCXVAL=OCXVAL+($E(OCXDT,1,4)\4-460)-($E(OCXDT,1,4)\200-9)+($E(OCXDT,1,4)\1000-1) ; ADJUST FOR LEAP YEARS
  1. ;;R^"860.8:",100,20
  1. ;;D^ ; .I '($E(OCXDT,1,4)#4),($E(OCXDT,1,4)#200),($E(OCXDT,5,6)<3) S OCXVAL=OCXVAL-1
  1. ;;R^"860.8:",100,21
  1. ;;D^ ; .I '($E(OCXDT,1,4)#1000),($E(OCXDT,5,6)<3) S OCXVAL=OCXVAL-1
  1. ;;R^"860.8:",100,22
  1. ;;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
  1. ;;R^"860.8:",100,23
  1. ;;D^ ; .S OCXVAL=OCXVAL+$E(OCXDT,7,8)-1 ; ADD DAYS
  1. ;;R^"860.8:",100,24
  1. ;;D^ ; .S OCXVAL=OCXVAL*86400 ; CONVERT TO SECONDS
  1. ;;R^"860.8:",100,25
  1. ;;D^ ; .S OCXVAL=OCXVAL+($E(OCXDT,9,10)*3600)+($E(OCXDT,11,12)*60)+$E(OCXDT,13,14) ; ADD TIME
  1. ;;R^"860.8:",100,26
  1. ;;D^ ; Q OCXDT
  1. ;;R^"860.8:",100,27
  1. ;;D^ ; ;
  1. ;;EOR^
  1. ;;KEY^860.8:^CONVERT DATE FROM OCX FORMAT TO READABLE FORMAT
  1. ;;R^"860.8:",.01,"E"
  1. ;;D^CONVERT DATE FROM OCX FORMAT TO READABLE FORMAT
  1. ;;R^"860.8:",.02,"E"
  1. ;;D^INT2DT
  1. ;;R^"860.8:",1,1
  1. ;;D^ ;INT2DT(OCXDT,OCXF) ; This Local Extrinsic Function converts an OCX internal format
  1. ;;R^"860.8:",1,2
  1. ;;D^ ; ; date into an Externl Format (Human Readable) date. 'OCXF=SHORT FORMAT OCXF=LONG FORMAT
  1. ;;R^"860.8:",1,3
  1. ;;D^ ; ;
  1. ;;R^"860.8:",100,1
  1. ;;D^ ;INT2DT(OCXDT,OCXF) ; This Local Extrinsic Function converts an OCX internal format
  1. ;;R^"860.8:",100,2
  1. ;;D^ ; ; date into an Externl Format (Human Readable) date. 'OCXF=SHORT FORMAT OCXF=LONG FORMAT
  1. ;;R^"860.8:",100,3
  1. ;;D^ ; ;
  1. ;;R^"860.8:",100,4
  1. ;;D^ ; Q:'$L($G(OCXDT)) "" S OCXF=+$G(OCXF)
  1. ;;R^"860.8:",100,5
  1. ;;D^ ; N OCXYR,OCXLPYR,OCXMON,OCXDAY,OCXHR,OCXMIN,OCXSEC,OCXCYR
  1. ;;R^"860.8:",100,6
  1. ;;D^ ; S (OCXYR,OCXLPYR,OCXMON,OCXDAY,OCXHR,OCXMIN,OCXSEC,OCXAP)=""
  1. ;;R^"860.8:",100,7
  1. ;;D^ ; S OCXSEC=$E(OCXDT#60+100,2,3),OCXDT=OCXDT\60
  1. ;;R^"860.8:",100,8
  1. ;;D^ ; S OCXMIN=$E(OCXDT#60+100,2,3),OCXDT=OCXDT\60
  1. ;;R^"860.8:",100,9
  1. ;;D^ ; S OCXHR=$E(OCXDT#24+100,2,3),OCXDT=OCXDT\24
  1. ;;R^"860.8:",100,10
  1. ;;D^ ; S OCXCYR=($H\1461)*4+1841+(($H#1461)\365)
  1. ;;R^"860.8:",100,11
  1. ;;D^ ; S OCXYR=(OCXDT\1461)*4+1841,OCXDT=OCXDT#1461
  1. ;;R^"860.8:",100,12
  1. ;;D^ ; S OCXLPYR=(OCXDT\365),OCXDT=OCXDT-(OCXLPYR*365),OCXYR=OCXYR+OCXLPYR
  1. ;;R^"860.8:",100,13
  1. ;;D^ ; S OCXCNT="031^059^090^120^151^181^212^243^273^304^334^365"
  1. ;;R^"860.8:",100,14
  1. ;;D^ ; S:(OCXLPYR=3) OCXCNT="031^060^091^121^152^182^213^244^274^305^335^366"
  1. ;;R^"860.8:",100,15
  1. ;;D^ ; F OCXMON=1:1:12 Q:(OCXDT<$P(OCXCNT,U,OCXMON))
  1. ;;R^"860.8:",100,16
  1. ;;D^ ; S OCXDAY=OCXDT-$P(OCXCNT,U,OCXMON-1)+1
  1. ;;R^"860.8:",100,17
  1. ;;D^ ; I OCXF S OCXMON=$P("January^February^March^April^May^June^July^August^September^October^November^December",U,OCXMON)
  1. ;;R^"860.8:",100,18
  1. ;;D^ ; E S OCXMON=$E(OCXMON+100,2,3)
  1. ;;R^"860.8:",100,19
  1. ;;D^ ; S OCXAP=$S('OCXHR:"Midnight",(OCXHR=12):"Noon",(OCXHR<12):"AM",1:"PM")
  1. ;;R^"860.8:",100,20
  1. ;;D^ ; I OCXF S OCXHR=OCXHR#12 S:'OCXHR OCXHR=12
  1. ;1;
  1. ;