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

GMTSPXOP.m

Go to the documentation of this file.
  1. GMTSPXOP ; SLC/SBW,KER - PCE Outpatient Encounter comp ;07/19/13 11:48
  1. ;;2.7;Health Summary;**8,10,28,37,47,49,76,101**;Oct 20, 1995;Build 12
  1. ;
  1. ; External References
  1. ; DBIA 1238 VISIT^PXRHS01
  1. ; DBIA 1996 $$MOD^ICPTMOD
  1. ; DBIA 10103 $$DT^XLFDT
  1. ; DBIA 10011 ^DIWP
  1. ;
  1. PURPOSE ; Encounters with ICD9 and providers
  1. N DTYPE S DTYPE="DP" D MAIN Q
  1. OUTPT ; Encounters with ICD9, CPT, and providers
  1. N DTYPE S DTYPE="CDP" D MAIN Q
  1. MAIN ; Entry for Purpose of Visit and Outpatient Encounters
  1. N GMTSIVD,GMTSDAT,GMTSDTU,GMTSOVT,GMTSLOC,DIWL,GMTAB,GMTSN,GMCKP,GMTSX
  1. N GMTSITE,GMTSINS,GMTSEVT,GMTSHIS,GMTSICL,GMTSLOC,GMTSELIG,X,GMTSVDF
  1. N GMTSCPTM,GMICL
  1. ;
  1. ; GMTSCPTM Component uses CPT Modifiers 1 yes 0 no
  1. S GMTSCPTM=+($$CPT^GMTSU(+($G(GMTSEGN)))) S:$G(GMPXCMOD)="N" GMTSCPTM=0
  1. ; GMTSICL # of blank left columns for support data of a visit
  1. S GMTSICL=14
  1. ; DIWL Used in TXTFMT call & to print returned data
  1. S DIWL=0
  1. ; GMTAB Used to offset data from TXTFMT call after 1st line
  1. S GMTAB=2
  1. ; GMTSOVT This is the set of Service Categories for AICTSORE
  1. ;
  1. ; A Ambulatory
  1. ; I Inpatient
  1. ; C Chart Review
  1. ; T Telecommunications
  1. ; S Day Surgery
  1. ; O Observation
  1. ; R Nursing Home Encounters
  1. ; E Event (Historical)
  1. ;
  1. ; Note: Hospitalization and Ancillary
  1. ; encounters are not included
  1. S GMTSOVT="AICTSORE"
  1. ;
  1. D VISIT^PXRHS01(DFN,GMTSEND,GMTSBEG,GMTSNDM,GMTSOVT,DTYPE,1)
  1. Q:'$D(^TMP("PXHSV",$J))
  1. S GMTSIVD=0
  1. F S GMTSIVD=$O(^TMP("PXHSV",$J,GMTSIVD)) Q:GMTSIVD']"" D Q:$D(GMTSQIT)
  1. . S GMTSVDF=0
  1. . F S GMTSVDF=$O(^TMP("PXHSV",$J,GMTSIVD,GMTSVDF)) Q:GMTSVDF'>0 D Q:$D(GMTSQIT)
  1. . . S GMTSN=$G(^TMP("PXHSV",$J,GMTSIVD,GMTSVDF,0))
  1. . . S GMTSEVT=$P(GMTSN,U,4),GMTSHIS=$S(GMTSEVT["HISTORICAL":1,1:0)
  1. . . S X=$P(GMTSN,U,1) D REGDT4^GMTSU S GMTSDAT=X
  1. . . S GMTSDTU=0,(GMTSITE,GMTSLOC)=""
  1. . . S GMTSINS=$S($P(GMTSN,U,3)]"":$E($P(GMTSN,U,3),1,10),$P(GMTSN,U,8)]"":$E($P(GMTSN,U,8),1,10),1:""),GMTSITE=GMTSINS
  1. . . I $G(GMPXHLOC)'="N" S GMTSLOC=$E($P(GMTSN,U,6),1,30)
  1. . . I '$L(GMTSLOC) S GMTSLOC=$P(GMTSN,U,9)
  1. . . S GMTSELIG=$E($P(GMTSN,U,12),1,17)
  1. . . S:GMTSITE=""&('GMTSHIS) GMTSLOC=""
  1. . . I GMTSHIS D
  1. . . . S:GMTSLOC'=""&(GMTSITE'="") GMTSLOC=GMTSLOC_" (Historical Event)"
  1. . . . S:GMTSLOC=""&(GMTSITE'="") GMTSITE=GMTSITE_" (Historical Event)"
  1. . . . S:GMTSLOC'=""&(GMTSITE="") GMTSITE=GMTSLOC_" (Historical Event)",GMTSLOC=""
  1. . . . S:GMTSLOC=""&(GMTSITE="") GMTSITE="Historical Event"
  1. . . D CKP^GMTSUP Q:$D(GMTSQIT) D DSPVIS,DSPPROV Q:$D(GMTSQIT)
  1. . . D DSPPOV Q:$D(GMTSQIT) D DSPCPT W !
  1. K ^TMP("PXHSV",$J)
  1. Q
  1. ;
  1. DSPPOV ; Display Purpose of visit
  1. Q:$O(^TMP("PXHSV",$J,GMTSIVD,GMTSVDF,"D",""))=""
  1. Q:$G(GMPXICDF)="N"&($G(GMPXNARR)="N")
  1. N GMTSN,GMTSMOD,GMTSICD,GMTSNARR,GMTSPDN,GMTS,GMTSQTY,GMTSPRI,COMMENT,GMTSICDT
  1. D CKP^GMTSUP Q:$D(GMTSQIT) D DSPVIS W ?3,"Diagnosis:"
  1. S GMCKP=0,GMTSPDN="",GMTSQTY=""
  1. F S GMTSPDN=$O(^TMP("PXHSV",$J,GMTSIVD,GMTSVDF,"D",GMTSPDN)) Q:GMTSPDN'>0 D Q:$D(GMTSQIT)
  1. . S GMTSICDT=$P(^TMP("PXHSV",$J,GMTSIVD,GMTSVDF,0),U)
  1. . S GMTSN=$G(^TMP("PXHSV",$J,GMTSIVD,GMTSVDF,"D",GMTSPDN))
  1. . S GMTSMOD=$P(GMTSN,U,2)
  1. . S GMTSICD=$P(GMTSN,U) D GETICDDX^GMTSPXU1(.GMTSICD,$G(GMPXICDF),GMTSMOD,GMTSICDT,"DIAG")
  1. . S GMTSNARR=""
  1. . S:$G(GMPXNARR)'="N" GMTSNARR=$G(^TMP("PXHSV",$J,GMTSIVD,GMTSVDF,"D",GMTSPDN,"N"))
  1. . I $P(GMTSICD,"-",2,10)=$G(GMTSNARR) S GMTSNARR=""
  1. . S GMTSPRI="" I $P(GMTSN,U,5)]"",$E($P(GMTSN,U,5),1)="P" S GMTSPRI=" (P)"
  1. . S GMTSICD=$P(GMTSICD,"-",2,10)_" ("_$$GETICDCD^GMTSPXU1(GMTSICDT,"DIAG")_"-CM "_$P(GMTSICD,"-",1)_")"
  1. . D TXTFMT^GMTSPXU1(GMTSICD,$G(GMTSNARR),GMTSICL,GMTAB,DIWL,GMTSQTY,GMTSPRI)
  1. . I '$D(^UTILITY($J,"W")) Q
  1. . S GMTSX=0
  1. . F S GMTSX=$O(^UTILITY($J,"W",DIWL,GMTSX)) Q:GMTSX'>0!$D(GMTSQIT) D
  1. . . I GMCKP>0 D CKP^GMTSUP Q:$D(GMTSQIT) D DSPVIS
  1. . . S GMCKP=1
  1. . . W ?GMTSICL+$S(GMTSX>1:GMTAB,1:0),$G(^UTILITY($J,"W",DIWL,GMTSX,0)),!
  1. . S COMMENT="",COMMENT=$P($G(^TMP("PXHSV",$J,GMTSIVD,GMTSVDF,"D",GMTSPDN,"COM")),U)
  1. . I COMMENT]"" S GMICL=20,GMTAB=2 D FORMAT I $D(^UTILITY($J,"W")) D
  1. . . F GMTSLN=1:1:^UTILITY($J,"W",DIWL) D LINE Q:$D(GMTSQIT)
  1. Q
  1. DSPCPT ; Display Procedures performed during the visit
  1. Q:$O(^TMP("PXHSV",$J,GMTSIVD,GMTSVDF,"C",""))=""
  1. N GMTSNARR,GMTSPDN,GMTSN,GMTSICD,GMTSNARR,GMTSCPT,GMTSQTY,GMTSPRIM,GMTSPRI,GMTSFLG,GMTSICDT
  1. D CKP^GMTSUP Q:$D(GMTSQIT) D DSPVIS W ?3,"Procedure:"
  1. S GMCKP=0,GMTSPDN="",GMTSPRI=""
  1. F S GMTSPDN=$O(^TMP("PXHSV",$J,GMTSIVD,GMTSVDF,"C",GMTSPDN)) Q:GMTSPDN'>0 D Q:$D(GMTSQIT)
  1. . S GMTSICDT=$P(^TMP("PXHSV",$J,GMTSIVD,GMTSVDF,0),U)
  1. . S GMTSN=$G(^TMP("PXHSV",$J,GMTSIVD,GMTSVDF,"C",GMTSPDN))
  1. . S GMTSNARR=$P(GMTSN,U,2),GMTSQTY=$P(GMTSN,U,3),GMTSPRIM=$P(GMTSN,U,4)
  1. . S GMTSCPT=$$GETCPT^GMTSPXU1($P(GMTSN,U)) I $P(GMTSCPT,"-",2,10)=GMTSNARR S GMTSNARR=""
  1. . S GMTSPRI="" S:$G(GMTSQTY)]"" GMTSQTY=" ("_GMTSQTY_")" S:$G(GMTSPRIM)="Y" GMTSPRI="(P)"
  1. . S GMTSFLG=1
  1. . D TXTFMT^GMTSPXU1(GMTSCPT,GMTSNARR,GMTSICL,GMTAB,DIWL,GMTSQTY,GMTSPRI)
  1. . Q:'$D(^UTILITY($J,"W")) D DCPT
  1. Q
  1. DCPT ; Display CPT Comments
  1. N GMTSLN,GMTSMOK,GMTSX S (GMTSMOK,GMTSX)=0
  1. F S GMTSX=$O(^UTILITY($J,"W",DIWL,GMTSX)) Q:GMTSX'>0 D Q:$D(GMTSQIT)
  1. . I GMCKP>0 D CKP^GMTSUP Q:$D(GMTSQIT) D DSPVIS Q:$D(GMTSQIT)
  1. . S (GMTSMOK,GMCKP)=1 W ?GMTSICL+$S(GMTSX>1:GMTAB,1:0)
  1. . W $G(^UTILITY($J,"W",DIWL,GMTSX,0))
  1. . D CKP^GMTSUP Q:$D(GMTSQIT) W !
  1. Q:DTYPE="DP"
  1. S COMMENT=$P($G(^TMP("PXHSV",$J,GMTSIVD,GMTSVDF,"C",GMTSPDN,"COM")),U)
  1. I COMMENT]"" S GMICL=20,GMTAB=2 D FORMAT I $D(^UTILITY($J,"W")) D
  1. . F GMTSLN=1:1:^UTILITY($J,"W",DIWL) D Q:$D(GMTSQIT)
  1. . . I GMTSFLG=1 W !,?10,"Comments:" S GMTSFLG=0
  1. . . D LINE
  1. S:+($G(GMTSCPTM))=0 GMTSMOK=0 D:GMTSMOK DMOD
  1. Q
  1. DMOD ; Display CPT Modifier Comments
  1. N GMTSM S GMTSM=""
  1. W !
  1. F S GMTSM=$O(^TMP("PXHSV",$J,GMTSIVD,GMTSVDF,"C",GMTSPDN,GMTSM)) Q:GMTSM="" D Q:$D(GMTSQIT)
  1. . I GMTSM="COM" Q
  1. . N COMMENT S COMMENT=$$FCM(GMTSM) Q:'$L(COMMENT)
  1. . S GMICL=26,GMTAB=2 D FORMAT I $D(^UTILITY($J,"W")) D
  1. . . F GMTSLN=1:1:^UTILITY($J,"W",DIWL) D LINE2 Q:$D(GMTSQIT)
  1. Q
  1. DSPPROV ; Display Providers for visit
  1. Q:$O(^TMP("PXHSV",$J,GMTSIVD,GMTSVDF,"P",""))=""
  1. N GMCNT,GMPROV
  1. D ORDERPRO^GMTSPXU1(.GMPROV,20)
  1. D CKP^GMTSUP Q:$D(GMTSQIT) D DSPVIS W ?3," Provider:"
  1. S GMCNT=0
  1. F S GMCNT=$O(GMPROV(GMCNT)) Q:GMCNT'>0 D Q:GMCNT'>0!$D(GMTSQIT)
  1. . I GMCNT>1 D CKP^GMTSUP Q:$D(GMTSQIT) D DSPVIS
  1. . W ?GMTSICL,GMPROV(GMCNT) S GMCNT=$O(GMPROV(GMCNT)) Q:GMCNT'>0
  1. . W ?37,GMPROV(GMCNT) S GMCNT=$O(GMPROV(GMCNT)) Q:GMCNT'>0
  1. . W ?60,GMPROV(GMCNT)
  1. . D CKP^GMTSUP Q:$D(GMTSQIT) W:$O(GMPROV(GMCNT)) !
  1. D CKP^GMTSUP Q:$D(GMTSQIT) W !
  1. Q
  1. DSPVIS ; Display outpatient visit data
  1. Q:GMTSNPG'>0&(GMTSDTU>0) D:GMTSNPG HDR I GMTSNPG!(+GMTSDTU'>0) D
  1. . W GMTSDAT,?14,GMTSITE,?29,GMTSLOC,?61,GMTSELIG
  1. . D CKP^GMTSUP Q:$D(GMTSQIT) W !
  1. . S GMTSDTU=1
  1. Q
  1. HDR ; Display header
  1. W ?3,"Date",?14,"Facility",?29,"Hospital Location",?61,"Encounter Elig.",!!
  1. Q
  1. FORMAT ; Formats Diagnosis/Procedure line of text
  1. N DIWR,DIWF,X S DIWL=3,DIWR=80-(GMICL+GMTAB) K ^UTILITY($J,"W") S X=COMMENT D ^DIWP
  1. Q
  1. FCM(X) ; Format CPT Modifier comment
  1. N Y,%,%H,GMTSIEN,GMTSC,GMTSS,GMTST S GMTSIEN=$G(X) Q:GMTSIEN="" ""
  1. S:'$D(DT)!(+($G(DT))=0) DT=$$DT^XLFDT
  1. S X=$$MOD^ICPTMOD(GMTSIEN,"E",) Q:'$D(X)
  1. S GMTSC=$P(X,"^",2),GMTSS=$P(X,"^",3)
  1. S GMTST=$$EN2^GMTSUMX(GMTSS) S Y=""
  1. S:$L(GMTST)&($L(GMTSC)) Y=GMTSC_"-"_GMTST
  1. S:'$L(GMTST)&($L(GMTSS))&($L(GMTSC)) Y=GMTSC_"-"_GMTSS
  1. S:'$L(GMTST)&('$L(GMTSS))&($L(GMTSC)) Y=GMTSC
  1. S:Y["-" Y="Modifier "_Y S X=Y
  1. Q X
  1. LINE ; Writes formatted lines
  1. D CKP^GMTSUP Q:$D(GMTSQIT) W ?20,^UTILITY($J,"W",DIWL,GMTSLN,0),! Q
  1. LINE2 ; Writes indented formatted lines
  1. D CKP^GMTSUP Q:$D(GMTSQIT) N GMTST S GMTST=20 S:+($G(GMTSLN))>1 GMTST=31 W ?GMTST,^UTILITY($J,"W",DIWL,GMTSLN,0),! Q