| 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 | 
|---|