| 1 | GMTSPXHR ; SLC/SBW,KER - PCE Clinical Reminders/Maint ; 06/15/2005
 | 
|---|
| 2 |  ;;2.7;Health Summary;**8,22,23,28,34,56,63,75**;Oct 20, 1995;Build 21
 | 
|---|
| 3 |  ;
 | 
|---|
| 4 |  ; External References
 | 
|---|
| 5 |  ;   DBIA  2182  MAIN^PXRM
 | 
|---|
| 6 |  ;                       
 | 
|---|
| 7 | MAIN ; Entry Point for Clinical Reminders
 | 
|---|
| 8 |  N CM,GMFLAG,HVET,HVDISP
 | 
|---|
| 9 |  S (HVET,CM)=0
 | 
|---|
| 10 |  I GMTSEGH["CR" S GMFLAG=0
 | 
|---|
| 11 |  I GMTSEGH["CRS" S GMFLAG=1
 | 
|---|
| 12 |  I GMTSEGH["CM" S GMFLAG=5,CM=1
 | 
|---|
| 13 |  I GMTSEGH["CMB" S GMFLAG=4,CM=1
 | 
|---|
| 14 |  I GMTSEGH["MHVD" S HVET=1,CM=1,HVDISP=11
 | 
|---|
| 15 |  I GMTSEGH["MHVS" S HVET=1,CM=1,HVDISP=10
 | 
|---|
| 16 |  Q:+$G(GMTSAGE)'>0!($G(SEX)="")!($G(DFN)'>0)
 | 
|---|
| 17 |  I HVET=1 D HVET Q
 | 
|---|
| 18 |  Q:$O(GMTSEG(GMTSEGN,811.9,0))'>0
 | 
|---|
| 19 |  N GMCR,GMFIRST,CRSEG,GMDISP
 | 
|---|
| 20 |  S GMCR=0,GMFIRST=1
 | 
|---|
| 21 |  F  S GMCR=$O(GMTSEG(GMTSEGN,811.9,GMCR)) Q:'GMCR  D  Q:$D(GMTSQIT)
 | 
|---|
| 22 |  . S CRSEG=GMTSEG(GMTSEGN,811.9,GMCR)
 | 
|---|
| 23 |  . K ^TMP("PXRHM",$J),^TMP("PXRM",$J)
 | 
|---|
| 24 |  . D MAIN^PXRM(DFN,CRSEG,+$G(GMFLAG),1)
 | 
|---|
| 25 |  . D:+$D(^TMP("PXRHM",$J)) GETCR
 | 
|---|
| 26 |  I +$G(GMDISP)'>0 D CKP^GMTSUP Q:$D(GMTSQIT)  W "Selected Clinical Reminders not due.",!
 | 
|---|
| 27 |  K ^TMP("PXRHM",$J),^TMP("PXRM",$J)
 | 
|---|
| 28 |  Q
 | 
|---|
| 29 |  ;
 | 
|---|
| 30 | HVET ;
 | 
|---|
| 31 |  N GMFIRST
 | 
|---|
| 32 |  K ^TMP("PXRHM",$J),^TMP("PXRMHV",$J)
 | 
|---|
| 33 |  S GMFIRST=1
 | 
|---|
| 34 |  D HS^PXRMHVET(DFN,HVDISP)
 | 
|---|
| 35 |  D:+$D(^TMP("PXRMHV",$J)) GETCRH
 | 
|---|
| 36 |  I +$G(GMDISP)'>0 D CKP^GMTSUP Q:$D(GMTSQIT)  W "No Patient Reminders found.",!
 | 
|---|
| 37 |  K ^TMP("PXRHM",$J),^TMP("PXRMHV",$J)
 | 
|---|
| 38 |  Q
 | 
|---|
| 39 |  ;
 | 
|---|
| 40 | GETCR ; Get reminders that were returned
 | 
|---|
| 41 |  N ITEM,GMDT,GMN0,X,GMTSDAT,GMTSDUE,GMREM
 | 
|---|
| 42 |  I HVET=1 D GETCRH
 | 
|---|
| 43 |  S ITEM=0
 | 
|---|
| 44 |  F  S ITEM=$O(^TMP("PXRHM",$J,ITEM)) Q:ITEM'>0  D  Q:$D(GMTSQIT)
 | 
|---|
| 45 |  . S GMREM=""
 | 
|---|
| 46 |  . F  S GMREM=$O(^TMP("PXRHM",$J,ITEM,GMREM)) Q:GMREM=""  D CRDISP Q:$D(GMTSQIT)
 | 
|---|
| 47 |  Q
 | 
|---|
| 48 |  ;
 | 
|---|
| 49 | GETCRH ; Get Reminders that were returned for MyHealtheVet
 | 
|---|
| 50 |  N ITEM,GMDT,GMN0,X,GMTSDAT,GMTSDUE,GMREM,GMSTATUS
 | 
|---|
| 51 |  S GMSTATUS=""
 | 
|---|
| 52 |  F  S GMSTATUS=$O(^TMP("PXRMHV",$J,GMSTATUS)) Q:GMSTATUS=""  D  Q:$D(GMTSQIT)
 | 
|---|
| 53 |  .S GMREM="" F  S GMREM=$O(^TMP("PXRMHV",$J,GMSTATUS,GMREM)) Q:GMREM=""  D  Q:$D(GMTSQIT)
 | 
|---|
| 54 |  ..S ITEM=0 F  S ITEM=$O(^TMP("PXRMHV",$J,GMSTATUS,GMREM,ITEM)) Q:ITEM'>0  D CRDISP Q:$D(GMTSQIT)
 | 
|---|
| 55 |  Q
 | 
|---|
| 56 |  ;
 | 
|---|
| 57 | CRDISP ; Display reminder data
 | 
|---|
| 58 |  N DUECOL,HIST,LASTCOL,STATUS,STATCOL,TYPE
 | 
|---|
| 59 |  I HVET=0 S GMN0=$G(^TMP("PXRHM",$J,ITEM,GMREM))
 | 
|---|
| 60 |  I HVET=1 S GMN0=$G(^TMP("PXRMHV",$J,GMSTATUS,GMREM,ITEM))
 | 
|---|
| 61 |  Q:GMN0']""
 | 
|---|
| 62 |  S STATUS=$P(GMN0,U,1)
 | 
|---|
| 63 |  S X=$P(GMN0,U,2) D REGDT4^GMTSU S GMTSDUE=X
 | 
|---|
| 64 |  S X=$P(GMN0,U,3) D REGDT4^GMTSU S GMTSDAT=X
 | 
|---|
| 65 |  S TYPE=$P(GMN0,U,4)
 | 
|---|
| 66 |  I TYPE["E" S HIST="(hist)"
 | 
|---|
| 67 |  I TYPE["X" S HIST="(exp)"
 | 
|---|
| 68 |  S GMDISP=1
 | 
|---|
| 69 |  D CKP^GMTSUP Q:$D(GMTSQIT)
 | 
|---|
| 70 |  I GMTSNPG D HDR,CKP^GMTSUP Q:$D(GMTSQIT)
 | 
|---|
| 71 |  I GMTSNPG D HDR
 | 
|---|
| 72 |  S STATCOL=41-($L(STATUS)/2)
 | 
|---|
| 73 |  S DUECOL=53-($L(GMTSDUE)/2)
 | 
|---|
| 74 |  S LASTCOL=67-($L(GMTSDAT)/2)
 | 
|---|
| 75 |  W GMREM,?STATCOL,STATUS,?DUECOL,GMTSDUE,?LASTCOL,GMTSDAT,?73,$G(HIST),!
 | 
|---|
| 76 |  I 'CM Q
 | 
|---|
| 77 |  ;   Display activity data on reminder
 | 
|---|
| 78 |  I HVET=1 D HVETCM Q
 | 
|---|
| 79 |  ;;commented out the following because I believe it is outdated
 | 
|---|
| 80 |  ;S GMDT=0
 | 
|---|
| 81 |  ;F  S GMDT=$O(^TMP("PXRHM",$J,ITEM,GMREM,GMDT)) Q:+GMDT'>0  D  Q:$D(GMTSQIT)
 | 
|---|
| 82 |  ;. S GMN0=$G(^TMP("PXRHM",$J,ITEM,GMREM,GMDT))
 | 
|---|
| 83 |  ;. Q:GMN0']""
 | 
|---|
| 84 |  ;. I $P(GMN0,U,2) S X=$P(GMN0,U,2) D REGDT4^GMTSU S GMTSDAT=X
 | 
|---|
| 85 |  ;. D CKP^GMTSUP Q:$D(GMTSQIT)
 | 
|---|
| 86 |  ;. I GMTSNPG D HDR
 | 
|---|
| 87 |  ;. W ?5,$P(GMN0,U)," on record - ",$G(GMTSDAT),", ",$P(GMN0,U,3),!
 | 
|---|
| 88 |  ;;   Display maintenance criteria for reminder
 | 
|---|
| 89 |  S GMDT=0
 | 
|---|
| 90 |  F  S GMDT=$O(^TMP("PXRHM",$J,ITEM,GMREM,"TXT",GMDT)) Q:+GMDT'>0  D  Q:$D(GMTSQIT)
 | 
|---|
| 91 |  . D CKP^GMTSUP Q:$D(GMTSQIT)
 | 
|---|
| 92 |  . I GMTSNPG D HDR
 | 
|---|
| 93 |  . W ?5,$G(^TMP("PXRHM",$J,ITEM,GMREM,"TXT",GMDT)),!
 | 
|---|
| 94 |  W !
 | 
|---|
| 95 |  Q
 | 
|---|
| 96 | HVETCM ;
 | 
|---|
| 97 |  ;   Display maintenance criteria for reminder
 | 
|---|
| 98 |  S GMDT=0
 | 
|---|
| 99 |  F  S GMDT=$O(^TMP("PXRMHV",$J,GMSTATUS,GMREM,ITEM,"TXT",GMDT)) Q:+GMDT'>0  D  Q:$D(GMTSQIT)
 | 
|---|
| 100 |  . D CKP^GMTSUP Q:$D(GMTSQIT)
 | 
|---|
| 101 |  . I GMTSNPG D HDR
 | 
|---|
| 102 |  . W ?5,$G(^TMP("PXRMHV",$J,GMSTATUS,GMREM,ITEM,"TXT",GMDT)),!
 | 
|---|
| 103 |  W !
 | 
|---|
| 104 |  Q
 | 
|---|
| 105 |  ;
 | 
|---|
| 106 | HDR ; Header
 | 
|---|
| 107 |  I GMFIRST D FIRST Q:$D(GMTSQIT)  S GMFIRST=0
 | 
|---|
| 108 |  W ?36,"--STATUS--",?47,"--DUE DATE--",?61,"--LAST DONE--",!
 | 
|---|
| 109 |  Q
 | 
|---|
| 110 |  ;
 | 
|---|
| 111 | FIRST ; Display Disclaimer
 | 
|---|
| 112 |  N GMREC
 | 
|---|
| 113 |  S GMREC=0
 | 
|---|
| 114 |  F  S GMREC=$O(^TMP("PXRM",$J,"DISC",GMREC)) Q:+GMREC'>0  D  Q:$D(GMTSQIT)
 | 
|---|
| 115 |  . D CKP^GMTSUP Q:$D(GMTSQIT)
 | 
|---|
| 116 |  . W ?1,$G(^TMP("PXRM",$J,"DISC",GMREC)),!
 | 
|---|
| 117 |  W !
 | 
|---|
| 118 |  Q
 | 
|---|