| 1 | ALPBIN ;OIFO-DALLAS/SED/KC/MW  BCMA-BCBU INPT TO HL7 INIT ;5/2/2002
 | 
|---|
| 2 |  ;;3.0;BAR CODE MED ADMIN;**8**;Mar 2004
 | 
|---|
| 3 |  ;
 | 
|---|
| 4 |  ; Reference/IA
 | 
|---|
| 5 |  ; DPT/10035
 | 
|---|
| 6 |  ; DIC(42/10039
 | 
|---|
| 7 |  ; DIC(42/2440
 | 
|---|
| 8 |  Q
 | 
|---|
| 9 | OPT ;Entry point for the option
 | 
|---|
| 10 |  ;Select all or by Division
 | 
|---|
| 11 | ALL ;Ask if the user want to send to all divisions
 | 
|---|
| 12 |  K DTOUT,DUOUT,DIRUT,DIROUT,DIR,ALPALL,ALPWKS,ALPDIV,ALPBDVN
 | 
|---|
| 13 |  S DIR(0)="Y",DIR("B")="YES"
 | 
|---|
| 14 |  S DIR("A")="Enter Yes or No"
 | 
|---|
| 15 |  S DIR("A",1)="Include all Divisions"
 | 
|---|
| 16 |  D ^DIR
 | 
|---|
| 17 |  I $D(DIRUT) G EXIT
 | 
|---|
| 18 |  S ALPALL=+Y
 | 
|---|
| 19 |  ;I +ALPALL>0 D QUE
 | 
|---|
| 20 |  I ALPALL'>0 D DIV
 | 
|---|
| 21 |  ;I +ALPALL'>0!(+ALPWKS>0) D QUE
 | 
|---|
| 22 |  D QUE
 | 
|---|
| 23 |  ;
 | 
|---|
| 24 | EXIT ;
 | 
|---|
| 25 |  K ALPB,ALPBI,ALPBJ,ALPCN,ALDFN,ALPMDT,ALPML,ALPORDR,MSCTR,MSH,ORC
 | 
|---|
| 26 |  K PID,PV1,ALPHLL,ALPALL,DIR,Y,DTOUT,DUOUT,DIRUT,DIROUT,ALPDIV
 | 
|---|
| 27 |  K ALPTST,ALPSTOP,ALPOK,ZTSAVE,ALPCNI,ALPCNT,ALP,ALPDVN
 | 
|---|
| 28 |  Q
 | 
|---|
| 29 |  ;
 | 
|---|
| 30 | DIV K ALPHLL,DIR,ALPDIV,DTOUT,DUOUT,DIRUT,DIROUT
 | 
|---|
| 31 |  S DIR(0)="PO^40.8:EMZ"
 | 
|---|
| 32 |  S DIR("A",1)="Enter the division that you would like to"
 | 
|---|
| 33 |  S DIR("A",2)="initialize"
 | 
|---|
| 34 |  D ^DIR
 | 
|---|
| 35 |  I $D(DIRUT)!(+Y'>0) S ALPDIV="" Q
 | 
|---|
| 36 |  S ALPDIV=$P(Y,U,1),ALPDVN=$P(Y,U,2)
 | 
|---|
| 37 |  D GET^ALPBPARM(.ALPHLL,ALPDIV)
 | 
|---|
| 38 |  I '$D(ALPHLL) W !,"No workstations defined with "_ALPDVN G DIV
 | 
|---|
| 39 | ALLWKS ;If no then set allow the user to select the workstation
 | 
|---|
| 40 |  K DTOUT,DUOUT,DIRUT,DIROUT,DIR
 | 
|---|
| 41 |  S DIR(0)="Y",DIR("B")="YES"
 | 
|---|
| 42 |  S DIR("A")="Enter Yes or No"
 | 
|---|
| 43 |  S DIR("A",1)="Include all workstations for the "_ALPDVN_" Division"
 | 
|---|
| 44 |  D ^DIR
 | 
|---|
| 45 |  I $D(DIRUT) G DIV
 | 
|---|
| 46 |  S ALPWKS=+Y
 | 
|---|
| 47 |  I +ALPWKS>0 Q
 | 
|---|
| 48 |  ;
 | 
|---|
| 49 | WRKSTN ;Now select which workstations for the division to be initialized
 | 
|---|
| 50 |  K ALPSCRN,ALPBANS
 | 
|---|
| 51 |  ;Set up screen
 | 
|---|
| 52 |  S ALP=0 F  S ALP=$O(ALPHLL("LINKS",ALP))  Q:+ALP'>0  D
 | 
|---|
| 53 |  . S ALPSCRN($P(ALPHLL("LINKS",ALP),U,2),ALP)=ALPHLL("LINKS",ALP)
 | 
|---|
| 54 |  K ALPHLL
 | 
|---|
| 55 |  F  D LP Q:$D(DIRUT)
 | 
|---|
| 56 |  ;I  $D(DIRUT)!$D(ALPHLL) W !!,"No Selected Workstations" G ALLWKS
 | 
|---|
| 57 |  I '$D(ALPBANS)!$D(ALPHLL) W !!,"No Selected Workstations" G ALLWKS
 | 
|---|
| 58 |  Q:'$D(ALPBANS)
 | 
|---|
| 59 |  S ALP="",ALPCNT=1
 | 
|---|
| 60 |  F  S ALP=$O(ALPBANS(ALP)) Q:ALP=""  D
 | 
|---|
| 61 |  . S ALPHLL("LINKS",ALPCNT)=ALPSCRN(ALP,$O(ALPSCRN(ALP,0)))
 | 
|---|
| 62 |  . S ALPCNT=ALPCNT+1
 | 
|---|
| 63 |  K ALPSCRN,ALPBANS
 | 
|---|
| 64 |  Q
 | 
|---|
| 65 |  ;
 | 
|---|
| 66 | LP ;Multiple entries
 | 
|---|
| 67 |  K DIR,DTOUT,DUOUT,DIRUT,DIROUT
 | 
|---|
| 68 |  S DIR(0)="PO^870:EMZ",DIR("A")="Select WorkStation Link "
 | 
|---|
| 69 |  S DIR("?")="Answer with WorkStation Link to update "
 | 
|---|
| 70 |  S DIR("S")="I $D(ALPSCRN($P(^HLCS(870,+Y,0),U,1)))"
 | 
|---|
| 71 |  D ^DIR
 | 
|---|
| 72 |  Q:$D(DIRUT)
 | 
|---|
| 73 |  S ALPBANS($P(Y,U,2),+Y)=""
 | 
|---|
| 74 |  W #,!!,"Selected Workstations",!!
 | 
|---|
| 75 |  S ALPB=""
 | 
|---|
| 76 |  F ALP=1:1 S ALPB=$O(ALPBANS(ALPB)) Q:ALPB=""  D
 | 
|---|
| 77 |  .W ?$S(ALP#2:1,1:40),ALPB
 | 
|---|
| 78 |  .W:ALP#2'>0 !
 | 
|---|
| 79 |  Q
 | 
|---|
| 80 |  ;
 | 
|---|
| 81 | QUE ;Que the job
 | 
|---|
| 82 |  ;W !,"QUE"
 | 
|---|
| 83 |  S ZTRTN="EN^ALPBIN"
 | 
|---|
| 84 |  S ZTDESC="PSB - Initialize the Contingency Workstation"
 | 
|---|
| 85 |  S ZTIO="",ZTSAVE("ALPWKS")="",ZTSAVE("ALPDIV")=""
 | 
|---|
| 86 |  I $D(ALPHLL) S ZTSAVE("ALPHLL(")=""
 | 
|---|
| 87 |  D ^%ZTLOAD
 | 
|---|
| 88 |  W:$D(ZTSK) !,ZTSK
 | 
|---|
| 89 |  K ZTIO,ZTDESC,ZTRTN,ZTSK
 | 
|---|
| 90 |  Q
 | 
|---|
| 91 | EN ;Loop through the inpatient list.
 | 
|---|
| 92 |  S ALPDTS=$$FMTE^XLFDT($$NOW^XLFDT)
 | 
|---|
| 93 |  I +$G(ALPDIV)'>0 S ALPDIV=0
 | 
|---|
| 94 |  S ALPSTOP=0,ALPOK=1
 | 
|---|
| 95 |  S ALPCN=""
 | 
|---|
| 96 |  F  S ALPCN=$O(^DPT("CN",ALPCN)) Q:ALPCN=""!(ALPSTOP)  D
 | 
|---|
| 97 |  . ;DIVISION SCREEN HERE
 | 
|---|
| 98 |  . S ALPCNI=$O(^DIC(42,"B",ALPCN,0))
 | 
|---|
| 99 |  . Q:+ALPCNI'>0  ;Quit if I can't decifer the Ward Location
 | 
|---|
| 100 |  . S ALPTST=$P($G(^DIC(42,ALPCNI,0)),U,11)
 | 
|---|
| 101 |  . I +ALPDIV&(ALPDIV'=ALPTST) Q
 | 
|---|
| 102 |  . S ALPSTOP=$$S^%ZTLOAD()
 | 
|---|
| 103 |  . Q:ALPSTOP
 | 
|---|
| 104 |  . S ALDFN=0
 | 
|---|
| 105 |  . F  S ALDFN=$O(^DPT("CN",ALPCN,ALDFN)) Q:+ALDFN'>0!(ALPSTOP)  D PAT^ALPBIND
 | 
|---|
| 106 |  ;
 | 
|---|
| 107 |  K XQA,XQAMSG
 | 
|---|
| 108 |  S ALPDTE=$$FMTE^XLFDT($$NOW^XLFDT)
 | 
|---|
| 109 |  S XQA(DUZ)=""
 | 
|---|
| 110 |  S XQAMSG="BCBU WORKSTATION INIT Started "_ALPDTS_" and finished "_ALPDTE_". "
 | 
|---|
| 111 |  ;_ALPBK_" entries sent."
 | 
|---|
| 112 |  D SETUP^XQALERT
 | 
|---|
| 113 |  K ALPDTS,ALPDTE,ALPCNT
 | 
|---|
| 114 |  D EXIT
 | 
|---|
| 115 |  Q
 | 
|---|