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

IBDFCNOF.m

Go to the documentation of this file.
  1. IBDFCNOF ;ALB/CJM - AICS clinics with no forms ; JUL 20,1993
  1. ;;3.0;AUTOMATED INFO COLLECTION SYS;;APR 24, 1997
  1. ;
  1. % ; -- list of clinics that have no encounter forms in use.
  1. ;
  1. N C,X,Y,SERV,SERVICE,CLINIC,IBHDT,IBDFIFN,IBDCNO,IBDFCNO,IBDFNODE,PAGE,IBQUIT,DIVIS,DIVNAM,VAUTD,MULTI
  1. W !!,"AICS List of Clinics with No Encounter Form in Use",!!
  1. S IBQUIT=0
  1. D DIVIS G:IBQUIT EXIT
  1. D DEVICE G:IBQUIT EXIT
  1. D DQ
  1. Q
  1. ;
  1. EXIT ; -- end of report
  1. K ^TMP($J,"IBDCN")
  1. I $D(ZTQUEUED) S ZTREQ="@" Q
  1. D ^%ZISC
  1. K ZTSK,ZTDESC,ZTSAVE,ZTRTN
  1. Q
  1. ;
  1. DQ ; -- entry point from taskmanager
  1. K ^TMP($J,"IBDCN")
  1. S IBQUIT=0,PAGE=1
  1. S IBHDT=$$HTE^XLFDT($H,1)
  1. D SET,LIST G EXIT
  1. Q
  1. ;
  1. SET ; -- build list into temporary array
  1. N IBDFCL,DIVIS,DIVNAM,SERVICE,CLINNAM,IBDFNODE,IBQUIT
  1. F IBDFIFN=0:0 S IBDFIFN=$O(^SC(IBDFIFN)) Q:'IBDFIFN S IBDCNO=$G(^SC(IBDFIFN,0)) I $P(IBDCNO,"^",3)="C" D
  1. .S DIVIS=+$P(IBDCNO,"^",15) I DIVIS=0 S DIVIS=$S(MULTI=0:$P($G(^DG(43,1,"GL")),"^",3),1:"Unknown")
  1. .S DIVNAM=$P($G(^DG(40.8,+DIVIS,0)),"^") S:DIVNAM="" DIVNAM="Unknown"
  1. .S CLINNAM=$P(IBDCNO,"^")
  1. .S Y=$P(IBDCNO,"^",8),C=$P(^DD(44,9,0),"^",2) D Y^DIQ S SERVICE=Y S:SERVICE="" SERVICE="Unknown"
  1. .I $O(^SD(409.95,"B",IBDFIFN,0)) D ; else follows
  1. ..S IBDFCL=$O(^SD(409.95,"B",IBDFIFN,0))
  1. ..S IBDFNODE=^SD(409.95,IBDFCL,0)
  1. ..S IBQUIT=0 F X=2:1:9 S:$P(IBDFNODE,"^",X)&("^1^2^3^4^5^6^8^9^"[X) IBQUIT=1 Q:IBQUIT
  1. ..I 'IBQUIT S ^TMP($J,"IBDCN",DIVIS,DIVNAM,SERVICE,CLINNAM)=IBDFIFN_"^"_$S($P(IBDFNODE,"^",7)]"":"FORM IN PROGRESS",1:"") S ^TMP($J,"IBDCN",DIVIS,0)=$G(^TMP($J,"IBDCN",DIVIS,0))+1
  1. .I '$O(^SD(409.95,"B",IBDFIFN,0)) S ^TMP($J,"IBDCN",DIVIS,DIVNAM,SERVICE,CLINNAM)=IBDFIFN,^TMP($J,"IBDCN",DIVIS,0)=$G(^TMP($J,"IBDCN",DIVIS,0))+1
  1. Q
  1. ;
  1. I $E(IOST,1,2)="C-",$Y>1,PAGE>1 D PAUSE Q:IBQUIT
  1. I PAGE>1 W @IOF
  1. W !,"List of Clinics Without Encounter Forms",?IOM-32,IBHDT," PAGE ",PAGE
  1. W !,"For Division: ",DIVNAM
  1. ;W !,"CLINICS",?27,"SERVICE",?47,"DIVISION"
  1. W !,"CLINICS",?27,"SERVICE",?47,"COMMENT"
  1. W !,$TR($J(" ",IOM)," ","-")
  1. S PAGE=PAGE+1
  1. Q
  1. ;
  1. PAUSE ; -- hold crt screen
  1. N DIR,X,Y
  1. F Q:$Y>(IOSL-2) W !
  1. S DIR(0)="E" D ^DIR S IBQUIT=$S(+Y:0,1:1)
  1. Q
  1. ;
  1. LIST ; -- lists the clinics using FORM
  1. N CLINIC,COUNT,DIR,NEWDIV,NAME,OLDDIV
  1. W:$E(IOST,1,2)="C-" @IOF
  1. I $D(^TMP($J,"IBDCN"))=0 W ?15,"No active clinics found without an assigned encounter form"
  1. S (NEWDIV,COUNT)=0,OLDDIV=""
  1. S DIVIS="" F S DIVIS=$O(^TMP($J,"IBDCN",DIVIS)) Q:DIVIS=""!(IBQUIT) D
  1. .I 'VAUTD,'$D(VAUTD(DIVIS)) Q
  1. .I 'VAUTD,'$D(^TMP($J,"IBDCN",DIVIS)) S DIVNAM=$P($G(^DG(40.8,+DIVIS,0)),"^") D HEADER W !,"No clinics found for division '",DIVNAM,"'",! Q
  1. .S DIVNAM=$O(^TMP($J,"IBDCN",DIVIS,0)) Q:DIVNAM=""
  1. .S NEWDIV=1
  1. .S SERV="" F S SERV=$O(^TMP($J,"IBDCN",DIVIS,DIVNAM,SERV)) Q:SERV=""!(IBQUIT) D
  1. ..S NAME="" F S NAME=$O(^TMP($J,"IBDCN",DIVIS,DIVNAM,SERV,NAME)) Q:NAME=""!(IBQUIT) S CLINIC=+^(NAME) D ONELINE
  1. I 'IBQUIT W:OLDDIV'="" !,"----------------",!,"Division Count = ",COUNT
  1. Q
  1. ;
  1. ONELINE ; -- print line of report
  1. I $G(NEWDIV) D NEWDIV Q:IBQUIT
  1. I $Y>(IOSL-3) D HEADER Q:IBQUIT
  1. ;W !,$E(NAME,1,25),?27,$E(SERV,1,18),?47,$E(DIVNAM,1,15)
  1. W !,$E(NAME,1,25),?27,$E(SERV,1,18)
  1. W ?47,$P(^TMP($J,"IBDCN",DIVIS,DIVNAM,SERV,NAME),"^",2)," "
  1. I '$$ACLN(CLINIC) W ?4,"(Clinic Currently Inactive)"
  1. S COUNT=COUNT+1
  1. Q
  1. ;
  1. NEWDIV ; -- print division totals and start new division
  1. I 'IBQUIT W:OLDDIV'="" !,"----------------",!,"Division Count = ",COUNT
  1. S OLDDIV=DIVIS
  1. D HEADER Q:IBQUIT
  1. W !?10,"Division: ",DIVNAM,! S NEWDIV=0,COUNT=0
  1. Q
  1. ;
  1. DEVICE ; -- select device
  1. I $D(ZTQUEUED) Q
  1. S %ZIS="MQ" D ^%ZIS I POP S IBQUIT=1 Q
  1. I $D(IO("Q")) S ZTRTN="DQ^IBDFCNOF",ZTDESC="IBD - Clinics with No Forms",ZTSAVE("VA*")="",ZTSAVE("MULTI")="" D ^%ZTLOAD W !,$S($D(ZTSK):"Request Queued Task="_ZTSK,1:"Request Canceled") D HOME^%ZIS S IBQUIT=1 Q
  1. U IO
  1. Q
  1. ;
  1. DIVIS ; -- Select division
  1. N X,Y S VAUTD=1,MULTI=0
  1. I $P($G(^DG(43,1,"GL")),"^",2) S MULTI=1 D DIVISION^VAUTOMA S:Y=-1 IBQUIT=1
  1. I 'VAUTD S X="" F S X=$O(VAUTD(X)) Q:'X S ^TMP($J,"IBDCN",X)=""
  1. Q
  1. ;
  1. ACLN(SC) ; function
  1. ; -- is clinic currently active
  1. ; Input SC := pointer to 44
  1. ; Output := 1 if currently active
  1. ; 0 if currently inactive
  1. ;
  1. N FLAG,SDIN,SDRE S FLAG=1
  1. I $D(^SC(SC,"I")) S Y=^("I"),SDIN=+Y,SDRE=+$P(Y,U,2)
  1. I $G(SDIN),SDIN'>DT,SDRE,SDRE>DT S FLAG=0
  1. I $G(SDIN),SDIN'>DT,'SDRE S FLAG=0
  1. ACLNQ Q FLAG