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

TIULD.m

Go to the documentation of this file.
  1. TIULD ; SLC/JER - Admission related functions ; 1/13/03
  1. ;;1.0;TEXT INTEGRATION UTILITIES;**7,21,148,156**;Jun 20, 1997
  1. ;IHS/ITSC/LJF 02/26/2003 set IHS visit variable
  1. ; called IHS routines for displays
  1. ;
  1. GETTIU(TIUY,TIUDA) ; Gets admission array for existing DCS
  1. N TIUMVN,TIUPTF,TIUVSTR,TIUDTYP,TIUD0,TIUD12,TIUD14
  1. S TIUD0=$G(^TIU(8925,+TIUDA,0)),TIUD12=$G(^(12)),TIUD14=$G(^(14))
  1. S TIUDTYP=+TIUD0,DFN=+$P(TIUD0,U,2),TIUMVN=$P(TIUD14,U)
  1. S TIUVSTR=$P(TIUD12,U,11)_";"_$P(TIUD0,U,7)_";"_$P(TIUD0,U,13)
  1. S TIUY("DOCTYP")=TIUDTYP_U_$$PNAME^TIULC1(TIUDTYP)
  1. I +$G(^TIU(8925,+TIUDA,13)) S TIUY("REFDT")=+$G(^(13))
  1. ;
  1. ;IHS/ITSC/LJF 02/26/2003 set IHS visit variable from visit attached to patient movement entry
  1. NEW BTIUVSIT
  1. I TIUMVN S BTIUVSIT=$$GET1^DIQ(405,TIUMVN,.27,"I")
  1. I 'TIUMVN,$P(TIUD0,U,3) S BTIUVSIT=$P(TIUD0,U,3)
  1. I $G(BTIUVSIT) S $P(TIUVSTR,";",3)=$$GET1^DIQ(9000010,+BTIUVSIT,.07,"I")
  1. ;IHS/ITSC/LJF 02/26/2003 end of new code
  1. ;
  1. ; If the Patient Movement Pointer's broken, try to fix
  1. I +TIUMVN,'$D(^DGPM(+TIUMVN,0)),+$G(TIUVSTR) D FIXMOVE(.TIUY,DFN,TIUVSTR,TIUDA) Q:+$G(TIUY("AD#"))
  1. D PATVADPT^TIULV(.TIUY,DFN,TIUMVN,TIUVSTR)
  1. Q
  1. FIXMOVE(TIUY,DFN,TIUVSTR,TIUDA) ; See if Admission has been reinstated, and fix
  1. N TIUEDT,TIULDT,TIULOC
  1. S TIUEDT=$P(TIUVSTR,";",2) Q:+TIUEDT'>0
  1. S TIULDT=$$FMADD^XLFDT(TIUEDT,1),TIULOC=+TIUVSTR
  1. Q:+TIULDT'>0!(+TIULOC'>0)
  1. D MAIN^TIUMOVE(.TIUY,DFN,"",TIUEDT,TIULDT,1,"LAST",0,+TIULOC)
  1. I +$G(TIU("AD#"))>0,$D(^DGPM(+$G(TIU("AD#")))) D
  1. . N DIE,DR,DA S DA=TIUDA,DR="1401////"_+$G(TIU("AD#")),DIE="^TIU(8925,"
  1. . D ^DIE
  1. Q
  1. CHEKDS(X) ; Display/validate correct patient/treatment episode
  1. Q $$CHEKDS^BTIULD(.X) ;IHS/ITSC/LJF 02/26/2003 use IHS code for display
  1. N DIR,Y,TIURC S Y=0
  1. I X("AD#")'>0!(X("EDT")="") D G CHEKDSX
  1. . W !!,"Movement data doesn't exist for admission, can't create "
  1. . W "Summary",!
  1. I +$$ISA^USRLM(DUZ,"TRANSCRIPTIONIST")>0 S Y=1 G CHEKDSX
  1. W !!?1,"Patient: ",$$NAME^TIULS(X("PNM"),"LAST, FIRST MI"),?40,"SSN: "
  1. W X("SSN"),?62,"Sex: ",$S(X("SEX")]"":$P(X("SEX"),U,2),1:"UNKNOWN"),!
  1. W ?5,"Age: ",$S(X("AGE")]"":X("AGE"),1:"UNKNOWN"),?40,"Claim #: "
  1. W $S(X("CLAIM")]"":X("CLAIM"),1:"UNKNOWN"),!
  1. W "Adm Date: ",$$DATE^TIULS($P(X("EDT"),U),"MM/DD/YY"),?40,"Ward: "
  1. W $P(X("WARD"),U,2),!
  1. W:X("LDT")]"" "Dis Date: ",$$DATE^TIULS(X("LDT"),"MM/DD/YY"),!
  1. W ?2,"Adm Dx: ",X("ADDX")
  1. ; Below TIU*148
  1. I $G(X("NUMRACE"))>0 D
  1. . W !?4,"Race: " F TIURC=1:1:X("NUMRACE") W ?10,$P(X("RACE",TIURC),U,2),!
  1. I $G(X("RACENO"))=0 W !?4,"Race: ",$P($G(X("RACE")),U,2),!
  1. I $D(X("DICTDT")) D
  1. . W !,"A DISCHARGE SUMMARY is already on file:",!
  1. . W ?2,"Dict'd: ",X("DICTDT"),?41,"By: ",X("AUTHOR"),!
  1. . W ?2,"Signed: ",X("SIGDT"),?35,"Cosigned: ",X("COSDT"),!
  1. . S Y=1
  1. E S Y=$$READ^TIUU("YO","Correct VISIT","YES")
  1. W !
  1. CHEKDSX Q Y
  1. CHEKPN(X,TIUBY) ; Display/validate demographic/visit information
  1. Q $$CHEKPN^BTIULD(.X,.TIUBY) ;IHS/ITSC/LJF 02/26/2003 use IHS code for display
  1. W !!,"Enter/Edit "
  1. W $S(+$G(TIUCLASS):$S(TIUCLASS=3:"PROGRESS NOTE",TIUCLASS=+$$CLASS^TIUCNSLT:"CONSULT RESULT",1:$$PNAME^TIULC1(+TIUCLASS)),1:"PROGRESS NOTE"),"..."
  1. W !?10,"Patient Location: ",$S(+X("LOC"):$P(X("LOC"),U,2),1:"UNKNOWN")
  1. W !?$S(+$G(X("AD#")):4,1:8),"Date/time of "
  1. W $S(+$G(X("AD#")):"Admission: ",1:"Visit: ")
  1. W $S(+$P($G(X("VSTR")),";",2):$$DATE^TIULS($P(X("VSTR"),";",2),"MM/DD/YY HR:MIN"),1:"UNKNOWN")
  1. W !?9,"Date/time of Note: "
  1. W $S(+$G(X("REFDT"))>0:$$DATE^TIULS(X("REFDT"),"MM/DD/YY HR:MIN"),1:"NOW")
  1. S:+$G(X("REFDT"))'>0 X("REFDT")=$$NOW^TIULC
  1. W !?12,"Author of Note: "
  1. W $$PERSNAME^TIULC1($S($D(TIUAUTH):+TIUAUTH,1:DUZ))
  1. S Y=$$READ^TIUU("YO"," ...OK","YES")
  1. I $S($D(DIROUT):1,$D(DUOUT):1,$D(DTOUT):1,1:0) Q 0
  1. S TIUBY=+Y
  1. S:'+Y Y=$$READ^TIUU("YO","Correct VISIT","YES")
  1. I $S($D(DIROUT):1,$D(DUOUT):1,$D(DTOUT):1,1:0) Q 0
  1. I +Y'>0 D
  1. . K X N TIUINOUT
  1. . S TIUINOUT=$$INOUT^TIUVSIT
  1. . I $S($D(DIROUT):1,$D(DUOUT):1,$D(DTOUT):1,1:0) Q
  1. . I $P(TIUINOUT,U)="o" D MAIN^TIUVSIT(.X,DFN,"","","","",1)
  1. . I $P(TIUINOUT,U)'="o" D MAIN^TIUMOVE(.X,DFN,"","","",1,"LAST",1)
  1. . S Y=$S($D(X)>9:$$CHEKPN(.X,.TIUBY),1:0)
  1. Q Y