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

GMVSC0.m

Go to the documentation of this file.
  1. GMVSC0 ;HOIFO/MD,YH,FT-CUMULATIVE VITALS/MEASUREMENTS FOR PATIENT OVER GIVEN DATE RANGE ;6/6/07
  1. ;;5.0;GEN. MED. REC. - VITALS;**23**;Oct 31, 2002;Build 25
  1. ;
  1. ; This routine uses the following IAs:
  1. ; #10039 - FILE 42 references (supported)
  1. ; #10061 - ^VADPT calls (supported)
  1. ; #10103 - ^XLFDT calls (supported)
  1. ;
  1. EN1(RESULT,GMVDATA) ; GMV CUMULATIVE REPORT [RPC entry point]
  1. ; Cumulative Vitals Report
  1. ; DFN - patient internal entry number (FILE 2)
  1. ; GMRVSDT - start date/time of report range
  1. ; GMRVFDT - end date/time of report range
  1. ; GMVDEV - device name
  1. ; GMVIEN - device internal entry name (FILE 3.5)
  1. ; GMVPDT - date/time to print the report
  1. ; GMVWARD - ward internal entry number (FILE 42)
  1. ; GMVHLOC - hospital location internal entry number (FILE 44)
  1. ; GMVRMLST - list of room numbers separated by commas (e.g., 200,210)
  1. ;
  1. N DFN,GMRVSDT,GMRVFDT,GMVDEV,GMVIEN,GMVPDT,GMVWARD,GMVHLOC,GMVRMLST
  1. S DFN=$P(GMVDATA,U,1),GMRVSDT=$P(GMVDATA,U,2),GMRVFDT=$P(GMVDATA,U,3),GMVDEV=$P(GMVDATA,U,5),GMVIEN=+$P(GMVDATA,U,6),GMVPDT=$P(GMVDATA,U,7),GMVWARD=$P(GMVDATA,U,8),GMVHLOC=$P(GMVDATA,U,9),GMVRMLST=$P(GMVDATA,U,10)
  1. S ZTIO=GMVDEV ;device
  1. S ZTDTH=$S($G(GMVPDT)>0:GMVPDT,1:$$NOW^XLFDT()) ;date/time to print
  1. S (ZTSAVE("DFN"),ZTSAVE("GMRVSDT"),ZTSAVE("GMRVFDT"))=""
  1. S (ZTSAVE("GMVWARD"),ZTSAVE("GMVHLOC"),ZTSAVE("GMVRMLST"))=""
  1. S ZTDESC="Cumulative vital/measurement report"
  1. S ZTRTN="START^GMVSC0"
  1. D ^%ZTLOAD
  1. S RESULT=$S($G(ZTSK)>0:"Report sent to device. Task #: "_ZTSK,1:"Unable to task the report.")
  1. K ZTSK,ZTIO,ZTDTH,ZTSAVE,ZTDESC,ZTRTN
  1. Q
  1. START ; Start the report output
  1. S:$D(ZTQUEUED) ZTREQ="@"
  1. ; if selected roombeds, then set up GMVROOM array
  1. I $L(GMVRMLST)>0 D
  1. .F GMVLOOP=1:1 Q:$P(GMVRMLST,",",GMVLOOP)="" D
  1. ..S GMVROOM($P(GMVRMLST,",",GMVLOOP))=""
  1. ..Q
  1. .Q
  1. S GMVEDB=$S(DFN>0:"P",GMVRMLST]"":"S",1:"A") ;P is one patient, A is whole ward, S is selected rooms
  1. S GMVWARD(1)=$S(GMVWARD>0:$P($G(^DIC(42,GMVWARD,0)),U,1),1:"") ;ward name
  1. I $G(GMVEDB)="P" D
  1. .D DEM^VADPT,INP^VADPT
  1. .S GMRRMBD=$S(VAIN(5)'="":VAIN(5),1:" BLANK") ;roombed
  1. .S GMVNAME=$S(VADM(1)'="":VADM(1),1:" BLANK") ;patient name
  1. .S GMVWARD=$P(VAIN(4),"^") ;ward ien
  1. .S GMVWARD(1)=$P(VAIN(4),"^",2) ;ward name
  1. .D KVAR^VADPT K VA ;kill VADPT variables
  1. .S ^TMP($J,GMRRMBD,GMVNAME,DFN)=""
  1. E D WARD^GMVDS1 ;returns TMP global with list of patients
  1. S (GMROUT,GMRPG)=0
  1. S GMVRANGE=$$FMTE^XLFDT(GMRVSDT)_"-"_$$FMTE^XLFDT(GMRVFDT)
  1. D NOW^%DTC S Y=% D D^DIQ
  1. S GMRPDT=$P(Y,"@")_" ("_$P($P(Y,"@",2),":",1,2)_")"
  1. S $P(GMRDSH,"-",80)=""
  1. U IO
  1. S GMRRMBD=""
  1. N GPEDIS S GPEDIS=$O(^GMRD(120.52,"B","DORSALIS PEDIS",0)) Q:GPEDIS'>0
  1. F S GMRRMBD=$O(^TMP($J,GMRRMBD)) Q:GMRRMBD=""!GMROUT S GMRNAM="" F S GMRNAM=$O(^TMP($J,GMRRMBD,GMRNAM)) Q:GMRNAM=""!GMROUT S DFN=0 F S DFN=$O(^TMP($J,GMRRMBD,GMRNAM,DFN)) Q:DFN'>0!GMROUT S GMRPG=0 D WRT Q:GMROUT D EN1^GMVSC1
  1. Q ; kill variables and quit
  1. D Q^GMVSC1
  1. K ^TMP($J)
  1. K GMRBMI,GMRVHT,GMRINF,GMRPG,GMREDB,GMRNAM,GMRRMBD,GMRVWLOC,GMRWARD,GMRMSL,GMRROOM,GMRRMST,GMRVHLOC,GMRLEN,GMRI,GMROUT,GMRVSDT,GMRVFDT,GPRT,GMVLOOP
  1. K GMVRMLST,GMVRANGE
  1. D ^%ZISC
  1. Q
  1. W !!,"*** (E) - Error entry",!! W:VADM(1)'="" ?$X-3,$E(VADM(1),1,15) W:VADM(2)'="" ?17,$E($P(VADM(2),"^",2),8,11) W:VADM(3)'="" ?30,$P(VADM(3),"^",2) W:VADM(4)'="" ?43,$P(VADM(4),"^")_" YRS"
  1. W:VADM(5)'="" ?51,$P(VADM(5),"^",2)
  1. W ?65,"VAF 10-7987j" W !,"Unit: "_$S($P(VAIN(4),"^",2)'="":$P(VAIN(4),"^",2),1:" "),?32,"Room: "_$S($P(VAIN(5),"^")'="":$P(VAIN(5),"^"),1:" "),!
  1. I '$D(GMRVHLOC) S GMRVHLOC=$$HOSPLOC^GMVUTL1(+$G(VAIN(4)))
  1. W "Division: "_$$DIVISION^GMVUTL1(+GMRVHLOC),!
  1. Q
  1. WRT ;
  1. S GMR1ST=1
  1. K GMRSITE
  1. D DEM^VADPT,INP^VADPT
  1. S GWARD=$S($P(VAIN(4),"^",2)'="":$P(VAIN(4),"^",2),1:" ")
  1. S GBED=$S(VAIN(5)'="":$P(VAIN(5),"^"),1:" ")
  1. D HDR^GMVSC2
  1. Q