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

WVBRNOT.m

Go to the documentation of this file.
  1. WVBRNOT ;HCIOFO/FT,JR IHS/ANMC/MWR - BROWSE NOTIFICATIONS; ;7/30/98 11:02
  1. ;;1.0;WOMEN'S HEALTH;;Sep 30, 1998
  1. ;;* MICHAEL REMILLARD, DDS * ALASKA NATIVE MEDICAL CENTER *
  1. ;; CALLED BY OPTION: "WV BROWSE NOTIFICATIONS" TO BROWSE AND EDIT
  1. ;; NOTIFICATIONS.
  1. ;
  1. ;---> VARIABLES:
  1. ;---> WVA: 1=ALL PATIENTS, 0=ONE PATIENT
  1. ;---> WVDFN: DFN OF SELECTED PATIENT
  1. ;---> DATES: WVBEGDT=BEGINNING DATE, WVENDDT=ENDING DATE
  1. ;---> WVB: d=DELINQUENT, o=OPEN, q=queued, a=ALL (includes CLOSED).
  1. ;---> SORT SEQUENCE IN WVC: 1=DATE, PATIENT, PRIORITY
  1. ;---> 2=PATIENT, DATE, PRIORITY
  1. ;---> 3=PRIORITY, DATE, PATIENT
  1. ;---> USE NODES 3 & 4 IN ^TMP GLOBAL.
  1. ;
  1. D SETVARS^WVUTL5
  1. D ^WVBRNOT2 G:WVPOP EXIT
  1. D SORT
  1. D COPYGBL
  1. D ^WVBRNOT1
  1. ;
  1. EXIT ;EP
  1. D KILLALL^WVUTL8
  1. Q
  1. ;
  1. ;
  1. SORT ;EP
  1. ;---> SORT AND STORE ARRAY IN ^TMP("WV",$J
  1. K ^TMP("WV",$J)
  1. ;---> WVBEGDT1=ONE SECOND BEFORE BEGIN DATE.
  1. ;---> WVENDDT1=THE LAST SECOND OF END DATE.
  1. S WVBEGDT1=WVBEGDT-.0001,WVENDDT1=WVENDDT+.9999
  1. ;
  1. ;**************************
  1. ;---> WVA=1: ALL PATIENTS
  1. I WVA D Q
  1. .;---> BY DATE GET EITHER ALL OR OPEN ONLY.
  1. .N WVDFN,WVIEN,Y
  1. .S WVXREF=$S(WVB="a":"D",WVB="q":"APRT",1:"AOPEN")
  1. .S WVDATE=WVBEGDT1
  1. .F S WVDATE=$O(^WV(790.4,WVXREF,WVDATE)) Q:'WVDATE!(WVDATE>WVENDDT1) D
  1. ..S WVIEN=0
  1. ..F S WVIEN=$O(^WV(790.4,WVXREF,WVDATE,WVIEN)) Q:'WVIEN D
  1. ...Q:'$D(^WV(790.4,WVIEN,0))
  1. ...S Y=^WV(790.4,WVIEN,0),WVDFN=$P(Y,U)
  1. ...;---> QUIT IF SELECTING FOR ONE CASE MANAGER AND THIS DOESN'T MATCH.
  1. ...I 'WVE Q:$P(^WV(790,WVDFN,0),U,10)'=WVCMGR
  1. ...;---> QUIT IF LISTING "DELINQUENT" AND THIS PROCDURE IS NOT DELINQ.
  1. ...I WVB="d" Q:$P(Y,U,13)'<DT!($P(Y,U,13)="")
  1. ...D STORE
  1. ;
  1. ;**************************
  1. ;---> WVA=0: ONE PATIENT
  1. N WVIEN,Y S WVIEN=0
  1. F S WVIEN=$O(^WV(790.4,"B",WVDFN,WVIEN)) Q:'WVIEN D
  1. .S Y=^WV(790.4,WVIEN,0)
  1. .;---> QUIT IF NOT WITHIN DATE RANGE.
  1. .S WVDATE=$P(Y,U,2)
  1. .Q:WVDATE'>WVBEGDT1!(WVDATE>WVENDDT1)
  1. .;---> QUIT IF "QUEUED" AND THIS NOTIFICATION IS NOT QUEUED.
  1. .I WVB="q" Q:'$P(Y,U,11) Q:'$D(^WV(790.4,"APRT",$P(Y,U,11),WVIEN))
  1. .;---> QUIT IF "DELINQUENT" OR OPEN ONLY AND THIS ENTRY IS CLOSED.
  1. .Q:"do"[WVB&($P(Y,U,14)="c")
  1. .I WVB="d" Q:$P(Y,U,13)'<DT!($P(Y,U,13)="")
  1. .D STORE
  1. Q
  1. ;
  1. STORE ;EP
  1. ;--->WVDATE IS ALREADY SET FROM LL SORT ABOVE. ;---> DATE
  1. S WVCHRT=$$SSN^WVUTL1(WVDFN)_" " ;---> SSN#
  1. S WVNAME=$$NAME^WVUTL1(WVDFN) ;---> NAME
  1. S WVACC=$P(Y,U,6) ;---> ACCESSION#
  1. I WVACC]"" S WVACC=$P(^WV(790.1,WVACC,0),U)
  1. S WVSTAT=$$STATUS^WVUTL4 ;---> STATUS
  1. S WVPRIO=9
  1. S:$P(Y,U,4)]"" WVPRIO=$P(^WV(790.404,$P(Y,U,4),0),U,2) ;---> PRIORITY
  1. ;
  1. S X=WVCHRT_U_WVNAME_U_WVDATE_U_WVACC_U_WVSTAT_U_WVPRIO_U_WVIEN
  1. I WVC=1 S ^TMP("WV",$J,3,WVDATE,WVNAME,WVPRIO,WVIEN)=X Q
  1. I WVC=2 S ^TMP("WV",$J,3,WVNAME,WVDATE,WVPRIO,WVIEN)=X Q
  1. I WVC=3 S ^TMP("WV",$J,3,WVPRIO,WVDATE,WVNAME,WVIEN)=X
  1. Q
  1. ;
  1. COPYGBL ;EP
  1. ;---> COPY ^TMP("WV",$J,3 TO ^TMP("WV",$J,4 TO MAKE IT FLAT.
  1. N I,M,N,P,Q
  1. S N=0,I=0
  1. F S N=$O(^TMP("WV",$J,3,N)) Q:N="" D
  1. .S M=0
  1. .F S M=$O(^TMP("WV",$J,3,N,M)) Q:M="" D
  1. ..S P=0
  1. ..F S P=$O(^TMP("WV",$J,3,N,M,P)) Q:P="" D
  1. ...S Q=0
  1. ...F S Q=$O(^TMP("WV",$J,3,N,M,P,Q)) Q:Q="" D
  1. ....S I=I+1,^TMP("WV",$J,4,I)=^TMP("WV",$J,3,N,M,P,Q)
  1. Q
  1. ;
  1. ;
  1. DEQUEUE ;EP
  1. ;---> TASKMAN QUEUE OF PRINTOUT.
  1. D SETVARS^WVUTL5,SORT,COPYGBL,^WVBRNOT1,EXIT
  1. Q
  1. ;
  1. FOLLOW(WVDFN) ;EP
  1. ;---> CALLED FROM PROCEDURE FOLLOWUP MENU.
  1. D SETVARS^WVUTL5
  1. S WVA=0,WVB="o",WVBEGDT=(DT-50000),WVC=1,WVE=1,WVENDDT=DT
  1. D DEVICE^WVBRNOT2 Q:WVPOP
  1. S WVLOOP=1
  1. D SORT,COPYGBL,^WVBRNOT1
  1. Q