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

BWBRPCD.m

Go to the documentation of this file.
  1. BWBRPCD ;IHS/ANMC/MWR - BROWSE PROCEDURES;27-Feb-2003 22:26;PLS
  1. ;;2.0;WOMEN'S HEALTH;**8**;MAY 16, 1996
  1. ;;* MICHAEL REMILLARD, DDS * ALASKA NATIVE MEDICAL CENTER *
  1. ;; CALLED BY OPTION: "BW BROWSE PROCEDURES" TO BROWSE AND EDIT
  1. ;; PROCEDURES.
  1. ;
  1. ;---> VARIABLES:
  1. ;---> BWA: 1=ALL PATIENTS, 0=ONE PATIENT
  1. ;---> BWDFN: DFN OF SELECTED PATIENT
  1. ;---> DATES: BWBEGDT=BEGINNING DATE, BWENDDT=ENDING DATE
  1. ;---> BWD: 1=BOTH ABNORMAL AND NORMAL, 0=NORMAL ONLY
  1. ;---> SORT SEQUENCE IN BWC: 1=DATE, PATIENT, PRIORITY
  1. ;---> 2=PATIENT, DATE, PRIORITY
  1. ;---> 3=PRIORITY, DATE, PATIENT
  1. ;---> USE NODES 1 & 2 IN ^TMP GLOBAL
  1. ;
  1. D SETVARS^BWUTL5 S BWPOP=0
  1. D ^BWBRPCD2 G:BWPOP EXIT
  1. D SORT
  1. D COPYGBL
  1. ;---> NEXT LINE: PASS TITLE, HEADER (IN ^BWUTL7), AND CODE TO
  1. ;---> EXECUTE BY DIR AT BOTTOM OF SCREEN.
  1. D DISPLAY^BWBRPCD1(BWTITLE,BWHEADER,BWCODE)
  1. ;
  1. EXIT ;EP
  1. D KILLALL^BWUTL8
  1. Q
  1. ;
  1. ;
  1. SORT ;EP
  1. ;---> SORT AND STORE ARRAY IN ^TMP("BW",$J
  1. N BWPROC
  1. K ^TMP("BW",$J)
  1. ;---> BWBEGDT1=ONE SECOND BEFORE BEGIN DATE.
  1. ;---> BWENDDT1=THE LAST SECOND OF END DATE.
  1. S BWBEGDT1=BWBEGDT-.0001,BWENDDT1=BWENDDT+.9999
  1. ;
  1. ;***********************
  1. ;---> BWA=1 ALL PATIENTS
  1. I BWA D Q
  1. .;---> BY DATE GET EITHER ALL OR ABNORMAL ONLY.
  1. .;---> ("INSUFFICIENT TISSUE" IS INCLUDED IN ABNML XREF.)
  1. .S BWXREF=$S(BWD:"D",1:"ABNML")
  1. .S BWDATE=BWBEGDT1
  1. .F S BWDATE=$O(^BWPCD(BWXREF,BWDATE)) Q:'BWDATE!(BWDATE>BWENDDT1) D
  1. ..S BWIEN=0
  1. ..F S BWIEN=$O(^BWPCD(BWXREF,BWDATE,BWIEN)) Q:'BWIEN D
  1. ...S Y=^BWPCD(BWIEN,0),BWDFN=$P(Y,U,2),BWPROC=+$P(Y,U,4)
  1. ...;---> QUIT IF THIS PROCEDURE HAS A RESULT OF "ERROR/DISREGARD".
  1. ...Q:$P(Y,U,5)=8
  1. ...;---> QUIT IF NOT SELECTING FOR ALL PROCEDURES AND IF THIS IS
  1. ...;---> NOT ONE OF THE SELECTED PROCEDURES.
  1. ...I '$D(BWARR("ALL")) Q:'$D(BWARR(BWPROC))
  1. ...;---> QUIT IF NOT "ALL PROCEDURES" AND THIS ENTRY IS "CLOSED".
  1. ...Q:BWB'="a"&($P(Y,U,14)="c")
  1. ...;---> QUIT IF SELECTING FOR ONE CASE MANAGER AND THIS DOESN'T MATCH.
  1. ...I 'BWE Q:$P(^BWP(BWDFN,0),U,10)'=BWCMGR
  1. ...;---> QUIT IF LISTING "DELINQUENT" AND THIS PROCDURE IS NOT DELINQ.
  1. ...I BWB="d" Q:$P(Y,U,13)>DT!($P(Y,U,13)="")
  1. ...;---> QUIT IF LISTING "NEW" AND THIS PROCDURE IS NOT NEW.
  1. ...Q:BWB="n"&($P(Y,U,14)'="n")
  1. ...D STORE(BWC,BWIEN,Y)
  1. ;
  1. ;**********************
  1. ;---> BWA=0 ONE PATIENT
  1. S BWIEN=0
  1. F S BWIEN=$O(^BWPCD("C",BWDFN,BWIEN)) Q:'BWIEN D
  1. .;---> SET Y=THE ZERO NODE FOR THIS PROCEDURE.
  1. .S Y=^BWPCD(BWIEN,0)
  1. .;---> QUIT IF THIS PROCEDURE HAS A RESULT OF "ERROR/DISREGARD".
  1. .Q:$P(Y,U,5)=8
  1. .;---> QUIT IF NOT WITHIN DATE RANGE.
  1. .S BWDATE=$P(Y,U,12)
  1. .Q:BWDATE'>BWBEGDT1!(BWDATE>BWENDDT1)
  1. .;---> QUIT IF SELECTING FOR "ABNORMAL" ONLY AND THIS PROCEDURE
  1. .;---> "NORMAL". ("INSUFF TISSUE" AND "UNSAT EXAM" WILL BE "ABNORMAL".)
  1. .Q:'BWD&('$$NORMAL^BWUTL4($P(Y,U,5)))
  1. .;---> QUIT IF "DELINQUENT" OR "OPEN" ONLY AND THIS ENTRY IS "CLOSED".
  1. .Q:BWB'="a"&($P(Y,U,14)="c")
  1. .;---> QUIT IF LISTING "DELINQUENT" AND THIS PROCDURE IS NOT DELINQ.
  1. .I BWB="d" Q:$P(Y,U,13)>DT!($P(Y,U,13)="")
  1. .Q:BWB="n"&($P(Y,U,14)'="n")
  1. .D STORE(BWC,BWIEN,Y)
  1. Q
  1. ;
  1. STORE(BWC,BWIEN,Y) ;EP
  1. ;---> CALLED TO STORE PROCEDURES IN ^TMP FOR BROWSING.
  1. ;---> BWC=LIST ORDER, BWIEN=IEN OR PROCEDURE, Y=ZERO NODE OF PROCEDURE.
  1. S BWDFN=$P(Y,U,2),BWDATE=$P(Y,U,12) ;---> DFN, DATE
  1. S BWCHRT=$$HRCN^BWUTL1(BWDFN) ;---> CHART#
  1. S BWNAME=$$NAME^BWUTL1(BWDFN) ;---> NAME
  1. S BWACC=$P(Y,U) ;---> ACCESSION#
  1. S BWSTAT=$E($$STATUS^BWUTL4) ;---> STATUS
  1. S BWDIAG=$$DIAG^BWUTL4($P(Y,U,5)) ;---> RESULT/DIAG
  1. S X=$P(Y,U,5),BWPRIO=$$PRIOR^BWUTL4 K X ;---> PRIORITY
  1. ;
  1. S X=BWCHRT_U_BWNAME_U_BWDATE_U_BWACC_U_BWDIAG_U_BWPRIO_U_BWSTAT_U_BWIEN
  1. I BWC=1 S ^TMP("BW",$J,1,BWDATE,BWNAME,BWPRIO,BWIEN)=X Q
  1. I BWC=2 S ^TMP("BW",$J,1,BWNAME,BWDATE,BWPRIO,BWIEN)=X Q
  1. I BWC=3 S ^TMP("BW",$J,1,BWPRIO,BWDATE,BWNAME,BWIEN)=X
  1. Q
  1. ;
  1. COPYGBL ;EP
  1. ;---> CALLED TO FLATTEN THE ^TMP ARRAY OF PROCEDURES FOR BROWSING.
  1. ;---> COPY ^TMP("BW",$J,1 TO ^TMP("BW",$J,2 TO MAKE IT FLAT.
  1. N I,M,N,P,Q
  1. S N=0,I=0
  1. F S N=$O(^TMP("BW",$J,1,N)) Q:N="" D
  1. .S M=0
  1. .F S M=$O(^TMP("BW",$J,1,N,M)) Q:M="" D
  1. ..S P=0
  1. ..F S P=$O(^TMP("BW",$J,1,N,M,P)) Q:P="" D
  1. ...S Q=0
  1. ...F S Q=$O(^TMP("BW",$J,1,N,M,P,Q)) Q:Q="" D
  1. ....S I=I+1,^TMP("BW",$J,2,I)=^TMP("BW",$J,1,N,M,P,Q)
  1. Q
  1. ;
  1. DEQUEUE ;EP
  1. ;---> FOR TASKMAN QUEUE OF PRINTOUT.
  1. D SETVARS^BWUTL5,SORT,COPYGBL
  1. D DISPLAY^BWBRPCD1(BWTITLE,BWHEADER,BWCODE)
  1. D EXIT
  1. Q