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

ALPBIN.m

Go to the documentation of this file.
  1. ALPBIN ;OIFO-DALLAS/SED/KC/MW BCMA-BCBU INPT TO HL7 INIT ;5/2/2002
  1. ;;3.0;BAR CODE MED ADMIN;**8**;Mar 2004
  1. ;
  1. ; Reference/IA
  1. ; DPT/10035
  1. ; DIC(42/10039
  1. ; DIC(42/2440
  1. Q
  1. OPT ;Entry point for the option
  1. ;Select all or by Division
  1. ALL ;Ask if the user want to send to all divisions
  1. K DTOUT,DUOUT,DIRUT,DIROUT,DIR,ALPALL,ALPWKS,ALPDIV,ALPBDVN
  1. S DIR(0)="Y",DIR("B")="YES"
  1. S DIR("A")="Enter Yes or No"
  1. S DIR("A",1)="Include all Divisions"
  1. D ^DIR
  1. I $D(DIRUT) G EXIT
  1. S ALPALL=+Y
  1. ;I +ALPALL>0 D QUE
  1. I ALPALL'>0 D DIV
  1. ;I +ALPALL'>0!(+ALPWKS>0) D QUE
  1. D QUE
  1. ;
  1. EXIT ;
  1. K ALPB,ALPBI,ALPBJ,ALPCN,ALDFN,ALPMDT,ALPML,ALPORDR,MSCTR,MSH,ORC
  1. K PID,PV1,ALPHLL,ALPALL,DIR,Y,DTOUT,DUOUT,DIRUT,DIROUT,ALPDIV
  1. K ALPTST,ALPSTOP,ALPOK,ZTSAVE,ALPCNI,ALPCNT,ALP,ALPDVN
  1. Q
  1. ;
  1. DIV K ALPHLL,DIR,ALPDIV,DTOUT,DUOUT,DIRUT,DIROUT
  1. S DIR(0)="PO^40.8:EMZ"
  1. S DIR("A",1)="Enter the division that you would like to"
  1. S DIR("A",2)="initialize"
  1. D ^DIR
  1. I $D(DIRUT)!(+Y'>0) S ALPDIV="" Q
  1. S ALPDIV=$P(Y,U,1),ALPDVN=$P(Y,U,2)
  1. D GET^ALPBPARM(.ALPHLL,ALPDIV)
  1. I '$D(ALPHLL) W !,"No workstations defined with "_ALPDVN G DIV
  1. ALLWKS ;If no then set allow the user to select the workstation
  1. K DTOUT,DUOUT,DIRUT,DIROUT,DIR
  1. S DIR(0)="Y",DIR("B")="YES"
  1. S DIR("A")="Enter Yes or No"
  1. S DIR("A",1)="Include all workstations for the "_ALPDVN_" Division"
  1. D ^DIR
  1. I $D(DIRUT) G DIV
  1. S ALPWKS=+Y
  1. I +ALPWKS>0 Q
  1. ;
  1. WRKSTN ;Now select which workstations for the division to be initialized
  1. K ALPSCRN,ALPBANS
  1. ;Set up screen
  1. S ALP=0 F S ALP=$O(ALPHLL("LINKS",ALP)) Q:+ALP'>0 D
  1. . S ALPSCRN($P(ALPHLL("LINKS",ALP),U,2),ALP)=ALPHLL("LINKS",ALP)
  1. K ALPHLL
  1. F D LP Q:$D(DIRUT)
  1. ;I $D(DIRUT)!$D(ALPHLL) W !!,"No Selected Workstations" G ALLWKS
  1. I '$D(ALPBANS)!$D(ALPHLL) W !!,"No Selected Workstations" G ALLWKS
  1. Q:'$D(ALPBANS)
  1. S ALP="",ALPCNT=1
  1. F S ALP=$O(ALPBANS(ALP)) Q:ALP="" D
  1. . S ALPHLL("LINKS",ALPCNT)=ALPSCRN(ALP,$O(ALPSCRN(ALP,0)))
  1. . S ALPCNT=ALPCNT+1
  1. K ALPSCRN,ALPBANS
  1. Q
  1. ;
  1. LP ;Multiple entries
  1. K DIR,DTOUT,DUOUT,DIRUT,DIROUT
  1. S DIR(0)="PO^870:EMZ",DIR("A")="Select WorkStation Link "
  1. S DIR("?")="Answer with WorkStation Link to update "
  1. S DIR("S")="I $D(ALPSCRN($P(^HLCS(870,+Y,0),U,1)))"
  1. D ^DIR
  1. Q:$D(DIRUT)
  1. S ALPBANS($P(Y,U,2),+Y)=""
  1. W #,!!,"Selected Workstations",!!
  1. S ALPB=""
  1. F ALP=1:1 S ALPB=$O(ALPBANS(ALPB)) Q:ALPB="" D
  1. .W ?$S(ALP#2:1,1:40),ALPB
  1. .W:ALP#2'>0 !
  1. Q
  1. ;
  1. QUE ;Que the job
  1. ;W !,"QUE"
  1. S ZTRTN="EN^ALPBIN"
  1. S ZTDESC="PSB - Initialize the Contingency Workstation"
  1. S ZTIO="",ZTSAVE("ALPWKS")="",ZTSAVE("ALPDIV")=""
  1. I $D(ALPHLL) S ZTSAVE("ALPHLL(")=""
  1. D ^%ZTLOAD
  1. W:$D(ZTSK) !,ZTSK
  1. K ZTIO,ZTDESC,ZTRTN,ZTSK
  1. Q
  1. EN ;Loop through the inpatient list.
  1. S ALPDTS=$$FMTE^XLFDT($$NOW^XLFDT)
  1. I +$G(ALPDIV)'>0 S ALPDIV=0
  1. S ALPSTOP=0,ALPOK=1
  1. S ALPCN=""
  1. F S ALPCN=$O(^DPT("CN",ALPCN)) Q:ALPCN=""!(ALPSTOP) D
  1. . ;DIVISION SCREEN HERE
  1. . S ALPCNI=$O(^DIC(42,"B",ALPCN,0))
  1. . Q:+ALPCNI'>0 ;Quit if I can't decifer the Ward Location
  1. . S ALPTST=$P($G(^DIC(42,ALPCNI,0)),U,11)
  1. . I +ALPDIV&(ALPDIV'=ALPTST) Q
  1. . S ALPSTOP=$$S^%ZTLOAD()
  1. . Q:ALPSTOP
  1. . S ALDFN=0
  1. . F S ALDFN=$O(^DPT("CN",ALPCN,ALDFN)) Q:+ALDFN'>0!(ALPSTOP) D PAT^ALPBIND
  1. ;
  1. K XQA,XQAMSG
  1. S ALPDTE=$$FMTE^XLFDT($$NOW^XLFDT)
  1. S XQA(DUZ)=""
  1. S XQAMSG="BCBU WORKSTATION INIT Started "_ALPDTS_" and finished "_ALPDTE_". "
  1. ;_ALPBK_" entries sent."
  1. D SETUP^XQALERT
  1. K ALPDTS,ALPDTE,ALPCNT
  1. D EXIT
  1. Q