| 1 | WVBRPCD ;HCIOFO/FT,JR IHS/ANMC/MWR - BROWSE PROCEDURES; ;7/30/98  11:07
 | 
|---|
| 2 |  ;;1.0;WOMEN'S HEALTH;;Sep 30, 1998
 | 
|---|
| 3 |  ;;* MICHAEL REMILLARD, DDS * ALASKA NATIVE MEDICAL CENTER *
 | 
|---|
| 4 |  ;;  CALLED BY OPTION: "WV BROWSE PROCEDURES" TO BROWSE AND EDIT
 | 
|---|
| 5 |  ;;  PROCEDURES.
 | 
|---|
| 6 |  ;
 | 
|---|
| 7 |  ;---> VARIABLES:
 | 
|---|
| 8 |  ;---> WVA:   1=ALL PATIENTS, 0=ONE PATIENT
 | 
|---|
| 9 |  ;---> WVDFN: DFN OF SELECTED PATIENT
 | 
|---|
| 10 |  ;---> DATES: WVBEGDT=BEGINNING DATE, WVENDDT=ENDING DATE
 | 
|---|
| 11 |  ;---> WVD:   1=BOTH ABNORMAL AND NORMAL, 0=NORMAL ONLY
 | 
|---|
| 12 |  ;---> SORT SEQUENCE IN WVC:  1=DATE, PATIENT, PRIORITY
 | 
|---|
| 13 |  ;--->                        2=PATIENT, DATE, PRIORITY
 | 
|---|
| 14 |  ;--->                        3=PRIORITY, DATE, PATIENT
 | 
|---|
| 15 |  ;---> USE NODES 1 & 2 IN ^TMP GLOBAL
 | 
|---|
| 16 |  ;
 | 
|---|
| 17 |  D SETVARS^WVUTL5 S WVPOP=0
 | 
|---|
| 18 |  D ^WVBRPCD2 G:WVPOP EXIT
 | 
|---|
| 19 |  D SORT
 | 
|---|
| 20 |  D COPYGBL
 | 
|---|
| 21 |  ;---> NEXT LINE: PASS TITLE, HEADER (IN ^WVUTL7), AND CODE TO
 | 
|---|
| 22 |  ;---> EXECUTE BY DIR AT BOTTOM OF SCREEN.
 | 
|---|
| 23 |  D DISPLAY^WVBRPCD1(WVTITLE,WVHEADER,WVCODE)
 | 
|---|
| 24 |  ;
 | 
|---|
| 25 | EXIT ;EP
 | 
|---|
| 26 |  D KILLALL^WVUTL8
 | 
|---|
| 27 |  Q
 | 
|---|
| 28 |  ;
 | 
|---|
| 29 |  ;
 | 
|---|
| 30 | SORT ;EP
 | 
