| 1 | SCRPU3 ;ALB/CMM - GENERIC UTILITIES ; 9/26/05 8:50am
 | 
|---|
| 2 |  ;;5.3;Scheduling;**41,45,52,140,181,177,432,433,346**;AUG 13, 1993
 | 
|---|
| 3 |  ;
 | 
|---|
| 4 | ELIG(DFN) ;
 | 
|---|
| 5 |  ;Gets Primary Eligibility
 | 
|---|
| 6 |  N PRIM
 | 
|---|
| 7 |  I '$D(^DPT(DFN,.36)) Q 0
 | 
|---|
| 8 |  I '$D(^DIC(8,+$P(^DPT(DFN,.36),"^"),0)) Q 0
 | 
|---|
| 9 |  S PRIM=$P($G(^DIC(8,$P($G(^DPT(DFN,.36)),"^"),0)),"^",9)
 | 
|---|
| 10 |  ;MAS Primary Eligibility Code
 | 
|---|
| 11 |  S PRIM=$P($G(^DIC(8.1,PRIM,0)),"^")
 | 
|---|
| 12 |  ;
 | 
|---|
| 13 |  S PRIM=$TR(PRIM,"abcdefghijklmnopqrstuvwxyz","ABCDEFGHIJKLMNOPQRSTUVWXYZ")
 | 
|---|
| 14 |  I PRIM="NON-SERVICE CONNECTED" S PRIM="NSC"
 | 
