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

GMTSPXHR.m

Go to the documentation of this file.
  1. GMTSPXHR ; SLC/SBW,KER - PCE Clinical Reminders/Maint ; 06/15/2005
  1. ;;2.7;Health Summary;**8,22,23,28,34,56,63,75,82**;Oct 20, 1995;Build 21
  1. ;
  1. ; External References
  1. ; DBIA 2182 MAIN^PXRM
  1. ;
  1. MAIN ; Entry Point for Clinical Reminders
  1. N CM,GMFLAG,HVET,HVDISP
  1. S (HVET,CM)=0
  1. I GMTSEGH["CR" S GMFLAG=0
  1. I GMTSEGH["CRS" S GMFLAG=1
  1. I GMTSEGH["CM" S GMFLAG=5,CM=1
  1. I GMTSEGH["CMB" S GMFLAG=4,CM=1
  1. I GMTSEGH["MHVD" S HVET=1,CM=1,HVDISP=11
  1. I GMTSEGH["MHVS" S HVET=1,CM=1,HVDISP=10
  1. Q:+$G(GMTSAGE)'>0!($G(SEX)="")!($G(DFN)'>0)
  1. I HVET=1 D HVET Q
  1. Q:$O(GMTSEG(GMTSEGN,811.9,0))'>0
  1. N GMCR,GMFIRST,CRSEG,GMDISP
  1. S GMCR=0,GMFIRST=1
  1. F S GMCR=$O(GMTSEG(GMTSEGN,811.9,GMCR)) Q:'GMCR D Q:$D(GMTSQIT)
  1. . S CRSEG=GMTSEG(GMTSEGN,811.9,GMCR)
  1. . K ^TMP("PXRHM",$J),^TMP("PXRM",$J)
  1. . D MAIN^PXRM(DFN,CRSEG,+$G(GMFLAG),1)
  1. . D:+$D(^TMP("PXRHM",$J)) GETCR
  1. I +$G(GMDISP)'>0 D CKP^GMTSUP Q:$D(GMTSQIT) W "Selected Clinical Reminders not due.",!
  1. K ^TMP("PXRHM",$J),^TMP("PXRM",$J)
  1. Q
  1. ;
  1. HVET ;
  1. N GMFIRST
  1. K ^TMP("PXRHM",$J),^TMP("PXRMHV",$J)
  1. S GMFIRST=1
  1. D HS^PXRMHVET(DFN,HVDISP)
  1. D:+$D(^TMP("PXRMHV",$J)) GETCRH
  1. I +$G(GMDISP)'>0 D CKP^GMTSUP Q:$D(GMTSQIT) W "No Patient Reminders found.",!
  1. K ^TMP("PXRHM",$J),^TMP("PXRMHV",$J)
  1. Q
  1. ;
  1. GETCR ; Get reminders that were returned
  1. N ITEM,GMDT,GMN0,X,GMTSDAT,GMTSDUE,GMREM
  1. I HVET=1 D GETCRH
  1. S ITEM=0
  1. F S ITEM=$O(^TMP("PXRHM",$J,ITEM)) Q:ITEM'>0 D Q:$D(GMTSQIT)
  1. . S GMREM=""
  1. . F S GMREM=$O(^TMP("PXRHM",$J,ITEM,GMREM)) Q:GMREM="" D CRDISP Q:$D(GMTSQIT)
  1. Q
  1. ;
  1. GETCRH ; Get Reminders that were returned for MyHealtheVet
  1. N ITEM,GMDT,GMN0,X,GMTSDAT,GMTSDUE,GMREM,GMSTATUS
  1. S GMSTATUS=""
  1. F S GMSTATUS=$O(^TMP("PXRMHV",$J,GMSTATUS)) Q:GMSTATUS="" D Q:$D(GMTSQIT)
  1. .S GMREM="" F S GMREM=$O(^TMP("PXRMHV",$J,GMSTATUS,GMREM)) Q:GMREM="" D Q:$D(GMTSQIT)
  1. ..S ITEM=0 F S ITEM=$O(^TMP("PXRMHV",$J,GMSTATUS,GMREM,ITEM)) Q:ITEM'>0 D CRDISP Q:$D(GMTSQIT)
  1. Q
  1. ;
  1. CRDISP ; Display reminder data
  1. N DUECOL,HIST,LASTCOL,STATUS,STATCOL,TYPE
  1. I HVET=0 S GMN0=$G(^TMP("PXRHM",$J,ITEM,GMREM))
  1. I HVET=1 S GMN0=$G(^TMP("PXRMHV",$J,GMSTATUS,GMREM,ITEM))
  1. Q:GMN0']""
  1. S STATUS=$P(GMN0,U,1)
  1. S X=$P(GMN0,U,2) D REGDT4^GMTSU S GMTSDUE=X
  1. S X=$P(GMN0,U,3) D REGDT4^GMTSU S GMTSDAT=X
  1. S TYPE=$P(GMN0,U,4)
  1. I TYPE["E" S HIST="(hist)"
  1. I TYPE["X" S HIST="(exp)"
  1. S GMDISP=1
  1. D CKP^GMTSUP Q:$D(GMTSQIT)
  1. I '$D(GMTSOBJ("COMPONENT HEADER")),$D(GMTSOBJ("REPORT HEADER")),GMFIRST=1 W !!
  1. I GMTSNPG D HDR,CKP^GMTSUP Q:$D(GMTSQIT)
  1. I GMTSNPG D HDR
  1. I GMFIRST W ?36,"--STATUS--",?47,"--DUE DATE--",?61,"--LAST DONE--",! S GMFIRST=0
  1. S STATCOL=41-($L(STATUS)/2)
  1. S DUECOL=53-($L(GMTSDUE)/2)
  1. S LASTCOL=67-($L(GMTSDAT)/2)
  1. W GMREM,?STATCOL,STATUS,?DUECOL,GMTSDUE,?LASTCOL,GMTSDAT,?73,$G(HIST),!
  1. I 'CM Q
  1. ; Display activity data on reminder
  1. I HVET=1 D HVETCM Q
  1. ;;commented out the following because I believe it is outdated
  1. ;S GMDT=0
  1. ;F S GMDT=$O(^TMP("PXRHM",$J,ITEM,GMREM,GMDT)) Q:+GMDT'>0 D Q:$D(GMTSQIT)
  1. ;. S GMN0=$G(^TMP("PXRHM",$J,ITEM,GMREM,GMDT))
  1. ;. Q:GMN0']""
  1. ;. I $P(GMN0,U,2) S X=$P(GMN0,U,2) D REGDT4^GMTSU S GMTSDAT=X
  1. ;. D CKP^GMTSUP Q:$D(GMTSQIT)
  1. ;. I GMTSNPG D HDR
  1. ;. W ?5,$P(GMN0,U)," on record - ",$G(GMTSDAT),", ",$P(GMN0,U,3),!
  1. ;; Display maintenance criteria for reminder
  1. S GMDT=0
  1. F S GMDT=$O(^TMP("PXRHM",$J,ITEM,GMREM,"TXT",GMDT)) Q:+GMDT'>0 D Q:$D(GMTSQIT)
  1. . D CKP^GMTSUP Q:$D(GMTSQIT)
  1. . I GMTSNPG D HDR
  1. . W ?5,$G(^TMP("PXRHM",$J,ITEM,GMREM,"TXT",GMDT)),!
  1. W !
  1. Q
  1. HVETCM ;
  1. ; Display maintenance criteria for reminder
  1. S GMDT=0
  1. F S GMDT=$O(^TMP("PXRMHV",$J,GMSTATUS,GMREM,ITEM,"TXT",GMDT)) Q:+GMDT'>0 D Q:$D(GMTSQIT)
  1. . D CKP^GMTSUP Q:$D(GMTSQIT)
  1. . I GMTSNPG D HDR
  1. . W ?5,$G(^TMP("PXRMHV",$J,GMSTATUS,GMREM,ITEM,"TXT",GMDT)),!
  1. W !
  1. Q
  1. ;
  1. HDR ; Component Header
  1. Q:'$D(GMTSOBJ("COMPONENT HEADER"))
  1. N GMREC S GMREC=0
  1. F S GMREC=$O(^TMP("PXRM",$J,"DISC",GMREC)) Q:+GMREC'>0 D Q:$D(GMTSQIT)
  1. . D CKP^GMTSUP Q:$D(GMTSQIT)
  1. . W ?1,$G(^TMP("PXRM",$J,"DISC",GMREC)),!
  1. W !
  1. Q