|---|
| 31 |  ;---> SORT AND STORE ARRAY IN ^TMP("WV",$J
 | 
|---|
| 32 |  K ^TMP("WV",$J)
 | 
|---|
| 33 |  ;---> WVBEGDT1=ONE SECOND BEFORE BEGIN DATE.
 | 
|---|
| 34 |  ;---> WVENDDT1=THE LAST SECOND OF END DATE.
 | 
|---|
| 35 |  S WVBEGDT1=WVBEGDT-.0001,WVENDDT1=WVENDDT+.9999
 | 
|---|
| 36 |  ;
 | 
|---|
| 37 |  ;***********************
 | 
|---|
| 38 |  ;---> WVA=1 ALL PATIENTS
 | 
|---|
| 39 |  I WVA D  Q
 | 
|---|
| 40 |  .;---> BY DATE GET EITHER ALL OR ABNORMAL ONLY.
 | 
|---|
| 41 |  .;---> ("INSUFFICIENT TISSUE" IS INCLUDED IN ABNML XREF.)
 | 
|---|
| 42 |  .S WVXREF=$S(WVD:"D",1:"ABNML")
 | 
|---|
| 43 |  .S WVDATE=WVBEGDT1
 | 
|---|
| 44 |  .F  S WVDATE=$O(^WV(790.1,WVXREF,WVDATE)) Q:'WVDATE!(WVDATE>WVENDDT1)  D
 | 
|---|
| 45 |  ..S WVIEN=0
 | 
|---|
| 46 |  ..F  S WVIEN=$O(^WV(790.1,WVXREF,WVDATE,WVIEN)) Q:'WVIEN  D
 | 
|---|
| 47 |  ...S Y=^WV(790.1,WVIEN,0),WVDFN=$P(Y,U,2)
 | 
|---|
| 48 |  ...;---> QUIT IF THIS PROCEDURE HAS A RESULT OF "ERROR/DISREGARD".
 | 
|---|
| 49 |  ...Q:$P(Y,U,5)=8
 | 
|---|
| 50 |  ...;---> QUIT IF NOT SELECTING FOR ALL PROCEDURES AND IF THIS IS
 | 
|---|
| 51 |  ...;---> NOT ONE OF THE SELECTED PROCEDURES.
 | 
|---|
| 52 |  ...I '$D(WVARR("ALL"))  Q:'$D(WVARR($P(Y,U,4)))
 | 
|---|
| 53 |  ...;---> QUIT IF NOT "ALL PROCEDURES" AND THIS ENTRY IS "CLOSED".
 | 
|---|
| 54 |  ...Q:WVB'="a"&($P(Y,U,14)="c")
 | 
|---|
| 55 |  ...;---> QUIT IF SELECTING FOR ONE CASE MANAGER AND THIS DOESN'T MATCH.
 | 
|---|
| 56 |  ...I 'WVE Q:$P(^WV(790,WVDFN,0),U,10)'=WVCMGR
 | 
|---|
| 57 |  ...;---> QUIT IF LISTING "DELINQUENT" AND THIS PROCDURE IS NOT DELINQ.
 | 
|---|
| 58 |  ...I WVB="d" Q:$P(Y,U,13)>DT!($P(Y,U,13)="")
 | 
|---|
| 59 |  ...;---> QUIT IF LISTING "NEW" AND THIS PROCDURE IS NOT NEW.
 | 
|---|
| 60 |  ...;Q:WVB="n"&($P(Y,U,14)'="n")
 | 
|---|
| 61 |  ...D STORE(WVC,WVIEN,Y)
 | 
|---|
| 62 |  ;
 | 
|---|
| 63 |  ;**********************
 | 
|---|
| 64 |  ;---> WVA=0 ONE PATIENT
 | 
|---|
| 65 |  S WVIEN=0
 | 
|---|
| 66 |  F  S WVIEN=$O(^WV(790.1,"C",WVDFN,WVIEN)) Q:'WVIEN  D
 | 
|---|
| 67 |  .;---> SET Y=THE ZERO NODE FOR THIS PROCEDURE.
 | 
|---|
| 68 |  .S Y=^WV(790.1,WVIEN,0)
 | 
|---|
| 69 |  .;---> QUIT IF THIS PROCEDURE HAS A RESULT OF "ERROR/DISREGARD".
 | 
|---|
| 70 |  .Q:$P(Y,U,5)=8
 | 
|---|
| 71 |  .;---> QUIT IF NOT WITHIN DATE RANGE.
 | 
|---|
| 72 |  .S WVDATE=$P(Y,U,12)
 | 
|---|
| 73 |  .Q:WVDATE'>WVBEGDT1!(WVDATE>WVENDDT1)
 | 
|---|
| 74 |  .;---> QUIT IF SELECTING FOR "ABNORMAL" ONLY AND THIS PROCEDURE
 | 
|---|
| 75 |  .;---> "NORMAL". ("INSUFF TISSUE" AND "UNSAT EXAM" WILL BE "ABNORMAL".)
 | 
|---|
| 76 |  .Q:'WVD&('$$NORMAL^WVUTL4($P(Y,U,5)))
 | 
|---|
| 77 |  .;---> QUIT IF "DELINQUENT" OR "OPEN" ONLY AND THIS ENTRY IS "CLOSED".
 | 
|---|
| 78 |  .Q:WVB'="a"&($P(Y,U,14)="c")
 | 
|---|
| 79 |  .;---> QUIT IF LISTING "DELINQUENT" AND THIS PROCDURE IS NOT DELINQ.
 | 
|---|
| 80 |  .I WVB="d" Q:$P(Y,U,13)>DT!($P(Y,U,13)="")
 | 
|---|
| 81 |  .;Q:WVB="n"&($P(Y,U,14)'="n")
 | 
|---|
| 82 |  .D STORE(WVC,WVIEN,Y)
 | 
|---|
| 83 |  Q
 | 
|---|
| 84 |  ;
 | 
|---|
| 85 | STORE(WVC,WVIEN,Y) ;EP
 | 
|---|
| 86 |  ;---> CALLED TO STORE PROCEDURES IN ^TMP FOR BROWSING.
 | 
|---|
| 87 |  ;---> WVC=LIST ORDER, WVIEN=IEN OR PROCEDURE, Y=ZERO NODE OF PROCEDURE.
 | 
|---|
| 88 |  S WVDFN=$P(Y,U,2),WVDATE=$P(Y,U,12)                   ;---> DFN, DATE
 | 
|---|
| 89 |  S WVCHRT=$$SSN^WVUTL1(WVDFN)_" "                      ;---> SSN#
 | 
|---|
| 90 |  S WVNAME=$$NAME^WVUTL1(WVDFN)                         ;---> NAME
 | 
|---|
| 91 |  S WVACC=$P(Y,U)                                       ;---> ACCESSION#
 | 
|---|
| 92 |  S WVSTAT=$E($$STATUS^WVUTL4)                          ;---> STATUS
 | 
|---|
| 93 |  S WVDIAG=$$DIAG^WVUTL4($P(Y,U,5))                     ;---> RESULT/DIAG
 | 
|---|
| 94 |  S X=$P(Y,U,5),WVPRIO=$$PRIOR^WVUTL4 K X               ;---> PRIORITY
 | 
|---|
| 95 |  ;
 | 
|---|
| 96 |  S X=WVCHRT_U_WVNAME_U_WVDATE_U_WVACC_U_WVDIAG_U_WVPRIO_U_WVSTAT_U_WVIEN
 | 
|---|
| 97 |  I WVC=1 S ^TMP("WV",$J,1,WVDATE,WVNAME,WVPRIO,WVIEN)=X Q
 | 
|---|
| 98 |  I WVC=2 S ^TMP("WV",$J,1,WVNAME,WVDATE,WVPRIO,WVIEN)=X Q
 | 
|---|
| 99 |  I WVC=3 S ^TMP("WV",$J,1,WVPRIO,WVDATE,WVNAME,WVIEN)=X
 | 
|---|
| 100 |  Q
 | 
|---|
| 101 |  ;
 | 
|---|
| 102 | COPYGBL ;EP
 | 
|---|
| 103 |  ;---> CALLED TO FLATTEN THE ^TMP ARRAY OF PROCEDURES FOR BROWSING.
 | 
|---|
| 104 |  ;---> COPY ^TMP("WV",$J,1 TO ^TMP("WV",$J,2 TO MAKE IT FLAT.
 | 
|---|
| 105 |  N I,M,N,P,Q
 | 
|---|
| 106 |  S N=0,I=0
 | 
|---|
| 107 |  F  S N=$O(^TMP("WV",$J,1,N)) Q:N=""  D
 | 
|---|
| 108 |  .S M=0
 | 
|---|
| 109 |  .F  S M=$O(^TMP("WV",$J,1,N,M)) Q:M=""  D
 | 
|---|
| 110 |  ..S P=0
 | 
|---|
| 111 |  ..F  S P=$O(^TMP("WV",$J,1,N,M,P)) Q:P=""  D
 | 
|---|
| 112 |  ...S Q=0
 | 
|---|
| 113 |  ...F  S Q=$O(^TMP("WV",$J,1,N,M,P,Q)) Q:Q=""  D
 | 
|---|
| 114 |  ....S I=I+1,^TMP("WV",$J,2,I)=^TMP("WV",$J,1,N,M,P,Q)
 | 
|---|
| 115 |  Q
 | 
|---|
| 116 |  ;
 | 
|---|
| 117 | DEQUEUE ;EP
 | 
|---|
| 118 |  ;---> FOR TASKMAN QUEUE OF PRINTOUT.
 | 
|---|
| 119 |  D SETVARS^WVUTL5,SORT,COPYGBL
 | 
|---|
| 120 |  D DISPLAY^WVBRPCD1(WVTITLE,WVHEADER,WVCODE)
 | 
|---|
| 121 |  D EXIT
 | 
|---|
| 122 |  Q
 | 
|---|