|---|
| 15 |  I PRIM["SERVICE CONNECTED" S PRIM=$P(PRIM,"SERVICE CONNECTED")_"SC"_$P(PRIM,"SERVICE CONNECTED",2,999)
 | 
|---|
| 16 |  I PRIM["LESS THAN" S PRIM=$P(PRIM,"LESS THAN")_"<"_$P(PRIM,"LESS THAN",2,999)
 | 
|---|
| 17 |  I PRIM[" TO " S PRIM=$P(PRIM," TO ")_"-"_$P(PRIM," TO ",2,999)
 | 
|---|
| 18 |  I PRIM["%" S PRIM=$TR(PRIM,"%","")
 | 
|---|
| 19 |  S PRIM=$E(PRIM,1,9)
 | 
|---|
| 20 |  Q PRIM
 | 
|---|
| 21 |  ;
 | 
|---|
| 22 | GETNEXT(DFN,CLN) ;
 | 
|---|
| 23 |  ;Get next appointment for patient (DFN) at Clinic (CLN)
 | 
|---|
| 24 |  ;Returning the date in 00/00/0000 format
 | 
|---|
| 25 |  N NEXT,APPT,FOUND
 | 
|---|
| 26 |  ;
 | 
|---|
| 27 |  N SDARRAY,SDCOUNT,SDDATE,SDAPPT,SDSTATUS,%
 | 
|---|
| 28 |  ; Tell SDAPI that we want only the next appointment based on:
 | 
|---|
| 29 |  ; Date          SDARRAY(1)=Today's Date;
 | 
|---|
| 30 |  ; Clinic        SDARRAY(2)=CLN
 | 
|---|
| 31 |  ; Patient       SDARRAY(4)=DFN
 | 
|---|
| 32 |  ; Status        SDARRAY(3)="R;I;NS;NSR;NT" 
 | 
|---|
| 33 |  ;  KEPT/INPATIENT/NOSHOW/NOSHOWRESCHED/NOACTIONTAKEN
 | 
|---|
| 34 |  ; and that we want to have field 3 (appt status) returned       
 | 
|---|
| 35 |  ; SDARRAY("FLDS")="3"
 | 
|---|
| 36 |  ; DATA will be returned in ^TMP($J,"SDAMA301",DFN,CLN,SDDATE)
 | 
|---|
| 37 |  ;
 | 
|---|
| 38 |  S FOUND=0,NEXT=""
 | 
|---|
| 39 |  I $G(CLN)=""!($G(DFN)="") Q NEXT
 | 
|---|
| 40 |  D NOW^%DTC S SDARRAY(1)=$P(%,".",1)_";"
 | 
|---|
| 41 |  S SDARRAY(2)=CLN,SDARRAY(3)="R;I;NS;NSR;NT",SDARRAY(4)=DFN,SDARRAY("FLDS")="3",SDARRAY("MAX")=1
 | 
|---|
| 42 |  S SDCOUNT=$$SDAPI^SDAMA301(.SDARRAY)
 | 
|---|
| 43 |  I SDCOUNT>0 S SDDATE="" S SDDATE=$O(^TMP($J,"SDAMA301",DFN,CLN,SDDATE)) D
 | 
|---|
| 44 |  .S NEXT=$TR($$FMTE^XLFDT(SDDATE,"5DF")," ","0")
 | 
|---|
| 45 |  I SDCOUNT<0 D  ;do processing for errors
 | 
|---|
| 46 |  .; None to do in this case -- return null
 | 
|---|
| 47 |  .Q
 | 
|---|
| 48 |  ; when finished with all processing, kill SDAPI output array
 | 
|---|
| 49 |  K ^TMP($J,"SDAMA301")
 | 
|---|
| 50 |  Q NEXT
 | 
|---|
| 51 |  ;
 | 
|---|
| 52 | GETLAST(DFN,CLN) ;
 | 
|---|
| 53 |  ;Get last appointment for patient (DFN) at Clinic (CLN)
 | 
|---|
| 54 |  ;Returning the date in 00/00/0000 format
 | 
|---|
| 55 |  N LAST,APPT,FOUND,STATUS
 | 
|---|
| 56 |  N SDARRAY,SDCOUNT,SDDATE,SDAPPT,SDSTATUS,%
 | 
|---|
| 57 |  ; Tell SDAPI that we want only the next appointment based on:
 | 
|---|
| 58 |  ; Date          SDARRAY(1)=;Today's Date
 | 
|---|
| 59 |  ; Clinic        SDARRAY(2)=CLN
 | 
|---|
| 60 |  ; Patient       SDARRAY(4)=DFN
 | 
|---|
| 61 |  ; Status        SDARRAY(3)="R;I;NT"
 | 
|---|
| 62 |  ; MAX           SDARRAY("MAX")=-1
 | 
|---|
| 63 |  ; and that we want to have field 3 (appt status) returned       
 | 
|---|
| 64 |  ; SDARRAY("FLDS")="3"
 | 
|---|
| 65 |  ; DATA will be returned in ^TMP($J,"SDAMA301",DFN,CLN,SDDATE)
 | 
|---|
| 66 |  ;
 | 
|---|
| 67 |  S FOUND=0,LAST=""
 | 
|---|
| 68 |  I $G(CLN)=""!($G(DFN)="") Q LAST
 | 
|---|
| 69 |  D NOW^%DTC S SDARRAY(1)=";"_$P(%,".",1)
 | 
|---|
| 70 |  S SDARRAY(2)=CLN,SDARRAY(3)="R;I;NT",SDARRAY(4)=DFN,SDARRAY("MAX")=-1
 | 
|---|
| 71 |  S SDARRAY("FLDS")="3"
 | 
|---|
| 72 |  S SDCOUNT=$$SDAPI^SDAMA301(.SDARRAY)
 | 
|---|
| 73 |  I SDCOUNT>0 S SDDATE="" D
 | 
|---|
| 74 |  .S SDDATE=$O(^TMP($J,"SDAMA301",DFN,CLN,SDDATE))
 | 
|---|
| 75 |  .S LAST=$TR($$FMTE^XLFDT(SDDATE,"5DF")," ","0")
 | 
|---|
| 76 |  I SDCOUNT<0 D  ;do processing for errors
 | 
|---|
| 77 |  .Q  ; None to do in this case
 | 
|---|
| 78 |  ; when finished with all processing, kill SDAPI output array
 | 
|---|
| 79 |  K ^TMP($J,"SDAMA301")
 | 
|---|
| 80 |  Q LAST
 | 
|---|
| 81 |  ;
 | 
|---|
| 82 | PDEVICE() ;
 | 
|---|
| 83 |  ;Generic Printer Call
 | 
|---|
| 84 |  N TION,POP
 | 
|---|
| 85 |  S %ZIS="QN" D ^%ZIS K %ZIS Q:POP!(ION="^") -1
 | 
|---|
| 86 |  S TION=ION
 | 
|---|
| 87 |  I $D(IO("Q")) S TION="Q;"_TION
 | 
|---|
| 88 |  Q TION_"^"_IOST
 | 
|---|
| 89 |  ;
 | 
|---|
| 90 | GETTIME() ;
 | 
|---|
| 91 |  ;Prompt for Queue Time
 | 
|---|
| 92 |  N X,Y
 | 
|---|
| 93 |  S DIR(0)="D^::RFE",DIR("A")="Start Time",DIR("B")="NOW"
 | 
|---|
| 94 |  D ^DIR
 | 
|---|
| 95 |  I $D(DTOUT)!(X="") S Y=$H
 | 
|---|
| 96 |  I $D(DUOUT)!($D(DIROUT)) S Y=-1
 | 
|---|
| 97 |  K DIR,DTOUT,DUOUT,DIROUT
 | 
|---|
| 98 |  Q Y
 | 
|---|
| 99 |  ;
 | 
|---|
| 100 | HOLD(PAGE,TIT,MARG) ;
 | 
|---|
| 101 |  ;device is home, reached end of page
 | 
|---|
| 102 |  N X
 | 
|---|
| 103 |  S MARG=$G(MARG) S:MARG'>80 MARG=80
 | 
|---|
| 104 |  W !!,"Press Any Key to Continue or '^' to Quit" R X:DTIME
 | 
|---|
| 105 |  I '$T!(X="^") S STOP=1 Q
 | 
|---|
| 106 |  D NEWP1(.PAGE,TIT,MARG)
 | 
|---|
| 107 |  Q
 | 
|---|
| 108 |  ;
 | 
|---|
| 109 | NEWP1(PAGE,TITL,MARG) ;
 | 
|---|
| 110 |  ;new page
 | 
|---|
| 111 |  ;
 | 
|---|
| 112 |  S MARG=$G(MARG) S:MARG'>80 MARG=80
 | 
|---|
| 113 |  D STOPCHK^DGUTL
 | 
|---|
| 114 |  I $G(STOP) D STOPPED^DGUTL Q
 | 
|---|
| 115 |  W:PAGE>0 @IOF
 | 
|---|
| 116 |  S PAGE=PAGE+1
 | 
|---|
| 117 |  D TITLE(PAGE,TITL,MARG)
 | 
|---|
| 118 |  Q
 | 
|---|
| 119 |  ;
 | 
|---|
| 120 | TITLE(PG,TITL,MARG) ;
 | 
|---|
| 121 |  N PDATE,SCX,SCI
 | 
|---|
| 122 |  S MARG=$G(MARG) S:MARG'>80 MARG=80
 | 
|---|
| 123 |  S PDATE=$$FMTE^XLFDT(DT,"5D")
 | 
|---|
| 124 |  S SCI=(IOM-$L(TITL)\2) S:SCI<24 SCI=24
 | 
|---|
| 125 |  S SCX="Printed on: "_PDATE
 | 
|---|
| 126 |  S $E(SCX,SCI)=TITL
 | 
|---|
| 127 |  S $E(SCX,(IOM-6-$L(PG)))="Page: "_PG
 | 
|---|
| 128 |  W SCX,!
 | 
|---|
| 129 |  Q
 | 
|---|
| 130 |  ;
 | 
|---|
| 131 | CLOSE ;close device
 | 
|---|
| 132 |  D:$E(IOST)'="C" ^%ZISC
 | 
|---|
| 133 |  Q
 | 
|---|
| 134 |  ;
 | 
|---|
| 135 | OPEN ;opens device
 | 
|---|
| 136 |  IF IOST?1"C-".E D  Q  ;%zis has already been called via $$pdevice
 | 
|---|
| 137 |  .W @IOF
 | 
|---|
| 138 |  D ^%ZIS
 | 
|---|
| 139 |  Q:POP
 | 
|---|
| 140 |  U IO
 | 
|---|
| 141 |  Q
 | 
|---|
| 142 |  ;
 | 
|---|
| 143 | NODATA(TITL) ;
 | 
|---|
| 144 |  ;no data to print
 | 
|---|
| 145 |  ;returns 1
 | 
|---|
| 146 |  D OPEN
 | 
|---|
| 147 |  D TITLE(1,TITL)
 | 
|---|
| 148 |  W !,"No data to report"
 | 
|---|
| 149 |  D CLOSE
 | 
|---|
| 150 |  Q 1
 | 
|---|
| 151 |  ;
 | 
|---|
| 152 | HELP W:'$D(VAUTNA) !,"ENTER:",!?5,"- A or ALL for all ",VAUTSTR,"s, or"
 | 
|---|
| 153 |  W:($D(VAUTTN))&(VAUTSTR="TEAM") !?5,"- N or NOT for not assigned to a team or"
 | 
|---|
| 154 |  W:($D(VAUTPO))&(VAUTSTR="PRACTITIONER") !?5,"- N or NONE or NOT for not assigned to a Practitioner"
 | 
|---|
| 155 |  W !?5,"- Select individual "_VAUTSTR W:'$D(VAUTPO) " -- limit 20"
 | 
|---|
| 156 |  W !?5,"Imprecise selections will yield an additional prompt."
 | 
|---|
| 157 |  I $O(@VAUTVB@(0))]"" W !?5,"- An entry preceeded by a minus [-] sign to remove entry from list."
 | 
|---|
| 158 |  I $O(@VAUTVB@(0))]"" W !,"NOTE, you have already selected:" S VAJ=0 F VAJ1=0:0 S VAJ=$O(@VAUTVB@(VAJ)) Q:VAJ=""  W !?8,$S(VAUTNI=1:VAJ,1:@VAUTVB@(VAJ))
 | 
|---|
| 159 |  Q
 | 
|---|
| 160 |  ;
 | 
|---|
| 161 | CONV(ORIGA,NEWA) ;
 | 
|---|
| 162 |  ;ORIGA - original array - name(ien)=data
 | 
|---|
| 163 |  ;NEWA - new array - name(n)=ien^data
 | 
|---|
| 164 |  ;
 | 
|---|
| 165 |  N ENT,CNT
 | 
|---|
| 166 |  S ENT=0,CNT=0
 | 
|---|
| 167 |  S NEWA=ORIGA
 | 
|---|
| 168 |  F  S ENT=$O(ORIGA(ENT)) Q:ENT=""!(ENT'?.N)  D
 | 
|---|
| 169 |  .S CNT=CNT+1
 | 
|---|
| 170 |  .S NEWA(CNT)=ENT_"^"_ORIGA(ENT)
 | 
|---|
| 171 |  Q
 | 
|---|