| 1 | SDNOS0 ;ALB/LDB - NO SHOW REPORT ; 07 May 99 10:21 AM | 
|---|
| 2 | ;;5.3;Scheduling;**20,194,410,517,523**;Aug 13, 1993;Build 6 | 
|---|
| 3 | D END1^SDNOS | 
|---|
| 4 | S (SDV1,SDIN,SDNM,SDNM1)=0,SDDIVO=SDDIV | 
|---|
| 5 | I $D(^DG(43,1,"GL")),$P(^("GL"),U,2) S SDV1=1 | 
|---|
| 6 | I SDDIV'="A" S (^UTILITY($J,"SDNO",SDDIV,"***TOT***"),^UTILITY($J,"SDNO",SDDIV,"***N***","***TOT***"),^UTILITY($J,"SDNO",SDDIV,"***NA***","***TOT***"),^UTILITY($J,"SDNO",SDDIV,"***SDNMS***"))=0 | 
|---|
| 7 | I SDDIV="A" D DIVRPT | 
|---|
| 8 | I SDCL(1)="ALL" S SDCL=0 D SDCL | 
|---|
| 9 | I SDCL(1)'="ALL" F SDSUB=0:0 S SDSUB=$O(SDCL(SDSUB)) Q:SDSUB=""  S SDCL=SDCL(SDSUB),SDLAB=$S(SDCL?.N1"*".E:"RANGE",1:"SDTST") D @SDLAB | 
|---|
| 10 | S (P1,SDTOT,SDTOT1)=0,DGTCH="NO-SHOW REPORT^CLINIC^PAGE#",(SDEND,SDHD)=0 | 
|---|
| 11 | D ^SDNOS1 | 
|---|
| 12 | Q | 
|---|
| 13 | ; | 
|---|
| 14 | DIVRPT F SDDIV=0:0 S SDDIV=$O(^DG(40.8,SDDIV)) Q:'SDDIV  S (^UTILITY($J,"SDNO",SDDIV,"***N***","***TOT***"),^UTILITY($J,"SDNO",SDDIV,"***NA***","***TOT***"),^UTILITY($J,"SDNO",SDDIV,"***TOT***"),^UTILITY($J,"SDNO",SDDIV,"***SDNMS***"))=0 | 
|---|
| 15 | Q | 
|---|
| 16 | ; | 
|---|
| 17 | SDCL F SDZ=1:1 S SDCL=$O(^SC(SDCL)) Q:'SDCL  D SDTST | 
|---|
| 18 | Q | 
|---|
| 19 | ; | 
|---|
| 20 | SDTST S SDNM=0,SDCL1=^SC(SDCL,0) I $P(SDCL1,U,3)'="C" Q | 
|---|
| 21 | I SDDIVO,SDCL(1),'$D(SDR1) D DATES Q | 
|---|
| 22 | I $S((SDDIVO&'SDCL(1)&(SDDIVO=$P(SDCL1,U,15))):1,'SDDIVO:1,$D(SDR1)&SDDIVO&($P(SDCL1,U,15)=SDDIVO):1,'$P(SDCL1,U,15)&(SDDIVO=$P(^DG(43,1,"GL"),U,3)):1,'SDV1:1,1:0) S SDIN=0 D:$D(^SC(SDCL,"I")) INAC^SDNOS1A Q:SDIN  D DATES | 
|---|
| 23 | Q | 
|---|
| 24 | ; | 
|---|
| 25 | DATES S:'SDDIVO SDDIV=$S($P(SDCL1,U,15)&SDV1:$P(SDCL1,U,15),$D(^DG(43,"GL")):$P(^("GL"),U,3),1:$O(^DG(40.8,0))) | 
|---|
| 26 | Q:$D(^UTILITY($J,"SDNO",SDDIV,$P(SDCL1,U),"***TOT***"))  S ^UTILITY($J,"SDNO",SDDIV,$P(SDCL1,U),"***TOT***")=0,^UTILITY($J,"SDNO",SDDIV,$P(SDCL1,U),"***SDNMS***")=0 | 
|---|
| 27 | S (SDEN,SDBEG)=0,SDBEG1=SDBD F SDZ1=1:1 S SDBEG1=$O(^SC(SDCL,"S",SDBEG1)) Q:SDBEG1'>0  D SDED Q:SDBEG!SDEN  D CHK | 
|---|
| 28 | S ^UTILITY($J,"SDNO",SDDIV,"***SDNMS***")=SDNM+^UTILITY($J,"SDNO",SDDIV,"***SDNMS***") | 
|---|
| 29 | Q | 
|---|
| 30 | ; | 
|---|
| 31 | SDED S SDBEG=0,SDEN=0 I $D(SDED),(SDBEG1>(SDED+.99999)) S SDEN=1 Q | 
|---|
| 32 | I '$D(SDED),(SDBEG1>(SDBD+.99999)) S SDBEG=1 Q | 
|---|
| 33 | Q | 
|---|
| 34 | ;Added 2nd Quit below SD/517 | 
|---|
| 35 | ;SD/523 - added Q:SDPAT="" to For loop | 
|---|
| 36 | CHK S SDAPP=0 F  S SDAPP=$O(^SC(SDCL,"S",SDBEG1,1,SDAPP)) Q:'SDAPP  Q:'$D(^(SDAPP,0))  I $D(^SC(SDCL,"S",SDBEG1,1,SDAPP))=10,$P(^(SDAPP,0),U,9)'="C" S SDPAT=$P(^SC(SDCL,"S",SDBEG1,1,SDAPP,0),U,1) Q:SDPAT=""  I $D(^DPT(SDPAT,"S",SDBEG1)) D CHK1 | 
|---|
| 37 | Q | 
|---|
| 38 | ; | 
|---|
| 39 | CHK1 S SD="SD" F SDCHK=1,2,10,12,14 S @(SD_SDCHK)=$P(^DPT(SDPAT,"S",SDBEG1,0),U,SDCHK) | 
|---|
| 40 | S:'SDDIVO&$P(SDCL1,U,15) SDDIV=$P(SDCL1,U,15) S:'SDDIVO&'$P(SDCL1,U,15) SDDIV=$O(^DG(40.8,0)) | 
|---|
| 41 | S:'$D(^UTILITY($J,"SDNO",SDDIV,$P(SDCL1,U),"***TOT***")) ^UTILITY($J,"SDNO",SDDIV,$P(SDCL1,U),"***TOT***")=0 | 
|---|
| 42 | I SDFMT=1 D | 
|---|
| 43 | .I (SD2="N")!(SD2="NA"),$$NOSHOW(SDPAT,SDBEG1,SDCL,$G(^DPT(SDPAT,"S",SDBEG1,0)),SDAPP) D | 
|---|
| 44 | ..D SET,TOTAL Q | 
|---|
| 45 | I SDFMT=2 D | 
|---|
| 46 | .I (SD2=""&('$D(^SC(SDCL,"S",SDBEG1,1,SDAPP,"C"))))!(SD2="N")!(SD2="NA")!(SD2="NT"),$$NOSHOW(SDPAT,SDBEG1,SDCL,$G(DPT(SDPAT,"S",SDBEG1,0)),SDAPP) D | 
|---|
| 47 | ..D SET,TOTAL Q | 
|---|
| 48 | I SD2'["C" S SDNM=SDNM+1,^UTILITY($J,"SDNO",SDDIV,$P(SDCL1,U),"***SDNMS***")=SDNM | 
|---|
| 49 | Q | 
|---|
| 50 | ; | 
|---|
| 51 | SET S:$P(SDCL1,U,15)&SDDIVO&SDV1 SDDIV=$P(SDCL1,U,15) S ^UTILITY($J,"SDNO",SDDIV,$P(SDCL1,U),SDBEG1,$P(^DPT(SDPAT,0),U),+$P(^(0),U,9))=SD2_U_SD10_U_SD12 | 
|---|
| 52 | Q | 
|---|
| 53 | ; | 
|---|
| 54 | TOTAL S ^UTILITY($J,"SDNO",SDDIV,$P(SDCL1,U),"***"_SD2_"***","***TOT***")=$S($D(^UTILITY($J,"SDNO",SDDIV,$P(SDCL1,U),"***"_SD2_"***","***TOT***")):^UTILITY($J,"SDNO",SDDIV,$P(SDCL1,U),"***"_SD2_"***","***TOT***")+1,1:1) | 
|---|
| 55 | S ^UTILITY($J,"SDNO",SDDIV,$P(SDCL1,U),$P(SDBEG1,"."),"***"_SD2_"***","***TOT***")=$S($D(^UTILITY($J,"SDNO",SDDIV,$P(SDCL1,U),$P(SDBEG1,"."),"***"_SD2_"***","***TOT***")):^("***TOT***")+1,1:1) | 
|---|
| 56 | S ^UTILITY($J,"SDNO",SDDIV,$P(SDCL1,U),"***TOT***")=$S($D(^UTILITY($J,"SDNO",SDDIV,$P(SDCL1,U),"***TOT***")):^UTILITY($J,"SDNO",SDDIV,$P(SDCL1,U),"***TOT***")+1,1:1) | 
|---|
| 57 | S ^("***TOT***")=^UTILITY($J,"SDNO",SDDIV,"***TOT***")+1,^("***TOT***")=$S($D(^UTILITY($J,"SDNO",SDDIV,"***"_SD2_"***","***TOT***")):^UTILITY($J,"SDNO",SDDIV,"***"_SD2_"***","***TOT***")+1,1:1) | 
|---|
| 58 | Q | 
|---|
| 59 | ; | 
|---|
| 60 | RANGE S SDREST=$E(SDCL,$F(SDCL,"*"),$L(SDCL)),SDCL=$E(SDCL,1,($F(SDCL,"*")-2)),SDCL1=^SC(SDCL,0) | 
|---|
| 61 | S:'SDDIVO SDDIV=$S($P(SDCL1,U,15):$P(SDCL1,U,15),'$P(SDCL1,U,15)&$D(^DG(43,"GL")):$P(^DG(43,"GL"),U,3),1:$O(^DG(40.8,0))) | 
|---|
| 62 | S SDR1=1,SDR=$P(SDCL1,U) D SDTST K SDR1 | 
|---|
| 63 | S SDREST="1"_""""_SDREST_""""_".E" F SDCXX=1:1 S SDR=$O(^SC("B",SDR)) Q:'(SDR?@SDREST)!(SDR="")  S SDCL=$O(^SC("B",SDR,-1)) S SDR1=1 D RANGE1 K SDR1 | 
|---|
| 64 | Q | 
|---|
| 65 | ; | 
|---|
| 66 | RANGE1 S:'SDDIVO SDDIV=$S($P(SDCL1,U,15):$P(SDCL1,U,15),'$P(SDCL1,U,15)&$D(^DG(43,"GL")):$P(^DG(43,"GL"),U,3),1:$O(^DG(40.8,0))) D SDTST | 
|---|
| 67 | Q | 
|---|
| 68 | ; | 
|---|
| 69 | NOSHOW(DFN,SDT,CIFN,PAT,DA) ;Input:  DFN=Patient IFN, SDT=Appointment D/T | 
|---|
| 70 | ;  CIFN=Clinic IFN, PAT=Zero node of pat. appt., DA=Clinic appt. IFN | 
|---|
| 71 | ;                        Output:  1 or 0 for noshow yes/no | 
|---|
| 72 | N NSQUERY,NS S NS=1,NSQUERY=$$STATUS^SDAM1(DFN,SDT,CIFN,PAT,DA) | 
|---|
| 73 | I $P(NSQUERY,";",3)["ACTION REQ" S NS=0 | 
|---|
| 74 | NOSHOWQ Q NS | 
|---|