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

IBDF6.m

Go to the documentation of this file.
  1. IBDF6 ;ALB/CJM - ENCOUNTER FORM - ENTRY FOR BUILDING A FORM ;NOV 16,1992
  1. ;;3.0;AUTOMATED INFO COLLECTION SYS;**10,29,30**;APR 24, 1997
  1. ;
  1. FORMLIST ;
  1. N IBTKFORM,IBDEVICE,IBAPI,IOVL,IOHL,IOBRC,IOBLC,IOTRC,IOTLC,IBFORM
  1. ;IBDEVICE stores parameters related to device for printing forms
  1. D DEVICE^IBDFUA(1,.IBDEVICE)
  1. S IBTKFORM=0 ;IBTKFORM=1 only for toolkit forms
  1. S IBAPI("INDEX")="D IDXFORMS^IBDF6"
  1. S IBAPI("SELECT")="D SELECT^IBDF6"
  1. N IBFASTXT ;set to 1 for fast exit from system
  1. S IBFASTXT=0
  1. K XQORS,VALMEVL,DIR
  1. S IBCLINIC=""
  1. D CLINIC
  1. I IBCLINIC D EN^VALM("IBDF CLINIC FORM LIST")
  1. Q
  1. ONENTRY ;
  1. D IDXFORMS
  1. Q
  1. ONEXIT ;
  1. D KILL^%ZISS
  1. K ^TMP("IB",$J),^TMP("IBDF",$J),IBCLINIC,VALMY,IBQUIT,VALMBCK,X,Y,I,DA,D0
  1. Q
  1. EDITFORM ;allows user to select a form, then displays it for edit
  1. N IBFORM,ARY,DFN,IBAPPT,RTNLIST,IBPRINT
  1. S ARY="^TMP(""IBDF"",$J,""TEMPORARY CLINIC LIST"")"
  1. ;
  1. K @ARY
  1. S VALMBCK=""
  1. I $G(IBAPI("SELECT"))'="" X IBAPI("SELECT")
  1. I IBFORM D CLINICS^IBDFU4(IBFORM,ARY) I $G(@ARY@(0))>1 W !,"The form is in use by other clinics!" D LIST^IBDFU4(ARY,4) S DIR(0)="Y",DIR("A")="Still want to edit",DIR("B")="N" D ^DIR K DIR I $D(DIRUT)!(Y=0) S IBFORM=""
  1. K ARY
  1. I IBFORM,'$$LOCKFRM2^IBDFU7(IBFORM) D LOCKMSG2^IBDFU7(IBFORM) S IBFORM=""
  1. I IBFORM D PRNTPRMS^IBDFU1C(.IBPRINT,0,1,0,1),UNCMPL^IBDF19(IBFORM,0),EN^VALM("IBDF DISPLAY FORM FOR EDIT"),UNCMPL^IBDF19(IBFORM,0),FREEFRM2^IBDFU7(IBFORM)
  1. S VALMBCK="R"
  1. Q
  1. ;
  1. CLINIC ;
  1. N DIR,DIC,DIE,DR,DA
  1. S DIR(0)="409.95,.01",DIR("A")="EDIT FORMS FOR WHICH CLINIC? "
  1. D ^DIR
  1. K DIR
  1. I $D(DIRUT)!(+Y<0) Q
  1. S IBCLINIC=+Y
  1. Q
  1. ;
  1. IDXFORMS ;build an array of forms used by IBCLINIC for the list processor
  1. N FORM,SETUP,NODE,SUB,SUBREC,USE,ID
  1. K @VALMAR
  1. S SETUP="",VALMCNT=0,ID=0
  1. S SETUP=$O(^SD(409.95,"B",IBCLINIC,"")) Q:'SETUP
  1. S NODE=$G(^SD(409.95,SETUP,0)) Q:NODE=""
  1. F SUB=2,6,8,9,3,4,5,7 S FORM=$P(NODE,"^",SUB) I FORM D
  1. .I $D(^IBE(357,FORM,0)) D
  1. ..S USE=""
  1. ..D ENTRY
  1. Q
  1. ENTRY ;adds an entry to the array
  1. S USE=USE_$S(SUB=2:"Basic Encounter Form",SUB=3:"Supplemental Form - Established Patients",SUB=4:"Supplemental Form - New Patients",SUB=5:"Form To Print With No Patient Data",1:"")
  1. S:USE="" USE=USE_$S(SUB=7:"For Future Use",1:"Supplemental Form - All Patients")
  1. S ID=ID+1,VALMCNT=VALMCNT+1,@VALMAR@(VALMCNT,0)=$$DISPLAY1(FORM,USE,ID),@VALMAR@("IDX",VALMCNT,ID)=FORM D FLDCTRL^VALM10(VALMCNT) ;set video for ID column
  1. S VALMCNT=VALMCNT+1,@VALMAR@(VALMCNT,0)=$$DISPLAY2(FORM),@VALMAR@("IDX",VALMCNT,ID)=FORM_"^"_$S(SUB=2:.02,SUB=3:.03,SUB=4:.04,SUB=5:.05,SUB=6:.06,SUB=7:.07,SUB=8:.08,SUB=9:.09,1:0)
  1. Q
  1. HDR ;
  1. S VALMHDR(1)="FORMS CURRENTLY USED BY '"_$$CLNCNAME_"' HOSPITAL LOCATION"
  1. Q
  1. CLNCNAME() ;
  1. Q $P($G(^SC(IBCLINIC,0)),"^",1)
  1. DISPLAY1(FORM,USE,ID) ;
  1. N NODE,NAME,RET
  1. S RET=$J(ID,3)_$$SP(2)
  1. S NODE=$G(^IBE(357,FORM,0))
  1. S NAME=$P(NODE,"^",1)
  1. S RET=RET_$$PR(NAME,30)_$$SP(2)_USE
  1. Q RET
  1. DISPLAY2(FORM) ;
  1. N NODE,DESCR,RET
  1. S RET=$$SP(37)
  1. S NODE=$G(^IBE(357,FORM,0))
  1. S DESCR=$P(NODE,"^",3)
  1. S RET=RET_$E(DESCR,1,80)
  1. Q RET
  1. PR(STR,LEN) ; pad right
  1. Q:'$G(LEN) ""
  1. N B S STR=$E($G(STR),1,LEN)
  1. S:LEN'=$L(STR) $P(B," ",LEN-$L($G(STR)))=" "
  1. Q STR_$G(B)
  1. SP(LEN) ;
  1. Q:'$G(LEN)
  1. N S S $P(S," ",LEN)=" "
  1. Q S
  1. CHNGCLNC ;allows the user to change the clinic
  1. N SAVECLNC S SAVECLNC=IBCLINIC
  1. D FULL^VALM1
  1. S VALMBCK="R"
  1. D CLINIC I 'IBCLINIC S IBCLINIC=SAVECLNC Q
  1. D HDR
  1. X IBAPI("INDEX")
  1. Q
  1. ;
  1. SELECT ;
  1. N SEL
  1. D EN^VALM2(XQORNOD(0),"S")
  1. S SEL=$O(VALMY(""))
  1. S IBFORM=$S('SEL:"",1:+$G(@VALMAR@("IDX",2*SEL,SEL)))
  1. Q