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

BWBRPCD2.m

Go to the documentation of this file.
  1. BWBRPCD2 ;IHS/ANMC/MWR - BROWSE PROCEDURES;15-Feb-2003 21:49;PLS
  1. ;;2.0;WOMEN'S HEALTH;**8**;MAY 16, 1996
  1. ;;* MICHAEL REMILLARD, DDS * ALASKA NATIVE MEDICAL CENTER *
  1. ;; PROMPTS FOR SELECTION CRITERIA IN BROWSING PROCEDURES.
  1. ;; CALLED BY BWBRPCD.
  1. ;
  1. D TITLE^BWUTL5("BROWSE PROCEDURES")
  1. D ONEALL Q:BWPOP
  1. D SELECT Q:BWPOP
  1. D DATES Q:BWPOP
  1. D STATUS Q:BWPOP
  1. D RESULT Q:BWPOP
  1. D CMGR Q:BWPOP
  1. D ORDER Q:BWPOP
  1. D DEVICE Q:BWPOP
  1. Q
  1. ;
  1. ONEALL ;EP
  1. ;---> SELECT ONE PATIENT OR ALL PATIENTS.
  1. N DIR,DIRUT,Y
  1. W !!?3,"Browse Procedures for ONE individual patient,"
  1. W !?3,"or browse Procedures for ALL patients?"
  1. S DIR("A")=" Select ONE or ALL: ",DIR("B")="ALL"
  1. S DIR(0)="SAM^o:ONE;a:ALL" D HELP2^BWBRPCD3
  1. D ^DIR
  1. I Y=-1!($D(DIRUT)) S BWPOP=1 Q
  1. ;---> IF ALL PATIENTS, S BWA=1 AND QUIT.
  1. I Y="a" S BWA=1 Q
  1. ;
  1. W !!," Select the patient whose Procedures you wish to browse."
  1. D PATLKUP^BWUTL8(.Y)
  1. I Y<0 S BWPOP=1 Q
  1. ;---> FOR ONE PATIENT, SET BWA=0 AND BWDFN=PATIENT DFN, QUIT.
  1. S BWDFN=+Y,BWA=0,BWCMGR=$P(^BWP(BWDFN,0),U,10)
  1. Q
  1. ;
  1. SELECT ;EP
  1. ;---> SELECT THE PROCEDURES TO BROWSE.
  1. D SELECT^BWSELECT("Procedure Type",9002086.2,"BWARR","","PAP",.BWPOP)
  1. Q
  1. ;
  1. DATES ;EP
  1. ;---> ASK DATE RANGE. RETURN DATES IN BWBEGDT AND BWENDDT.
  1. ;---> IF LOOKING AT ONLY ONE PATIENT, SET DEFAULT BEGIN DATE=T-365.
  1. S BWBEGDF=$S(BWA:"T-30",1:"T-365")
  1. D ASKDATES^BWUTL3(.BWBEGDT,.BWENDDT,.BWPOP,BWBEGDF,"T")
  1. Q
  1. ;
  1. STATUS ;EP
  1. ;---> GET XREF: OPEN OR ALL
  1. N DIR,DIRUT,Y W !!?3
  1. W "Do you wish to browse DELINQUENT, NEW, OPEN, or ALL Procedures?"
  1. S DIR("A")=" Select DELINQUENT, NEW, OPEN or ALL: ",DIR("B")="OPEN"
  1. S DIR(0)="SAM^d:DELINQUENT;n:NEW;o:OPEN;a:ALL" D HELP4^BWBRPCD3
  1. D ^DIR
  1. I Y=-1!($D(DIRUT)) S BWPOP=1 Q
  1. S BWB=Y
  1. Q
  1. ;
  1. RESULT ;EP
  1. ;---> GET XREF: ABNORMAL OR ALL
  1. N DIR,DIRUT,Y
  1. W !!?3,"Do you wish to browse only Procedures with ABNORMAL results, "
  1. W !?3,"or both ABNORMAL and NORMAL?"
  1. S DIR("A")=" Select ABNORMAL or BOTH: "
  1. S DIR("B")="ABNORMAL ONLY" D HELP1^BWBRPCD3
  1. S DIR(0)="SAM^a:ABNORMAL ONLY;b:BOTH ABNORMAL AND NORMAL"
  1. D ^DIR
  1. I Y=-1!($D(DIRUT)) S BWPOP=1 Q
  1. S BWD=$S(Y="a":0,1:1)
  1. Q
  1. ;
  1. CMGR ;EP
  1. ;---> SELECT CASES FOR ONE CASE MANAGER OR ALL.
  1. ;---> DO NOT PROMPT FOR CASE MANAGER IF SITE PARAMETERS SAY NOT TO,
  1. ;---> OR IF LOOKING AT PROCEDURES FOR ONLY ONE PATIENT.
  1. N DIR,DIRUT,Y
  1. I '$D(^BWSITE(DUZ(2),0)) S BWE=1 Q
  1. I '$P(^BWSITE(DUZ(2),0),U,5)!('BWA) S BWE=1 Q
  1. W !!?3,"Browse Procedures for ONE particular Case Manager,"
  1. W !?3,"or browse Procedures for ALL Case Managers?"
  1. S DIR("A")=" Select ONE or ALL: ",DIR("B")="ALL"
  1. S DIR(0)="SAM^o:ONE;a:ALL" D HELP5^BWBRPCD3
  1. D ^DIR
  1. I Y=-1!($D(DIRUT)) S BWPOP=1 Q
  1. ;---> IF ALL CASE MANAGERS, S BWE=1 AND QUIT.
  1. I Y="a" S BWE=1 Q
  1. N DIC
  1. W !!," Select the Case Manager whose patients you wish to browse."
  1. D DIC^BWFMAN(9002086.01,"QEMA",.Y," Select CASE MANAGER: ")
  1. I Y<0 S BWPOP=1 Q
  1. ;---> FOR ONE CASE MANAGER, SET BWE=0 AND BWCMGR=^VA(200 DFN, QUIT.
  1. S BWCMGR=+Y,BWE=0
  1. Q
  1. ;
  1. ORDER ;EP
  1. ;---> ASK ORDER BY DATE OR BY PATIENT OR BY PRIORITY.
  1. ;---> IF LOOKING AT ONLY ONE PATIENT, ORDER BY DATE AND QUIT.
  1. I 'BWA S BWC=1 D TITLE Q
  1. ;
  1. ;---> SORT SEQUENCE IN BWC: 1=DATE, PATIENT, PRIORITY
  1. ;---> 2=PATIENT, DATE, PRIORITY
  1. ;---> 3=PRIORITY, DATE, PATIENT
  1. ;
  1. N DIR,DIRUT,Y
  1. W !!?3,"Display Procedures in order of:"
  1. W ?37,"1) DATE OF PROCEDURE (earliest first)"
  1. W !?37,"2) NAME OF PATIENT (alphabetically)"
  1. W !?37,"3) PRIORITY (most urgent being highest)"
  1. S DIR("A")=" Select 1, 2, or 3: ",DIR("B")=1
  1. S DIR(0)="SAM^1:DATE;2:NAME;3:PRIORITY" D HELP3^BWBRPCD3
  1. D ^DIR
  1. I Y=-1!($D(DIRUT)) S BWPOP=1 Q
  1. S BWC=Y D TITLE
  1. Q
  1. ;
  1. TITLE ;EP
  1. ;---> SET TITLE OF REPORT BASED ON ORDER SELECTED ABOVE.
  1. N Y S Y=$S(BWC=1:"DATE",BWC=2:"PATIENT",BWC=3:"DIAGNOSIS",1:"?")
  1. S BWTITLE="* * * PROCEDURES LISTED BY "_Y_" * * *"
  1. S BWCODE="D EDIT^BWBRPCD1,SORT^BWBRPCD,COPYGBL^BWBRPCD"
  1. S BWHEADER="HEADER1"
  1. Q
  1. ;
  1. DEVICE ;EP
  1. ;---> GET DEVICE AND POSSIBLY QUEUE TO TASKMAN.
  1. S ZTRTN="DEQUEUE^BWBRPCD"
  1. F BWSV="A","B","C","CODE","D","E","CMGR" D
  1. .I $D(@("BW"_BWSV)) S ZTSAVE("BW"_BWSV)=""
  1. F BWSV="DFN","BEGDT","ENDDT","HEADER","TITLE" D
  1. .I $D(@("BW"_BWSV)) S ZTSAVE("BW"_BWSV)=""
  1. ;---> SAVE THE SELECTED PROCEDURES ARRAY.
  1. I $D(BWARR) N N S N=0 F S N=$O(BWARR(N)) Q:N="" D
  1. .S ZTSAVE("BWARR("""_N_""")")=""
  1. D ZIS^BWUTL2(.BWPOP,1,"HOME")
  1. Q