1 | IBDF2A ;ALB/CJM - ENCOUNTER FORM (builds form and prints it) ;NOV 16,1992
|
---|
2 | ;;3.0;AUTOMATED INFO COLLECTION SYS;**1,46**;APR 24, 1997
|
---|
3 | FORM(IBFORM,WITHDATA) ;prints FORM - defines IBDEVICE array
|
---|
4 | ;input variables - IBFORM=ien of the form, WITHDATA=1 if the form should be completed with data
|
---|
5 | ;
|
---|
6 | N IBDEVICE
|
---|
7 | ;
|
---|
8 | D DEVICE^IBDFUA(0,.IBDEVICE)
|
---|
9 | D DRWFORM(IBFORM,WITHDATA,.IBDEVICE)
|
---|
10 | EXIT ;
|
---|
11 | ;
|
---|
12 | D KPRNTVAR^IBDFUA ;kills the screen and graphics parameters
|
---|
13 | K X,Y,I
|
---|
14 | Q
|
---|
15 | DRWFORM(IBFORM,WITHDATA,IBDEVICE) ;prints IBFORM - IBDEVICE array already defined, must be passed by reference
|
---|
16 | N RTNLIST,NODE,IBPFID,IBARRAY,LINES,HAND,IBPRINT,TYPE,UNIT,PRINT,REPRINT
|
---|
17 | ;
|
---|
18 | Q:'$$FORMDSCR^IBDFU1C(.IBFORM)
|
---|
19 | D PRNTPRMS^IBDFU1C(.IBPRINT,WITHDATA,1,0,1)
|
---|
20 | ;
|
---|
21 | D DEVSETUP^IBDF2A1(.IBFORM,.IBDEVICE)
|
---|
22 | K ^TMP("IB",$J,"INTERFACES"),^TMP("IBDF",$J,"FORM"),^("OVERFLOW")
|
---|
23 | S IBPFID=""
|
---|
24 | ;
|
---|
25 | ;for forms other than toolkit, always use compiled version
|
---|
26 | I 'IBFORM("TOOLKIT"),'IBFORM("COMPILED") D COMPILE^IBDF19 Q:'IBFORM("COMPILED")
|
---|
27 | ;
|
---|
28 | S REPRINT=0
|
---|
29 | ;if printing a form with patient data to paper get id for form tracking
|
---|
30 | I '$G(IBDSAMP),IBFORM("COMPILED"),IBPRINT("WITH_DATA"),'IBDEVICE("CRT") S IBPFID=+$$FID^IBDF18C(DFN,IBAPPT,1,IBFORM("TYPE"),IBCLINIC) I $P($G(^IBD(357.96,+IBPFID,1,0)),"^",4) S REPRINT=1
|
---|
31 | ;
|
---|
32 | D ARRAYS^IBDFU1C(.IBFORM,.IBARRAY)
|
---|
33 | I 'IBFORM("TOOLKIT"),WITHDATA D JUSTDATA(WITHDATA)
|
---|
34 | I IBFORM("TOOLKIT") D DRWBLKS
|
---|
35 | ;
|
---|
36 | ;if no graphics and not PCL replace graphics with something printable
|
---|
37 | I 'IBDEVICE("PCL") D REPLACE
|
---|
38 | ;
|
---|
39 | ;can not do underlining on a CRT
|
---|
40 | I IBDEVICE("CRT") S IBARRAY("UNDERLINES")="IBARRAY(""UNDERLINES"")"
|
---|
41 | ;
|
---|
42 | ;print the form
|
---|
43 | D LNPRINT^IBDF2F($G(IBPFID))
|
---|
44 | ;
|
---|
45 | ;print the overflow report
|
---|
46 | D OVERFLOW^IBDF1B3
|
---|
47 | ;
|
---|
48 | K ^TMP("IB",$J,"INTERFACES"),^TMP("IBDF",$J,"FORM")
|
---|
49 | ;
|
---|
50 | ;reset printer defaults if PCL5
|
---|
51 | I $G(IBDEVICE("PCL")) D
|
---|
52 | . X $G(^%ZIS(2,$G(IOST(0)),2))
|
---|
53 | Q
|
---|
54 | ;
|
---|
55 | DRWBLKS ;draws all the form's blocks
|
---|
56 | N IBBLK,RTNLIST
|
---|
57 | S IBBLK="" F S IBBLK=$O(^IBE(357.1,"C",IBFORM,IBBLK)) Q:'IBBLK D DRWBLOCK^IBDF2A1(IBBLK,0)
|
---|
58 | Q
|
---|
59 | ;
|
---|
60 | JUSTDATA(WITHDATA) ;draws the form's data fields and dynamic selection lists, just the portion that may change with data
|
---|
61 | ;WITHDATA means to fill in with data
|
---|
62 | ;
|
---|
63 | N IBBLK,RTNLIST,IBFLD,IBLIST,SUB,NODE,IBPRINT
|
---|
64 | ;
|
---|
65 | D PRNTPRMS^IBDFU1C(.IBPRINT,WITHDATA,0,0,1)
|
---|
66 | ;
|
---|
67 | I IBDEVICE("LISTMAN") N IBWARN S IBWARN=0
|
---|
68 | S IBBLK="" F S IBBLK=$O(^IBE(357.1,"C",IBFORM,IBBLK)) Q:'IBBLK D
|
---|
69 | .Q:$$BLKDESCR^IBDFU1B(.IBBLK)
|
---|
70 | .S IBFLD="" F S IBFLD=$O(^IBE(357.5,"C",IBBLK,IBFLD)) Q:'IBFLD D DATAFLD^IBDF2B(IBFLD)
|
---|
71 | .S:'IBPRINT("WITH_DATA") IBPRINT("ENTIRE")=1 S IBLIST="" F S IBLIST=$O(^IBE(357.2,"AD",IBBLK,IBLIST)) Q:'IBLIST D PRINTLST^IBDF2D(IBLIST)
|
---|
72 | .I IBDEVICE("LISTMAN") S SUB=0 F S SUB=$O(^IBE(357.1,IBBLK,"B",SUB)) Q:'SUB S NODE=$G(^IBE(357.1,IBBLK,"B",SUB,0)) D DRWSTR^IBDFU(+$P(NODE,"^")\1,+$P(NODE,"^",2),"[ ]")
|
---|
73 | Q
|
---|
74 | ;
|
---|
75 | REPLACE ;replace objects requiring PCL with plain text
|
---|
76 | N IBROW,IBCOL,IBBLK
|
---|
77 | D PRNTPRMS^IBDFU1C(.IBPRINT,0,1,0,1)
|
---|
78 | S IBBLK("X")=0,IBBLK("Y")=0
|
---|
79 | I 'IBDEVICE("GRAPHICS") D
|
---|
80 | .S IBROW="" F S IBROW=$O(@IBARRAY("GRAPHICS")@(IBROW)) Q:IBROW="" S IBCOL="" F S IBCOL=$O(@IBARRAY("GRAPHICS")@(IBROW,IBCOL)) Q:IBCOL="" D DRWSTR^IBDFU(IBROW,IBCOL,$G(@IBARRAY("GRAPHICS")@(IBROW,IBCOL)),"G")
|
---|
81 | .S IBARRAY("GRAPHICS")="IBARRAY(""GRAPHICS"")"
|
---|
82 | ;
|
---|
83 | ;replace bubbles with "[ ]"
|
---|
84 | S IBROW="" F S IBROW=$O(@IBARRAY("BUBBLES")@(IBROW)) Q:IBROW="" S IBCOL="" F S IBCOL=$O(@IBARRAY("BUBBLES")@(IBROW,IBCOL)) Q:IBCOL="" D DRWSTR^IBDFU(IBROW\1,IBCOL,"[ ]")
|
---|
85 | S IBARRAY("BUBBLES")="IBARRAY(""BUBBLES"")"
|
---|
86 | ;
|
---|
87 | ;now replace hand print fields
|
---|
88 | S IBROW="" F S IBROW=$O(@IBARRAY("HAND_PRINT")@(IBROW)) Q:IBROW="" S IBCOL="" F S IBCOL=$O(@IBARRAY("HAND_PRINT")@(IBROW,IBCOL)) Q:IBCOL="" S HAND=0 F S HAND=$O(@IBARRAY("HAND_PRINT")@(IBROW,IBCOL,HAND)) Q:'HAND D
|
---|
89 | .N ROW
|
---|
90 | .S NODE=$G(@IBARRAY("HAND_PRINT")@(IBROW,IBCOL,HAND)),WIDTH=$P(NODE,"^",3),LINES=$P(NODE,"^",6),TYPE=$P(NODE,"^",14),(UNIT,PRINT)="" I $P(NODE,"^",17) S NODE=$G(^IBE(359.1,$P(NODE,"^",17),0)),UNIT=$P(NODE,"^",11),PRINT=$P(NODE,"^",5)
|
---|
91 | .Q:('WIDTH)!('TYPE)
|
---|
92 | .S STRING=""
|
---|
93 | .S:LINES'>0 LINES=1
|
---|
94 | .S ROW=IBROW
|
---|
95 | .I TYPE=1 D CNVRTLEN^IBDF2D1(WIDTH,.WIDTH),CNVRTHT^IBDF2D1(LINES,.LINES)
|
---|
96 | .I TYPE=2 F Q:LINES'>0 D S LINES=LINES-1,ROW=IBROW+2
|
---|
97 | ..N REPLACE,A,I
|
---|
98 | ..I IBFORM("WIDTH")>96 S $P(STRING,"___|",WIDTH+1)="",REPLACE("_")=" " F I=1:1:$L(PRINT) S A=$E(PRINT,I) S:A'="_" REPLACE(A)=" "_A_" "
|
---|
99 | ..I IBFORM("WIDTH")'>96 S $P(STRING,"__|",WIDTH+1)="",REPLACE("_")=" " F I=1:1:$L(PRINT) S A=$E(PRINT,I) S:A'="_" REPLACE(A)=" "_A_" "
|
---|
100 | ..S:$L(UNIT) STRING=STRING_" "_UNIT
|
---|
101 | ..I $L(PRINT) S PRINT=$$REPLACE^XLFSTR(PRINT,.REPLACE)
|
---|
102 | ..D:$L(PRINT) DRWSTR^IBDFU(ROW,IBCOL,PRINT,"",$L(STRING))
|
---|
103 | ..D DRWSTR^IBDFU(ROW+1,IBCOL,STRING,"",$L(STRING))
|
---|
104 | .I TYPE=1 S $P(STRING,"_",WIDTH+1)="_" D DRWSTR^IBDFU(ROW+LINES-1,IBCOL,STRING,"")
|
---|
105 | S IBARRAY("HAND_PRINT")="IBARRAY(""HAND_PRINT"")"
|
---|
106 | Q
|
---|