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

GMRCONS2.m

Go to the documentation of this file.
  1. GMRCONS2 ;ALB/MRY - Consult/Scheduling link report ;4/10/06 14:21
  1. ;;3.0;CONSULT/REQUEST TRACKING;**52**;DEC 27, 1997
  1. ;
  1. ;Continued from GMRCONS1
  1. D SUMARY,CT,SUMARY2,CT2
  1. S SETNOD=" " D SETNOD S SETNOD=" " D SETNOD S SETNOD="End of report." D SETNOD
  1. ;
  1. VALM S VALMHDR(1)="Service: "_SRVNM
  1. S SETNOD=$$SPC("Status",21),SETNOD=SETNOD_"Date",SETNOD=$$SPC(SETNOD,31),SETNOD=SETNOD_"SC",SETNOD=$$SPC(SETNOD,36),SETNOD=SETNOD_"L4",SETNOD=$$SPC(SETNOD,41),SETNOD=SETNOD_"Patient",SETNOD=$$SPC(SETNOD,62)
  1. S SETNOD=SETNOD_"Appointment",SETNOD=$$SPC(SETNOD,79),SETNOD=SETNOD_"Date/Time",SETNOD=$$SPC(SETNOD,97)
  1. D CHGCAP^VALM("CAPTION LINE",SETNOD)
  1. Q
  1. ;
  1. SUMARY ;Create the "A" x-ref
  1. ;;ACTERAP;Active, By Admin;Active, Edit Re-submit Admin Purpose
  1. ;;ACTERCC;Active, Can By Clinic;Active, Edit Re-submit, Cancel by Clinic
  1. ;;ACTERCP;Active, Can By Patient;Active, Edit Re-submit, Cancel by Patient
  1. ;;ACTERNS;Active, No-Show;Active, Edit Re-submit, No Show
  1. ;;ACTEROW;Active, Edit Resubmit;Active, Edit Re-submit, Old Way
  1. ;;ACTWOLHNWL;Active, Manually;Active, Without Link History
  1. ;;ACTWOLHWL;Active, EWL;Active, Without Link History EWL
  1. ;;ACTWOLHIFC;Active, IFC;Active, Without Link History IFC
  1. ;;CANCELED;Cancelled;Cancelled
  1. ;;COMPLETE;Completed;Completed
  1. ;;DSCNTUED;Discontinued;Discontinued
  1. ;;INCMPLTE;Incomplete;Incomplete
  1. ;;PENNWL;Pending;Pending
  1. ;;PENWL;Pending, EWL;Pending, Electronic Wait List
  1. ;;SCHWALCO;Sch, Linked, Ck'd Out;Scheduled, Linked, Checked Out;1
  1. ;;SCHWALNCO;Scheduled, Linked;Scheduled, Linked;1
  1. ;;SCHWHNAL;Sch, Not Linked now;Scheduled, Not Linked
  1. ;;SCHWOLHNWL;Sch, Never Linked;Scheduled, Without Link History
  1. ;;SCHWOLHWL;Schedule, EWL;Scheduled, Without Link history, wait listed
  1. ;;SCHWOLHIFC;Schedule, IFC;Scheduled, Without Link history, interfacility consult
  1. ;;TOC;Total Open Consults;Total Open Consults
  1. ;;TCC;Total Closed Consults;Total Closed Consults
  1. ;;
  1. F A=1:1 S B=$T(SUMARY+A) Q:$P(B,";",3)="" S ^TMP($J,"A",$P(B,";",3))=0
  1. S ST="" F S ST=$O(^TMP($J,"S",ST)) Q:ST="" D K WL
  1. .S AD=0 F S AD=$O(^TMP($J,"S",ST,AD)) Q:'+AD S CS=0 F S CS=$O(^TMP($J,"S",ST,AD,CS)) Q:'+CS S TND=^(CS),PTNM=$P(TND,U),PTIEN=$P(TND,U,2),LSTACT=$P(TND,U,3),AWAS1=$P(TND,U,4),AHST1=$P(TND,U,5),SRV=$P(TND,U,6) D K WL
  1. ..S STPCLNC="",SC=0 F S SC=$O(^GMR(123.5,SRV,688,SC)) Q:'+SC S STPCOD=$P(^GMR(123.5,SRV,688,SC,0),U) I STPCOD'="" S STPCLNC=$P(^DIC(40.7,STPCOD,0),U)_","_STPCLNC
  1. ..I ST="ACTIVE" D ACTIVE,TOC
  1. ..I ST="SCHEDULED" D SCHEDULE,TOC
  1. ..I ST="PENDING" D PENDING,TOC
  1. ..I ST="PARTIAL RESULTS" D INCMPLTE,KILNODE,TOC
  1. ..I ST="CANCELLED" D CANCELED,KILNODE,TCC
  1. ..I ST="DISCONTINUED" D DSCNTUED,KILNODE,TCC
  1. ..I ST="COMPLETE" D COMPLETE,KILNODE,TCC
  1. Q
  1. ACTIVE D ACTIVE^GMRCONS1 Q
  1. SCHEDULE D SCHEDULE^GMRCONS1 Q
  1. PENDING D PENDING^GMRCONS1 Q
  1. INCMPLTE D INCMPLTE^GMRCONS1 Q
  1. CANCELED D CANCELED^GMRCONS1 Q
  1. DSCNTUED D DSCNTUED^GMRCONS1 Q
  1. COMPLETE D COMPLETE^GMRCONS1 Q
  1. TOC D TOC^GMRCONS1 Q
  1. TCC D TCC^GMRCONS1 Q
  1. KILNODE D KILNODE^GMRCONS1 Q
  1. ;
  1. CT ;whole summary
  1. S LN=0,WDTH=102,PG=1,$P(DSH,"=",WDTH)="",FR=$E(PSD,4,5)_"/"_$E(PSD,6,7)_"/"_$E(PSD,2,3),TO=$E(ED,4,5)_"/"_$E(ED,6,7)_"/"_$E(ED,2,3),PD=$E(DT,4,5)_"/"_$E(DT,6,7)_"/"_$E(DT,2,3)
  1. S SETNOD="SUMMARY From: "_FR_" To "_TO,SETNOD=$$SPC(SETNOD,93),SETNOD=SETNOD_PD D SETNOD
  1. S SETNOD=DSH D SETNOD S SETNOD=" " D SETNOD
  1. S PG=PG+1,BB=$O(^TMP($J,"A","")),SUBTOT=0
  1. S B="",SUM2=0,SUM=0 F S B=$O(^TMP($J,"A",B)) Q:B="" S TOT=^(B) I TOT'=0 D:B'="COMPLETE"&(B'="CANCELED")&(B'="DSCNTUED")&(B'="TOC")&(B'="TCC")
  1. .F TX=1:1 S TEXT=$T(SUMARY+TX),P3=$P(TEXT,";",3) Q:P3="" I P3[B S SUM=SUM+TOT,SUBTOT=SUBTOT+TOT,SETNOD=" "_$J(TOT,6)_" "_$P(TEXT,";",4) D SETNOD Q
  1. S SUM2=SUM2+SUM,SETNOD="----------" D SETNOD S SETNOD=$$SPC(" "_$J(SUM,6),12),SETNOD=SETNOD_"Total OPEN consults" D SETNOD S SETNOD=" " D SETNOD
  1. S B="",SUM=0 F S B=$O(^TMP($J,"A",B)) Q:B="" S TOT=^(B) I TOT'=0 D:B="COMPLETE"!(B="CANCELED")!(B="DSCNTUED")
  1. .F TX=1:1 S TEXT=$T(SUMARY+TX),P3=$P(TEXT,";",3) Q:P3="" I P3[B S SUM=SUM+TOT,SETNOD=" "_$J(TOT,6)_" "_$P(TEXT,";",4) D SETNOD Q
  1. S SUM2=SUM2+SUM,SETNOD="----------" D SETNOD S SETNOD=$$SPC(" "_$J(SUM,6),12),SETNOD=SETNOD_"Total CLOSED consults" D SETNOD S SETNOD=" " D SETNOD
  1. S SETNOD="==========" D SETNOD S SETNOD=$$SPC(" "_$J(SUM2,6),12),SETNOD=SETNOD_"GRAND TOTAL" D SETNOD S SETNOD=" " D SETNOD
  1. Q
  1. SPC(DATA,COL) ;
  1. N SPC S SPC=DATA,L2=COL,L1=$L(DATA) F L3=1:1:(L2-L1) S SPC=SPC_" "
  1. Q SPC
  1. Q
  1. SETNOD ;
  1. S LN=LN+1,^TMP("GMRCR",$J,"CP",LN,0)=SETNOD,SPC="",VALMCNT=LN
  1. Q
  1. CT2 ;print clinic summary
  1. S A="" F S A=$O(^TMP($J,"B",A)) Q:A="" S PG=PG+1 D
  1. .S SETNOD=" " D SETNOD
  1. .S SETNOD=A_" "_FR_" - "_TO D SETNOD S SETNOD=$$SPC(" ",22),SETNOD=SETNOD_"Consult",SETNOD=$$SPC(SETNOD,63),SETNOD=SETNOD_"Clinic",SETNOD=$$SPC(SETNOD,80),SETNOD=SETNOD_"Appointment",SETNOD=$$SPC(SETNOD,97),SETNOD=SETNOD_"Stop" D SETNOD
  1. .S SETNOD=$$SPC("Status",22),SETNOD=SETNOD_"Date",SETNOD=$$SPC(SETNOD,32),SETNOD=SETNOD_"SC",SETNOD=$$SPC(SETNOD,37),SETNOD=SETNOD_"L4",SETNOD=$$SPC(SETNOD,42),SETNOD=SETNOD_"Patient",SETNOD=$$SPC(SETNOD,63)
  1. .S SETNOD=SETNOD_"Appointment",SETNOD=$$SPC(SETNOD,80),SETNOD=SETNOD_"Date/time",SETNOD=$$SPC(SETNOD,97),SETNOD=SETNOD_"Code" D SETNOD S SETNOD=DSH D SETNOD
  1. .S PG=PG+1,SUM=0,B="" F S B=$O(^TMP($J,"B",A,B)) Q:B="" S TOT=^(B) I TOT'=0 D:B'="COMPLETE"&(B'="CANCELED")&(B'="DSCNTUED")&(B'="TOC")&(B'="TCC")
  1. ..S CNSDT=0 F S CNSDT=$O(^TMP($J,"B",A,B,CNSDT)) Q:'+CNSDT S CNSLT=0 F S CNSLT=$O(^TMP($J,"B",A,B,CNSDT,CNSLT)) Q:'+CNSLT S CNSLTND=^(CNSLT),PTNM=$P(CNSLTND,U),PRTCNDT=$E(CNSDT,4,5)_"-"_$E(CNSDT,6,7)_"-"_$E(CNSDT,2,3) D
  1. ...F TX=1:1 S TEXT=$T(SUMARY+TX),P3=$P(TEXT,";",3) Q:P3="" I P3[B S P4=$P(TEXT,";",4),P6=$P(TEXT,";",6) D
  1. ....I P6=1 I $D(^SC("AWAS1",CNSLT)) D
  1. .....S CLINIC=$O(^SC("AWAS1",CNSLT,":"),-1),SDAPT=$O(^SC("AWAS1",CNSLT,CLINIC,":"),-1),STCOD=$P(^SC(CLINIC,0),U,7),STCOD=$P(^DIC(40.7,STCOD,0),U,2),CLINIC=$P(^SC(CLINIC,0),U),SDAPT1=$E(SDAPT,4,5)_"-"_$E(SDAPT,6,7)_"-"_$E(SDAPT,2,3)
  1. .....S Y=SDAPT D DD^%DT S SDAPTIM=$E($P(Y,"@",2),1,5)
  1. ....S SETNOD=$$SPC(P4,22),SETNOD=SETNOD_PRTCNDT,SETNOD=$$SPC(SETNOD,32),SETNOD=SETNOD_$P(CNSLTND,U,10),SETNOD=$$SPC(SETNOD,37),SETNOD=SETNOD_$P(CNSLTND,U,9),SETNOD=$$SPC(SETNOD,42),SETNOD=SETNOD_$E(PTNM,1,18),SETNOD=$$SPC(SETNOD,63)
  1. ....D:P6=1 D SETNOD S SUM=SUM+TOT
  1. .....S SETNOD=SETNOD_$E(CLINIC,1,15),SETNOD=$$SPC(SETNOD,80),SETNOD=SETNOD_SDAPT1_" @ "_SDAPTIM,SETNOD=$$SPC(SETNOD,98),SETNOD=SETNOD_$E(STCOD,1,5)
  1. .S SETNOD=" " D SETNOD
  1. .S BB=$O(^TMP($J,"B",A,"")),SUBTOT=0,SUM2=0,SUM=0,B="" F S B=$O(^TMP($J,"B",A,B)) Q:B="" S TOT=^(B) I TOT'=0 D:B'="COMPLETE"&(B'="CANCELED")&(B'="DSCNTUED")&(B'="TOC")&(B'="TCC")
  1. ..F TX=1:1 S TEXT=$T(SUMARY+TX),P3=$P(TEXT,";",3) Q:P3="" I P3[B S SUM=SUM+TOT S SUBTOT=SUBTOT+TOT D
  1. ...S SETNOD=" "_$J(TOT,6)_" "_$P(TEXT,";",4) D SETNOD Q
  1. .S SUM2=SUM2+SUM,SETNOD="----------" D SETNOD S SETNOD=$$SPC(" "_$J(SUM,6),12),SETNOD=SETNOD_"Total OPEN consults" D SETNOD S SETNOD=" " D SETNOD
  1. .S SUM=0,B="" F S B=$O(^TMP($J,"B",A,B)) Q:B="" S TOT=^(B) I TOT'=0 D:B="COMPLETE"!(B="CANCELED")!(B="DSCNTUED")
  1. ..F TX=1:1 S TEXT=$T(SUMARY+TX),P3=$P(TEXT,";",3) Q:P3="" I P3[B S SUM=SUM+TOT,SETNOD=" "_$J(TOT,6)_" "_$P(TEXT,";",4) D SETNOD Q
  1. .S SUM2=SUM2+SUM,SETNOD="----------" D SETNOD S SETNOD=$$SPC(" "_$J(SUM,6),12),SETNOD=SETNOD_"Total CLOSED consults" D SETNOD
  1. .S SETNOD=" " D SETNOD S SETNOD="==========" D SETNOD
  1. .S SETNOD=$$SPC(" "_$J(SUM2,6),12),SETNOD=SETNOD_"Total "_A_" consults" D SETNOD S SETNOD=" " D SETNOD
  1. Q
  1. SUMARY2 ;create the "B" x-reference
  1. S A="" F S A=$O(^TMP($J,"A",A)) Q:A="" S B=0 F S B=$O(^TMP($J,"A",A,B)) Q:'+B S C=0 F S C=$O(^TMP($J,"A",A,B,C)) Q:'+C S D=0 F S D=$O(^TMP($J,"A",A,B,C,D)) Q:'+D S ND=^(D) D
  1. .S CLNCNM=$P(^GMR(123.5,B,0),U) S ^TMP($J,"B",CLNCNM,A,C,D)=ND,^TMP($J,"C",A,CLNCNM,C,D)=ND S:'($D(^TMP($J,"B",CLNCNM,A))#2) ^TMP($J,"B",CLNCNM,A)=0 S ^TMP($J,"B",CLNCNM,A)=^TMP($J,"B",CLNCNM,A)+1
  1. Q