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

FHDSSAPI.m

Go to the documentation of this file.
  1. FHDSSAPI ;Hines OIFO/RTK,JRC-DSS REQUESTED API's ; 11/3/08 2:42pm
  1. ;;5.5;DIETETICS;**7,11,10,16,18**;Jan 28, 2005;Build 27
  1. ;11/22/2006 KAM/BAY Remedy Call 168346 Add Variable Cleanup from *7
  1. ;03/31/2008 GDU/SLC Remedy 226373, inpatient record selection for extract re-worked
  1. DATA(FHSDT,FHEDT) ;API for DSS extract of NFS data
  1. ; INPUT: START DATE, END DATE
  1. ; OUTPUT: ^TMP($J,"FH"
  1. ; Get inpatient meals
  1. I FHSDT>FHEDT W !!,"END DATE BEFORE START DATE!",! H 1 Q
  1. K ^TMP($J,"FH") S FHEDT=FHEDT_.99
  1. F FHDFN=0:0 S FHDFN=$O(^FHPT(FHDFN)) Q:FHDFN'>0 D
  1. . I '$D(^FHPT(FHDFN,0)) Q
  1. . D PATNAME^FHOMUTL
  1. . ;Check if patient is deceased. Quit if date of death is before start date
  1. . S FHDCEASE=$$GET1^DIQ(2,DFN,".351","I")
  1. . I FHDCEASE&(FHDCEASE<FHSDT) D CLEAN Q
  1. . D INPAT,CLEAN
  1. D OUTPAT
  1. K FHADM,FHDATE,FHDFN,FHDSEQ,FHEL,FHNODE,FHNODE2,FHNODE3,FHOMDT,FHRNUM
  1. K FHSDTX1,FHSF,FHSFDT,FHSO,FHSODT,FHTF,FHTFDT,FHTFPR,FHTUZN,FHZ,FHZN
  1. K FHCDATE,FHNUM,FHEFF,FHADTM,FHDDTM,FHLAST,X,X1,X2,FHDCEASE,FHSTOP
  1. Q
  1. CLEAN ;Clean up variables set by PATNAME^FHOMUTL
  1. K BID,DFN,FHAGE,FHDOB,FHPCZN,FHPTNM,FHSEX,FHSSN,FILE,PID,IEN
  1. Q
  1. INPAT ;Process inpatient data
  1. F FHADM=0:0 S FHADM=$O(^FHPT(FHDFN,"A",FHADM)) Q:FHADM'>0 D
  1. .S FHZN=$G(^FHPT(FHDFN,"A",FHADM,0)),FHLAST="",FHSTOP=0
  1. .S FHADTM=$P(FHZN,U,1) I $P(FHADTM,".")>FHEDT Q
  1. .;If no discharge date, pull discharge date from registration pacakge for this admission
  1. .;If no matching record in registration package for this admission continue to next admission record
  1. .I '$P(FHZN,U,14) D I FHSTOP Q
  1. .. S VAINDT=FHADTM
  1. .. D INP^VADPT
  1. .. I VAIN(1)="" D KVAR^VADPT S FHSTOP=1 Q
  1. .. S VAIP("E")=VAIN(1),VAIP("M")=1
  1. .. D IN5^VADPT
  1. .. I +VAIP(2)=3 S $P(FHZN,U,14)=+VAIP(3)
  1. .. D KVAR^VADPT
  1. .;If no discharge date, set to date of death if patient is deceased
  1. .I '$P(FHZN,U,14),FHDCEASE S $P(FHZN,U,14)=FHDCEASE
  1. .S FHDDTM=$P(FHZN,U,14) I FHDDTM'="",FHDDTM<FHSDT Q
  1. .F FHDATE=0:0 S FHDATE=$O(^FHPT(FHDFN,"A",FHADM,"AC",FHDATE)) Q:FHDATE'>0!(FHDATE>FHEDT) D
  1. ..S FHDSEQ=$P($G(^FHPT(FHDFN,"A",FHADM,"AC",FHDATE,0)),U,2)
  1. ..S FHNODE=$G(^FHPT(FHDFN,"A",FHADM,"DI",FHDSEQ,0))
  1. ..I $P(FHNODE,U,18)="",$P(FHZN,U,14)'="" S $P(FHNODE,U,18)=$P(FHZN,U,14)
  1. ..I FHDATE<FHSDT I FHLAST'="" K ^TMP($J,"FH",FHADM,FHDFN,FHLAST,"INP")
  1. ..S FHLAST=FHDATE
  1. ..S ^TMP($J,"FH",FHADM,FHDFN,FHDATE,"INP")=FHNODE I '$D(^TMP($J,"FH","ZN",FHDFN)) S ^TMP($J,"FH","ZN",FHDFN)=^FHPT(FHDFN,0)
  1. .; Get additional feedings for inpatient
  1. .; Get Early/Late trays
  1. .F FHDATE=0:0 S FHDATE=$O(^FHPT(FHDFN,"A",FHADM,"EL",FHDATE)) Q:FHDATE'>0!(FHDATE>FHEDT) D
  1. ..S FHNODE=$G(^FHPT(FHDFN,"A",FHADM,"EL",FHDATE,0))
  1. ..I FHDATE<FHSDT Q I FHLAST'="" K ^TMP($J,"FH",FHADM,FHDFN,FHLAST,"EL")
  1. ..S ^TMP($J,"FH",FHADM,FHDFN,FHDATE,"EL")=FHNODE
  1. .;Get Supplemental Feedings
  1. .S FHLAST="" F FHSF=0:0 S FHSF=$O(^FHPT(FHDFN,"A",FHADM,"SF",FHSF)) Q:FHSF'>0 D
  1. ..S FHNODE=$G(^FHPT(FHDFN,"A",FHADM,"SF",FHSF,0))
  1. ..I $P(FHNODE,U,32)="",$P(FHZN,U,14)'="" S $P(FHNODE,U,32)=$P(FHZN,U,14)
  1. ..S FHDATE=$P(FHNODE,U,2) I FHDATE>FHEDT Q
  1. ..S FHCDATE=$P(FHNODE,U,32) I FHCDATE'="" I FHCDATE<FHSDT Q
  1. ..I FHDATE<FHSDT I FHLAST'="" K ^TMP($J,"FH",FHADM,FHDFN,FHLAST,"SF")
  1. ..S FHLAST=FHDATE
  1. ..S ^TMP($J,"FH",FHADM,FHDFN,FHDATE,"SF")=FHNODE
  1. .;Get Standing Orders
  1. .S FHNUM=0 F FHSO=0:0 S FHSO=$O(^FHPT(FHDFN,"A",FHADM,"SP",FHSO)) Q:FHSO'>0 D
  1. ..S FHNODE=$G(^FHPT(FHDFN,"A",FHADM,"SP",FHSO,0))
  1. ..I $P(FHNODE,U,6)="",$P(FHZN,U,14)'="" S $P(FHNODE,U,6)=$P(FHZN,U,14)
  1. ..S FHDATE=$P(FHNODE,U,4) I FHDATE>FHEDT Q
  1. ..S FHCDATE=$P(FHNODE,U,6) I FHCDATE'="" I FHCDATE<FHSDT Q
  1. ..S FHNUM=FHNUM+1,^TMP($J,"FH",FHADM,FHDFN,FHDATE,"SO",FHNUM)=FHNODE
  1. .;Get Tube Feedings
  1. .S FHLAST="" F FHTF=0:0 S FHTF=$O(^FHPT(FHDFN,"A",FHADM,"TF",FHTF)) Q:FHTF'>0 D
  1. ..S FHNODE=$G(^FHPT(FHDFN,"A",FHADM,"TF",FHTF,0))
  1. ..I $P(FHNODE,U,11)="",$P(FHZN,U,14)'="" S $P(FHNODE,U,11)=$P(FHZN,U,14)
  1. ..S FHDATE=$P(FHNODE,U,1) I FHDATE>FHEDT Q
  1. ..S FHCDATE=$P(FHNODE,U,11) I FHCDATE'="" I FHCDATE<FHSDT Q
  1. ..I FHDATE<FHSDT I FHLAST'="" K ^TMP($J,"FH",FHADM,FHDFN,FHLAST,"TF")
  1. ..S FHLAST=FHDATE
  1. ..S ^TMP($J,"FH",FHADM,FHDFN,FHDATE,"TF")=FHNODE
  1. ..F FHTFPR=0:0 S FHTFPR=$O(^FHPT(FHDFN,"A",FHADM,"TF",FHTF,"P",FHTFPR)) Q:FHTFPR'>0 D
  1. ...S FHNODE=$G(^FHPT(FHDFN,"A",FHADM,"TF",FHTF,"P",FHTFPR,0))
  1. ...S ^TMP($J,"FH",FHADM,FHDFN,FHDATE,"TF",FHTFPR,"P")=FHNODE
  1. ...Q
  1. ..Q
  1. .Q
  1. Q
  1. ;
  1. OUTPAT ;Process outpatient data
  1. ; Get outpatient meals
  1. S X1=FHSDT,X2=-1 D C^%DTC S FHSDTX1=X_.99
  1. ; Get recurring meals
  1. F FHOMDT=FHSDTX1:0 S FHOMDT=$O(^FHPT("RM",FHOMDT)) Q:FHOMDT=""!(FHOMDT'<FHEDT) D
  1. .F FHDFN=0:0 S FHDFN=$O(^FHPT("RM",FHOMDT,FHDFN)) Q:FHDFN="" D
  1. ..I '$D(^FHPT(FHDFN,0)) Q
  1. ..F FHRNUM=0:0 S FHRNUM=$O(^FHPT("RM",FHOMDT,FHDFN,FHRNUM)) Q:FHRNUM="" D
  1. ...S FHNODE=$G(^FHPT(FHDFN,"OP",FHRNUM,0)) I $P(FHNODE,U,15)="C" Q
  1. ...I $P($G(^FHPT(FHDFN,0)),U,3)="" Q
  1. ...S ^TMP($J,"FH",FHOMDT,FHDFN,FHRNUM,"RM")=FHNODE I '$D(^TMP($J,"FH","ZN",FHDFN)) S ^TMP($J,"FH","ZN",FHDFN)=^FHPT(FHDFN,0)
  1. ...;
  1. ...; IF NON-VA LOC DIET(S) ARE IN FIELDS DIET1-DIET5
  1. ...;
  1. ...I $D(^FHPT(FHDFN,"OP",FHRNUM,2)) D
  1. ....S FHNODE2=$G(^FHPT(FHDFN,"OP",FHRNUM,2)) I $P(FHNODE2,U,6)="C" Q
  1. ....I $P($G(^FHPT(FHDFN,0)),U,3)="" Q
  1. ....S ^TMP($J,"FH",FHOMDT,FHDFN,FHRNUM,"RMEL")=FHNODE2 I '$D(^TMP($J,"FH","ZN",FHDFN)) S ^TMP($J,"FH","ZN",FHDFN)=^FHPT(FHDFN,0)
  1. ...I $D(^FHPT(FHDFN,"OP",FHRNUM,3)) D
  1. ....S FHNODE3=$G(^FHPT(FHDFN,"OP",FHRNUM,3)) I $P(FHNODE3,U,5)="C" Q
  1. ....I $P($G(^FHPT(FHDFN,0)),U,3)="" Q
  1. ....S ^TMP($J,"FH",FHOMDT,FHDFN,FHRNUM,"RMTF")=FHNODE3 I '$D(^TMP($J,"FH","ZN",FHDFN)) S ^TMP($J,"FH","ZN",FHDFN)=^FHPT(FHDFN,0)
  1. ....F FHZ=0:0 S FHZ=$O(^FHPT(FHDFN,"OP",FHRNUM,"TF",FHZ)) Q:FHZ'>0 D
  1. .....S FHTUZN=$G(^FHPT(FHDFN,"OP",FHRNUM,"TF",FHZ,0))
  1. .....S ^TMP($J,"FH",FHOMDT,FHDFN,FHRNUM,"RMTF",FHZ)=FHTUZN I '$D(^TMP($J,"FH","ZN",FHDFN)) S ^TMP($J,"FH","ZN",FHDFN)=^FHPT(FHDFN,0)
  1. ...;fh*5.5*18
  1. ...;adding supplemental feedings for outpatient
  1. ...I $D(^FHPT(FHDFN,"OP",FHRNUM,"SF")) D
  1. ....S FHLAST="" F FHSF=0:0 S FHSF=$O(^FHPT(FHDFN,"OP",FHRNUM,"SF",FHSF)) Q:FHSF'>0 D
  1. .....S FHNODE=$G(^FHPT(FHDFN,"OP",FHRNUM,"SF",FHSF,0))
  1. .....S FHDATE=$P(FHNODE,U,2) I FHDATE>FHEDT Q
  1. .....S FHCDATE=$P(FHNODE,U,32) I FHCDATE'="" I FHCDATE<FHSDT Q
  1. .....I FHDATE<FHSDT I FHLAST'="" K ^TMP($J,"FH",FHOMDT,FHDFN,FHRNUM,"SF")
  1. .....S FHLAST=FHDATE
  1. .....S ^TMP($J,"FH",FHOMDT,FHDFN,FHRNUM,"RMSF")=FHNODE
  1. ...;adding standing orders for outpatient
  1. ...S FHNUM=0 F FHSO=0:0 S FHSO=$O(^FHPT(FHDFN,"OP",FHRNUM,"SP",FHSO)) Q:FHSO'>0 D
  1. ....S FHNODE=$G(^FHPT(FHDFN,"OP",FHRNUM,"SP",FHSO,0))
  1. ....S FHDATE=$P(FHNODE,U,4) I FHDATE>FHEDT Q
  1. ....S FHCDATE=$P(FHNODE,U,6) I FHCDATE'="" I FHCDATE<FHSDT Q
  1. ....S FHNUM=FHNUM+1,^TMP($J,"FH",FHOMDT,FHDFN,FHRNUM,"RMSO",FHNUM)=FHNODE
  1. ; Get special meals
  1. F FHOMDT=FHSDTX1:0 S FHOMDT=$O(^FHPT("SM",FHOMDT)) Q:FHOMDT=""!(FHOMDT'<FHEDT) D
  1. .F FHDFN=0:0 S FHDFN=$O(^FHPT("SM",FHOMDT,FHDFN)) Q:FHDFN="" D
  1. ..I '$D(^FHPT(FHDFN,0)) Q
  1. ..S FHNODE=$G(^FHPT(FHDFN,"SM",FHOMDT,0)) I $P(FHNODE,U,2)'="A" Q
  1. ..I $P($G(^FHPT(FHDFN,0)),U,3)="" Q
  1. ..S ^TMP($J,"FH",FHOMDT,FHDFN,"SM")=FHNODE I '$D(^TMP($J,"FH","ZN",FHDFN)) S ^TMP($J,"FH","ZN",FHDFN)=^FHPT(FHDFN,0)
  1. ; Get guest meals
  1. F FHOMDT=FHSDTX1:0 S FHOMDT=$O(^FHPT("GM",FHOMDT)) Q:FHOMDT=""!(FHOMDT'<FHEDT) D
  1. .F FHDFN=0:0 S FHDFN=$O(^FHPT("GM",FHOMDT,FHDFN)) Q:FHDFN="" D
  1. ..I '$D(^FHPT(FHDFN,0)) Q
  1. ..S FHNODE=$G(^FHPT(FHDFN,"GM",FHOMDT,0)) I $P(FHNODE,U,9)="C" Q
  1. ..I $P($G(^FHPT(FHDFN,0)),U,3)="" Q
  1. ..S ^TMP($J,"FH",FHOMDT,FHDFN,"GM")=FHNODE I '$D(^TMP($J,"FH","ZN",FHDFN)) S ^TMP($J,"FH","ZN",FHDFN)=^FHPT(FHDFN,0)
  1. Q