Changeset 623 for WorldVistAEHR/trunk/r/SCHEDULING-SD-SC/SDAL.m
- Timestamp:
- Dec 4, 2009, 12:11:15 AM (16 years ago)
- File:
-
- 1 edited
-
WorldVistAEHR/trunk/r/SCHEDULING-SD-SC/SDAL.m (modified) (1 diff)
Legend:
- Unmodified
- Added
- Removed
-
WorldVistAEHR/trunk/r/SCHEDULING-SD-SC/SDAL.m
r613 r623 1 SDAL ;ALB/GRR,MJK - APPOINTMENT LIST ; 29 Jun 99 04:11PM ; Compiled August 20, 2007 14:24:592 ;;5.3;Scheduling;**37,46,106,171,177,80,266,491**;Aug 13, 1993;Build 533 EN W ! S SDEND=1 D ASK2^SDDIV G:Y<0 END4 W ! S VAUTNI=1 D NCOUNT^SDAL0 I SDCONC=U G END5 W ! D NCLINIC^SDAL0 G:Y<0 END6 RD1 W ! N %DT K DIC("S") S %DT("A")="For date: ",%DT="AEX" D ^%DT7 I (X["^")!(Y<0) K %,VAUTD,VAUTC,X,Y Q8 S SDD=Y9 N DIR S DIR(0)="Y",DIR("B")="NO"10 S DIR("A")="Include Primary Care assignment information in the output"11 W ! D ^DIR I $D(DTOUT)!$D(DUOUT) K SDD,VAUTC,VAUTD,X,Y Q12 W ! S SDPCMM=Y13 N K SDX,SDX1 R !,"Number of copies: 1// ",M:DTIME S:M="" M=114 I M["^" K M,SDD,VAUTC,VAUTD,X,Y Q15 I (M'?.N)!((M'>0)!($L(M)>3)) W !,"ENTER A WHOLE NUMBER TO SELECT THE # OF COPIES OF THE APPOINTMENT LIST THAT ARE NEEDED- (1-999)" G N16 S SDCOPY=M17 ; -- specify device18 W ! N %ZIS K IO("Q") S %ZIS="QMP" D ^%ZIS G END:POP19 S SDBC=$$BARQ(+IOST(0),IOM) I SDBC="^" G END20 I $D(IO("Q")) D QUE W:$D(ZTSK) " (Task#: ",ZTSK,")" G END21 ;22 START U IO N CNT,SDCLAR,SDCOUNT S (SDCOUNT,CNT)=023 ;SET UP A TEMP ARRAY -SDCLAR- WITH CLASSIFICATION ABBREVIATIONS24 F S CNT=$O(^SD(409.41,CNT)) Q:CNT'>0 D25 .S SDCLAR(CNT)=$P(^SD(409.41,CNT,0),U,7)26 S:'$D(DTIME) DTIME=300 I '$D(DT) D DT^SDUTL27 S SDASH="",$P(SDASH,"_",IOM+1)="" S SDBC=+$G(SDBC),SDCOPY=$S($D(SDCOPY):+SDCOPY,$D(M):+M,1:1)28 D NOW^%DTC S Y=% X ^DD("DD") S SDPNOW=$P(Y,":",1,2)29 I SDBC S SDBC=$S(IOM<120:0,1:$$BARC^SDAMU(+IOST(0),.SDBCON,.SDBCOFF))30 S (SDEND,SD1,PCNT)=0,Y=DT D D^DIQ S SDNT=Y,Y=SDD,X=Y D D^DIQ S SDPD=Y D DW^%DTC S SDPD=X_" "_SDPD31 ;if user has selected 'all' clinics, populate VAUTC with all uncancelled TYPE=C clinics from ^SC32 I VAUTC=1 S SDIEN=0 F S SDIEN=$O(^SC(SDIEN)) Q:+SDIEN=0 D33 . I $P(^SC(SDIEN,0),"^",3)="C",$G(^SC(SDIEN,"ST",SDD,1))'["CANCELLED" D34 .. S SDNAME=$P(^SC(SDIEN,0),"^",1) I $G(SDNAME)]"" S VAUTC(SDNAME)=SDIEN35 ;-------------CALL TO SDAPI^SDAMA301 TO RETRIEVE APPT DATA------------------36 K ^TMP($J,"SDAMA301") N SDARRAY,SDIEN,SDNAME,SDERR,SDCL,SDDFN,SDDT,SDRESULT37 S SDARRAY(1)=SDD_";"_SDD,SDARRAY(3)="I;R;NT",SDARRAY("FLDS")="4;6;7;8;10;19;20;21"38 ;if user has selected clinics, build clinic filter list39 I VAUTC'=1 D I $L(SDARRAY(2)) S SDARRAY(2)=$E(SDARRAY(2),1,$L(SDARRAY(2))-1) ;remove last ';' from end40 . S SD="" F S SD=$O(VAUTC(SD)) Q:SD']"" S SC=$G(VAUTC(SD)) I $G(SC)]"" S SDARRAY(2)=$G(SDARRAY(2))_SC_";"41 ;call SDAPI to retrieve appointment data42 S SDRESULT=$$SDAPI^SDAMA301(.SDARRAY)43 ;I SDRESULT<0 S SDERR=$$SDAPIERR^SDAMUTDT() I $L(SDERR) S SC=0 D HED W !!,SDERR,! I $E(IOST,1,2)="C-" D OUT^SDUTL44 ;if error returned from SDAPI, display on report and quit45 I SDRESULT<0 S SDERR=$$SDAPIERR^SDAMUTDT() I $L(SDERR) S SC=0 S SDPAGE=1 D HED W !!,SDERR,! D:$E(IOST,1,2)="C-" OUT^SDUTL D EXIT Q46 ;if appts returned from SDAPI, sort output by clinic, appt d/t, patient47 I SDRESULT>0 D48 . S SDCL=0 F S SDCL=$O(^TMP($J,"SDAMA301",SDCL)) Q:'SDCL D49 .. S SDDFN=0 F S SDDFN=$O(^TMP($J,"SDAMA301",SDCL,SDDFN)) Q:'SDDFN D50 ... S SDDT=0 F S SDDT=$O(^TMP($J,"SDAMA301",SDCL,SDDFN,SDDT)) Q:'SDDT D51 .... M ^TMP($J,"SDAMA301","S",SDCL,SDDT,SDDFN)=^TMP($J,"SDAMA301",SDCL,SDDFN,SDDT)52 ;---------------------------------------------------------------------------53 LOOPA ;S SD=0 F S SD=$S(VAUTC:$O(^SC("B",SD)),1:$O(VAUTC(SD))) Q:SD']""!SDEND D CLIN54 ;if no error returned from SDAPI, start looping through clinics in VAUTC (sorted by name)55 I SDRESULT'<0 S SD=0 F S SD=$O(VAUTC(SD)) Q:SD']""!SDEND D CLIN56 G:SDEND END57 OVER ;S PCNT=PCNT+1 I PCNT<SDCOPY,SDCOUNT S VAUTC=0 G LOOPA58 S PCNT=PCNT+1 I PCNT<SDCOPY,SDCOUNT G LOOPA59 END I $G(SDCOUNT)="" G EXIT60 ;I SDCOUNT=0 S SDPCT="No activity found for this date!" D HED W !!?$L(SDPCT)\2,SDPCT,!61 I SDCOUNT=0 S SDPCT="No activity found for this date!" S SDPAGE=1,SC=0 D HED W !!?$L(SDPCT)\2,SDPCT,!62 I $E(IOST,1,2)="C-" D:'$G(SDEND)&$G(SDCOUNT) OUT^SDUTL W @IOF63 EXIT K %,%H,%H,A,ALL,DFN,DIC,I,INC,K,M,PCNT,POP,PT,SC,SD,SD1,SDCC,SDCONC,SDCP,SDD,SDEM1,SDDIF,SDDIF1,SDEA,SDEC,SDEDT,SDEM,SDEND,SDFL,SDFS,SDIN,SDNT64 K DIRUT,SDCOPY,SDPAGE,SDPCT,SDPNOW,SDPT0,SDOI,SDPD,SDREV,SDT,SDX,SDXX,SDZ,VADAT,VADATE,VAUTC,VAUTNI,VAUTSTR,VAUTVB,VAUTD,VAQK,X,Y,Y1,Y2,Z65 K SDBC,SDBCON,SDBCOFF,SDASH,SDPCMM,^TMP($J,"SDAMA301")66 D CLOSE^DGUTQ Q67 ;68 CLIN ;S (SDFL,SC)=0 F S SC=$O(^SC("B",SD,SC)) Q:SC'>0!SDEND I $D(^SC(SC,0)),$P(^(0),"^",3)="C" I $S(VAUTC:1,'$D(VAUTC(SD)):0,VAUTC(SD)=SC:1,1:0) D LOOP^SDAL069 ;process each clinic IEN from VAUTC array70 S (SDFL,SC)=0 S SC=$G(VAUTC(SD)) I $G(SC)>0,$D(^SC(SC,0)) D LOOP^SDAL071 Q72 ;73 BARQ(TTYPE,MARGIN) ;74 N ON,OFF,Y75 I MARGIN<120 S Y=0 G BARCQ76 I '$$BARC^SDAMU(.TTYPE,.ON,.OFF) S Y=0 G BARCQ77 S DIR(0)="Y",DIR("B")="NO",DIR("A")="SHOULD BARCODES BE PRINTED ON LIST(S)"78 D ^DIR K DIR S:$D(DIRUT) Y="^"79 BARCQ Q Y80 ;81 QUE ;Queue output82 N ZTDESC,ZTSAVE,ZTRTN83 K ZTSK,IO("Q")84 S ZTDESC="Appointment Lists",ZTRTN="START^SDAL"85 F X="VAUTD(","VAUTC(","SDCOPY","SDD","SDBC","VAUTD","VAUTC","SDCONC","SDPCMM" S ZTSAVE(X)=""86 D ^%ZTLOAD87 Q88 ;89 STOP ;Check for stop task request90 S:$D(ZTQUEUED) (SDEND,ZTSTOP)=$S($$S^%ZTLOAD:1,1:0) Q91 ;92 HED ;Print report header93 I SD1,$E(IOST)="C" D OUT^SDUTL Q:SDEND94 D STOP Q:SDEND95 S SDCOUNT=SDCOUNT+1,SD1=196 W:SDCOUNT>1!($E(IOST)="C") $$XY^SCRPW50(IOF,1,0) W:$X $$XY^SCRPW50("",0,0)97 W:SC "Appointments for ",$P(^SC(SC,0),"^",1)," clinic on ",SDPD98 W:'SC "Appointments for ",SDPD99 W !,"Date printed: ",SDPNOW,?(IOM-6-$L(SDPAGE)),"Page: ",SDPAGE,!100 W !," Appt.",?11,"Patient Name",?44,"SSN",?53,"Lab",?62,"X-Ray",?73,"EKG"101 ;W !," Time",?53,"Time",?62,"Time",?73,"Time",!,?15,"Other Information",?40,"Ward Location",!,?41,"Room-Bed"102 W !," Time",?53,"Time",?62,"Time",?73,"Time",!,?15,"Other Information",?40,"Ward Location",!,?41,"Room-Bed"103 W !,SDASH S SDPAGE=SDPAGE+1104 D:SDBC PAINT(SC,SDD)105 Q106 ;107 PAINT(CLINIC,DATE) ; -- paint header barcodes108 ; input: CLINIC := clinic ifn109 ; DATE := appt date only110 ;111 W !?10,"Date",?45,"Clinic#",?85,"No",?110,"Yes",!112 D BARC(10,$E(DATE,4,7)_$E(DATE,2,3))113 D BARC(45,"%"_CLINIC_"$")114 D BARC(85,"N"),BARC(110,"Y")115 W !!!!,SDASH116 Q117 ;118 BARC(TAB,X) ; --print barcode119 ; input: TAB := tab position120 ; X := string to print121 ;122 W *13,?TAB W @SDBCON,X,@SDBCOFF123 Q124 ;1 SDAL ;ALB/GRR,MJK - APPOINTMENT LIST ; 29 Jun 99 04:11PM 2 ;;5.3;Scheduling;**37,46,106,171,177,80,266**;Aug 13, 1993 3 EN W ! S SDEND=1 D ASK2^SDDIV G:Y<0 END 4 W ! S VAUTNI=1 D NCOUNT^SDAL0 I SDCONC=U G END 5 W ! D NCLINIC^SDAL0 G:Y<0 END 6 RD1 W ! N %DT K DIC("S") S %DT("A")="For date: ",%DT="AEXF" D ^%DT 7 I (X["^")!(Y<0) K %,VAUTD,VAUTC,X,Y Q 8 S SDD=Y 9 N DIR S DIR(0)="Y",DIR("B")="NO" 10 S DIR("A")="Include Primary Care assignment information in the output" 11 W ! D ^DIR I $D(DTOUT)!$D(DUOUT) K SDD,VAUTC,VAUTD,X,Y Q 12 W ! S SDPCMM=Y 13 N K SDX,SDX1 R !,"Number of copies: 1// ",M:DTIME S:M="" M=1 14 I M["^" K M,SDD,VAUTC,VAUTD,X,Y Q 15 I (M'?.N)!((M'>0)!($L(M)>3)) W !,"ENTER A WHOLE NUMBER TO SELECT THE # OF COPIES OF THE APPOINTMENT LIST THAT ARE NEEDED- (1-999)" G N 16 S SDCOPY=M 17 ; -- specify device 18 W ! N %ZIS K IO("Q") S %ZIS="QMP" D ^%ZIS G END:POP 19 S SDBC=$$BARQ(+IOST(0),IOM) I SDBC="^" G END 20 I $D(IO("Q")) D QUE W:$D(ZTSK) " (Task#: ",ZTSK,")" G END 21 ; 22 START U IO N CNT,SDCLAR,SDCOUNT S (SDCOUNT,CNT)=0 23 ;SET UP A TEMP ARRAY -SDCLAR- WITH CLASSIFICATION ABBREVIATIONS 24 F S CNT=$O(^SD(409.41,CNT)) Q:CNT'>0 D 25 .S SDCLAR(CNT)=$P(^SD(409.41,CNT,0),U,7) 26 S:'$D(DTIME) DTIME=300 I '$D(DT) D DT^SDUTL 27 S SDASH="",$P(SDASH,"_",IOM+1)="" S SDBC=+$G(SDBC),SDCOPY=$S($D(SDCOPY):+SDCOPY,$D(M):+M,1:1) 28 D NOW^%DTC S Y=% X ^DD("DD") S SDPNOW=$P(Y,":",1,2) 29 I SDBC S SDBC=$S(IOM<120:0,1:$$BARC^SDAMU(+IOST(0),.SDBCON,.SDBCOFF)) 30 S (SDEND,SD1,PCNT)=0,Y=DT D D^DIQ S SDNT=Y,Y=SDD,X=Y D D^DIQ S SDPD=Y D DW^%DTC S SDPD=X_" "_SDPD 31 ;if user has selected 'all' clinics, populate VAUTC with all uncancelled TYPE=C clinics from ^SC 32 I VAUTC=1 S SDIEN=0 F S SDIEN=$O(^SC(SDIEN)) Q:+SDIEN=0 D 33 . I $P(^SC(SDIEN,0),"^",3)="C",$G(^SC(SDIEN,"ST",SDD,1))'["CANCELLED" D 34 .. S SDNAME=$P(^SC(SDIEN,0),"^",1) I $G(SDNAME)]"" S VAUTC(SDNAME)=SDIEN 35 ;-------------CALL TO SDAPI^SDAMA301 TO RETRIEVE APPT DATA------------------ 36 K ^TMP($J,"SDAMA301") N SDARRAY,SDIEN,SDNAME,SDERR,SDCL,SDDFN,SDDT,SDRESULT 37 S SDARRAY(1)=SDD_";"_SDD,SDARRAY(3)="I;R;NT",SDARRAY("FLDS")="4;6;7;8;10;19;20;21" 38 ;if user has selected clinics, build clinic filter list 39 I VAUTC'=1 D I $L(SDARRAY(2)) S SDARRAY(2)=$E(SDARRAY(2),1,$L(SDARRAY(2))-1) ;remove last ';' from end 40 . S SD="" F S SD=$O(VAUTC(SD)) Q:SD']"" S SC=$G(VAUTC(SD)) I $G(SC)]"" S SDARRAY(2)=$G(SDARRAY(2))_SC_";" 41 ;call SDAPI to retrieve appointment data 42 S SDRESULT=$$SDAPI^SDAMA301(.SDARRAY) 43 ;I SDRESULT<0 S SDERR=$$SDAPIERR^SDAMUTDT() I $L(SDERR) S SC=0 D HED W !!,SDERR,! I $E(IOST,1,2)="C-" D OUT^SDUTL 44 ;if error returned from SDAPI, display on report and quit 45 I SDRESULT<0 S SDERR=$$SDAPIERR^SDAMUTDT() I $L(SDERR) S SC=0 S SDPAGE=1 D HED W !!,SDERR,! D:$E(IOST,1,2)="C-" OUT^SDUTL D EXIT Q 46 ;if appts returned from SDAPI, sort output by clinic, appt d/t, patient 47 I SDRESULT>0 D 48 . S SDCL=0 F S SDCL=$O(^TMP($J,"SDAMA301",SDCL)) Q:'SDCL D 49 .. S SDDFN=0 F S SDDFN=$O(^TMP($J,"SDAMA301",SDCL,SDDFN)) Q:'SDDFN D 50 ... S SDDT=0 F S SDDT=$O(^TMP($J,"SDAMA301",SDCL,SDDFN,SDDT)) Q:'SDDT D 51 .... M ^TMP($J,"SDAMA301","S",SDCL,SDDT,SDDFN)=^TMP($J,"SDAMA301",SDCL,SDDFN,SDDT) 52 ;--------------------------------------------------------------------------- 53 LOOPA ;S SD=0 F S SD=$S(VAUTC:$O(^SC("B",SD)),1:$O(VAUTC(SD))) Q:SD']""!SDEND D CLIN 54 ;if no error returned from SDAPI, start looping through clinics in VAUTC (sorted by name) 55 I SDRESULT'<0 S SD=0 F S SD=$O(VAUTC(SD)) Q:SD']""!SDEND D CLIN 56 G:SDEND END 57 OVER ;S PCNT=PCNT+1 I PCNT<SDCOPY,SDCOUNT S VAUTC=0 G LOOPA 58 S PCNT=PCNT+1 I PCNT<SDCOPY,SDCOUNT G LOOPA 59 END I $G(SDCOUNT)="" G EXIT 60 ;I SDCOUNT=0 S SDPCT="No activity found for this date!" D HED W !!?$L(SDPCT)\2,SDPCT,! 61 I SDCOUNT=0 S SDPCT="No activity found for this date!" S SDPAGE=1,SC=0 D HED W !!?$L(SDPCT)\2,SDPCT,! 62 I $E(IOST,1,2)="C-" D:'$G(SDEND)&$G(SDCOUNT) OUT^SDUTL W @IOF 63 EXIT K %,%H,%H,A,ALL,DFN,DIC,I,INC,K,M,PCNT,POP,PT,SC,SD,SD1,SDCC,SDCONC,SDCP,SDD,SDEM1,SDDIF,SDDIF1,SDEA,SDEC,SDEDT,SDEM,SDEND,SDFL,SDFS,SDIN,SDNT 64 K DIRUT,SDCOPY,SDPAGE,SDPCT,SDPNOW,SDPT0,SDOI,SDPD,SDREV,SDT,SDX,SDXX,SDZ,VADAT,VADATE,VAUTC,VAUTNI,VAUTSTR,VAUTVB,VAUTD,VAQK,X,Y,Y1,Y2,Z 65 K SDBC,SDBCON,SDBCOFF,SDASH,SDPCMM,^TMP($J,"SDAMA301") 66 D CLOSE^DGUTQ Q 67 ; 68 CLIN ;S (SDFL,SC)=0 F S SC=$O(^SC("B",SD,SC)) Q:SC'>0!SDEND I $D(^SC(SC,0)),$P(^(0),"^",3)="C" I $S(VAUTC:1,'$D(VAUTC(SD)):0,VAUTC(SD)=SC:1,1:0) D LOOP^SDAL0 69 ;process each clinic IEN from VAUTC array 70 S (SDFL,SC)=0 S SC=$G(VAUTC(SD)) I $G(SC)>0,$D(^SC(SC,0)) D LOOP^SDAL0 71 Q 72 ; 73 BARQ(TTYPE,MARGIN) ; 74 N ON,OFF,Y 75 I MARGIN<120 S Y=0 G BARCQ 76 I '$$BARC^SDAMU(.TTYPE,.ON,.OFF) S Y=0 G BARCQ 77 S DIR(0)="Y",DIR("B")="NO",DIR("A")="SHOULD BARCODES BE PRINTED ON LIST(S)" 78 D ^DIR K DIR S:$D(DIRUT) Y="^" 79 BARCQ Q Y 80 ; 81 QUE ;Queue output 82 N ZTDESC,ZTSAVE,ZTRTN 83 K ZTSK,IO("Q") 84 S ZTDESC="Appointment Lists",ZTRTN="START^SDAL" 85 F X="VAUTD(","VAUTC(","SDCOPY","SDD","SDBC","VAUTD","VAUTC","SDCONC","SDPCMM" S ZTSAVE(X)="" 86 D ^%ZTLOAD 87 Q 88 ; 89 STOP ;Check for stop task request 90 S:$D(ZTQUEUED) (SDEND,ZTSTOP)=$S($$S^%ZTLOAD:1,1:0) Q 91 ; 92 HED ;Print report header 93 I SD1,$E(IOST)="C" D OUT^SDUTL Q:SDEND 94 D STOP Q:SDEND 95 S SDCOUNT=SDCOUNT+1,SD1=1 96 W:SDCOUNT>1!($E(IOST)="C") $$XY^SCRPW50(IOF,1,0) W:$X $$XY^SCRPW50("",0,0) 97 W:SC "Appointments for ",$P(^SC(SC,0),"^",1)," clinic on ",SDPD 98 W:'SC "Appointments for ",SDPD 99 W !,"Date printed: ",SDPNOW,?(IOM-6-$L(SDPAGE)),"Page: ",SDPAGE,! 100 W !," Appt.",?11,"Patient Name",?44,"SSN",?53,"Lab",?62,"X-Ray",?73,"EKG" 101 ;W !," Time",?53,"Time",?62,"Time",?73,"Time",!,?15,"Other Information",?40,"Ward Location",!,?41,"Room-Bed" 102 W !," Time",?53,"Time",?62,"Time",?73,"Time",!,?15,"Other Information",?40,"Ward Location",!,?41,"Room-Bed" 103 W !,SDASH S SDPAGE=SDPAGE+1 104 D:SDBC PAINT(SC,SDD) 105 Q 106 ; 107 PAINT(CLINIC,DATE) ; -- paint header barcodes 108 ; input: CLINIC := clinic ifn 109 ; DATE := appt date only 110 ; 111 W !?10,"Date",?45,"Clinic#",?85,"No",?110,"Yes",! 112 D BARC(10,$E(DATE,4,7)_$E(DATE,2,3)) 113 D BARC(45,"%"_CLINIC_"$") 114 D BARC(85,"N"),BARC(110,"Y") 115 W !!!!,SDASH 116 Q 117 ; 118 BARC(TAB,X) ; --print barcode 119 ; input: TAB := tab position 120 ; X := string to print 121 ; 122 W *13,?TAB W @SDBCON,X,@SDBCOFF 123 Q 124 ;
Note:
See TracChangeset
for help on using the changeset viewer.
