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

GMTSMCZZ.m

Go to the documentation of this file.
  1. GMTSMCZZ ;SLC/SBW - Medicine 2.2 HS Component ;18/APRIL/95
  1. ;;2.7;Health Summary;;Oct 20, 1995
  1. GMTSMCPS ;WISC/DCB - Medicine 2.2 Health Summary Component ;5/10/94
  1. ;;2.7;Health Summary;;Oct 20, 1995
  1. BEG ;One Line summary only
  1. D START(0,"B") Q
  1. BRIEF ;Brief Summary
  1. D START(1,"B") Q
  1. ABN ;Print Brief summary for only abnomaral or Null
  1. D START(2,"B") Q
  1. FULL ;Full Sunnary
  1. D START(1,"F") Q
  1. CAP ;Capture
  1. D START(1,"C") Q
  1. ADBF ;Print Full Summary for only abnotmal or null
  1. D START(2,"F") Q
  1. START(BRIEF,MCTYPE) ;Get the record and display the record
  1. N TV,VV,SP
  1. K ^TMP("MCAR",$J)
  1. S RMAR=$S($D(IOM):IOM,1:IOM)
  1. S TV=(.25*RMAR+.5)\1
  1. S VV=(.70*RMAR+.5)\1
  1. S SP=(RMAR-(TV+VV))-1
  1. D KVAR^VADPT
  1. I '$D(^MCAR(690,"AC",DFN)) D EXIT Q
  1. D SEARCH
  1. I '$D(^TMP("MCAR",$J)) D EXIT Q
  1. F MCL=1:1 Q:$D(GMTSQIT) Q:'$D(^TMP("MCAR",$J,MCL)) D GETREC(MCL,RMAR,TV,VV,SP)
  1. D EXIT
  1. Q
  1. I $D(GMTSNDM),(GMTSNDM>0) S MAX=GMTSNDM
  1. E S MAX=50
  1. D HSUM^GMTSMCMA(DFN,GMTSEND,GMTSBEG,MAX,"",MCTYPE)
  1. Q
  1. GETREC(MCL,RMAR,TV,VV,SP) ;Return record
  1. N MCDATE,MCPROC,MCSUM,MCPSUM,LOOP,LINE,BLINE
  1. S (LOOP,BLINE)="",$P(BLINE,"-",80)="-"
  1. S MCDATE=$$RETURN("DATE/TIME",MCL)
  1. S MCPROC=$$RETURN("PROCEDURE",MCL)
  1. S MCSUM=$$RETURN("SUMMARY",MCL)
  1. S MCPSUM=$$RETURN("PROCEDURE SUMMARY",MCL)
  1. D CKP^GMTSUP Q:$D(GMTSQIT) W !,MCDATE,?(TV+SP),MCPROC
  1. D CKP^GMTSUP Q:$D(GMTSQIT) W !,BLINE
  1. D:MCSUM'="" PRINT(MCSUM,VV,"Summary:",TV,SP)
  1. D:MCPSUM'="" PRINT(MCPSUM,VV,"Procedure Summary:",TV,SP)
  1. D CKP^GMTSUP Q:$D(GMTSQIT) W !
  1. Q:+$G(BRIEF)=0
  1. I BRIEF=2,("N"[$E(MCSUM,1)),(MCSUM'="") Q
  1. F S LOOP=+$O(^TMP("MCAR",$J,MCL,LOOP)) Q:LOOP=0!$D(GMTSQIT) D REPORT(LOOP,MCL,RMAR,BLINE,TV,VV,SP)
  1. Q
  1. I MLEN>RMAR D CKP^GMTSUP Q:$D(GMTSQIT) W !
  1. REPORT(LOOP,MCL,RMAR,BLINE,TV,VV,SP) ;Report on procedure
  1. N LINE,TEMP,HOLD,TITLE,VALUE,UNITS,MLEN,RANGE
  1. N TARRAY,VARRY,LARRAY,TMAX,VMAX,MAX,LOOP2
  1. S LINE=^TMP("MCAR",$J,MCL,LOOP,1)
  1. S TEMP=$P(LINE,U,1),TITLE=$P(TEMP,";",1)_":"
  1. S VALUE=$P(LINE,U,3,255),UNITS=$P(LINE,U,2)
  1. Q:(VALUE="")&(MCTYPE'="C")
  1. I $P(TEMP,";",2)="W" D WORD(MCL,LOOP,TITLE,RMAR,TV,VV,SP) Q
  1. S VALUE=VALUE_$S(UNITS="":"",1:" "_UNITS)
  1. D PRINT(VALUE,VV,TITLE,TV,SP)
  1. D CKP^GMTSUP Q:$D(GMTSQIT) W !
  1. Q
  1. WARP(VALUE,LENGTH,TEMP,MAX) ;WARP A FIELD
  1. N DIWL,DIWR,DIWF,X,LOOP3,TEMP1 S LOOP3=""
  1. K ^UTILITY($J,"W")
  1. S DIWL=0,DIWR=LENGTH,X=VALUE D ^DIWP
  1. F MAX=1:1 S LOOP3=+$O(^UTILITY($J,"W",DIWL,LOOP3)) Q:LOOP3=0 D
  1. .S TEMP1=^UTILITY($J,"W",DIWL,LOOP3,0)
  1. .S:$E(TEMP1,$L(TEMP1))=" " TEMP1=$E(TEMP1,1,$L(TEMP1)-1)
  1. .S TEMP(LOOP3)=TEMP1
  1. S MAX=MAX-1
  1. Q
  1. WORD(MCL,LOOP,TITLE,RMAR,TV,VV,SP) ;Display word processing
  1. N SLOOP,X,DIWR,DIWL,DIWF,TARRAY,TMAX,LOOP3,SPAC
  1. D WARP(TITLE,TV,.TARRAY,.TMAX) K ^UTILITY($J,"W") S DIWR=VV,DIWL=0
  1. F SLOOP=0:0 S SLOOP=+$O(^TMP("MCAR",$J,MCL,LOOP,SLOOP)) Q:SLOOP=0 D
  1. .S X=$P(^TMP("MCAR",$J,MCL,LOOP,SLOOP),U,3) D ^DIWP
  1. S SLOOP=0
  1. F LOOP3=1:1 S SLOOP=+$O(^UTILITY($J,"W",DIWL,SLOOP)) Q:(SLOOP=0)!($D(GMTSQIT)) D
  1. .D CKP^GMTSUP Q:$D(GMTSQIT)
  1. .W !,$J($G(TARRAY(LOOP3)),TV),?(TV+SP),^UTILITY($J,"W",DIWL,SLOOP,0)
  1. D CKP^GMTSUP Q:$D(GMTSQIT) W !
  1. Q
  1. CONVERT(TITLE) ;Convert a word to upper/lower case TEMP = Temp
  1. N UPPER,LOWER,TEMP,LOOP,HOLD,HOLD2
  1. S UPPER="ABCDEFGHIJKLMNOPQRSTUVWXYZ",LOWER="abcdefghijklmnopqrstuvwxyz"
  1. F LOOP=1:1:255 S HOLD=$P(TITLE," ",LOOP) Q:HOLD="" D
  1. .S:$D(TEMP) TEMP=TEMP_" "
  1. .S HOLD2=$E(HOLD,2,$L(HOLD))
  1. .S TEMP=$G(TEMP)_$E(HOLD,1)_$TR(HOLD2,UPPER,LOWER)
  1. Q TEMP
  1. PRINT(VALUE,VV,TITLE,TV,SP) ;Print a field and its value
  1. N VMAX,TMAX,TARRAY,VARRAY,SPAC,LOOP2
  1. S TITLE=$$CONVERT(TITLE)
  1. D WARP(VALUE,VV,.VARRAY,.VMAX)
  1. D WARP(TITLE,TV,.TARRAY,.TMAX)
  1. S MAX=$S(VMAX<TMAX:TMAX,VMAX>TMAX:VMAX,1:TMAX)
  1. S SPAC=TMAX-VMAX S:SPAC<0 SPAC=0
  1. F LOOP2=1:1:TMAX D CKP^GMTSUP Q:$D(GMTSQIT) D
  1. .W !,$J($G(TARRAY(LOOP2)),TV),?(TV+SP),$G(VARRAY(LOOP2-SPAC))
  1. Q:$D(GMTSQIT)
  1. Q
  1. RETURN(TYPE,LINE) ;Return key elements
  1. N MCHOLD,HOLD
  1. S MCHOLD=+$O(^TMP("MCAR",$J,LINE,"B",TYPE,""))
  1. S HOLD=$P($G(^TMP("MCAR",$J,LINE,MCHOLD,1)),U,3)
  1. K ^TMP("MCAR",$J,LINE,"B",TYPE,LINE)
  1. K ^TMP("MCAR",$J,LINE,MCHOLD,1)
  1. Q HOLD
  1. EXIT ;
  1. K PR,OT,DA,MCARPPS,MCI,MCJ,R,MCL,S1,S2,S4,S5,S6,LL,LL1,MAX,VA
  1. K ^TMP("MCAR",$J),K,N,MCARDT,MCARNM,MCARPROC,M,RMAR
  1. Q