1 | IBDFFV3 ;;ALB/CMR - AICS FORM VALIDATION ; FEB 23, 1996
|
---|
2 | ;;3.0;AUTOMATED INFO COLLECTION SYS;;APR 24, 1997
|
---|
3 | PRINT(FRM,NAME,TYPE,CL,DG) ; -- print validation for each form
|
---|
4 | ; -- FRM = ien file 357
|
---|
5 | ; -- NAME (optional) name of form
|
---|
6 | ; -- TYPE (optional) type of form where:
|
---|
7 | ; -- 1 = FORM
|
---|
8 | ; -- 2 = BASIC DEFAULT FORM
|
---|
9 | ; -- 3 = SUPPLEMENTAL FORM - PATIENT WITH PRIOR VISITS
|
---|
10 | ; -- 4 = SUPPLEMENTAL FORM - FIRST TIME PATIENT
|
---|
11 | ; -- 5 = FORM WITH NO PRE-PRINTED PATIENT DATA
|
---|
12 | ; -- 6 = SUPPLEMENTAL FORM - ALL PATIENTS
|
---|
13 | ; -- 7 = RESERVED FOR FUTURE USE
|
---|
14 | ; -- 8 = SUPPLEMENTAL FORM - ALL PATIENTS
|
---|
15 | ; -- 9 = SUPPLEMENTAL FORM - ALL PATIENTS
|
---|
16 | ; -- CL (optional) clinic header
|
---|
17 | ; -- DG (optional) group or division header
|
---|
18 | N IEN,BUB,NODE,PG,IBDFFVAL,IBID,IBLABEL,PI,CK,CODE,GROUP
|
---|
19 | K WRITE
|
---|
20 | Q:'FRM!($G(^IBE(357,FRM,0))']"")
|
---|
21 | S PG=0
|
---|
22 | I $G(NAME)']"" S NAME=$P(^IBE(357,FRM,0),U)
|
---|
23 | I '$G(TYPE) S TYPE=1
|
---|
24 | S IEN=$P(^IBE(357,FRM,0),U,13) Q:'IEN!('$D(^IBD(357.95,+IEN)))
|
---|
25 | W $$CJ^XLFSTR("ENCOUNTER FORM VALIDATION",IOM),!
|
---|
26 | I $G(DG)]"" W !,DG
|
---|
27 | I $G(CL)]"" W !,CL
|
---|
28 | W !,$P($T(TYPE+TYPE),";;",2)," ",NAME
|
---|
29 | K BUB,HP
|
---|
30 | ; -- $o through all bubbles
|
---|
31 | S BUB=0,GROUP="" F S BUB=$O(^IBD(357.95,IEN,1,BUB)) Q:'BUB!($G(IBDFOUT)) S NODE=$G(^IBD(357.95,IEN,1,BUB,0)) I NODE]"" D DISP
|
---|
32 | K BUB
|
---|
33 | S HP=0 F S HP=$O(^IBD(357.95,IEN,2,HP)) Q:'HP!($G(IBDFOUT)) S NODE=$G(^IBD(357.95,IEN,2,HP,0)) I NODE]"" D DISP
|
---|
34 | Q:$G(IBDFOUT)
|
---|
35 | D PAGE(100) ;force final page footers
|
---|
36 | Q
|
---|
37 | DISP ; -- display data for each element
|
---|
38 | N IBINACT
|
---|
39 | N ERR
|
---|
40 | ; -- write out group subheader if different from previous
|
---|
41 | I GROUP'=$P(NODE,U,5) S GROUP=$P(NODE,U,5) D PAGE(8) Q:$G(IBDFOUT) I '$G(CK) W !!,GROUP,!
|
---|
42 | ; -- determine errors up front
|
---|
43 | S PI=$S($D(BUB):$P(NODE,U,3),$D(HP):$P(NODE,U,4),1:"") I 'PI S ERR("PI")=""
|
---|
44 | S DQ=$P(NODE,U,10) I 'DQ,$P($G(^IBE(357.6,+PI,0)),U,19) S ERR("DQ")=""
|
---|
45 | K IBID,IBLABEL,IBINACT
|
---|
46 | I $D(BUB) S X=$P(NODE,U,4) I X,PI X $G(^IBE(357.6,PI,19)) I $G(IBLABEL)']"" S ERR("CODE")=""
|
---|
47 | I $G(IBINACT) S ERR("INACT")=""
|
---|
48 | D PAGE(5) Q:$G(IBDFOUT)
|
---|
49 | ; -- write error flag followed by displayed text
|
---|
50 | W ! W:$D(ERR) "*" W ?2,"[ ] ",$S($D(BUB):$P(NODE,U,8),$D(HP):$P(NODE,U,9),1:"") S WRITE=1
|
---|
51 | ; -- if bubble is dynamic s code accordingly
|
---|
52 | I $D(BUB),($G(IBID)']""),($P(NODE,U,11)) S IBID="DYNAMIC",IBLABEL="Value determined at print time"
|
---|
53 | I $D(HP) S IBID="HAND PRINT",IBLABEL="Value determined at scan time"
|
---|
54 | ; -- write return values
|
---|
55 | I $G(IBID)]"" W !,?6,IBID,?22,$G(IBLABEL)
|
---|
56 | ; -- write data qualifiers
|
---|
57 | I DQ]"" W !?6,"DATA QUALIFIER",?22,$P($G(^IBD(357.98,DQ,0)),"^")
|
---|
58 | I $D(HP),($P(NODE,U,17)) W !?6,"DATA ELEMENT",?22,$P($G(^IBE(359.1,$P(NODE,U,17),0)),U)
|
---|
59 | ; -- process errors
|
---|
60 | I $D(ERR) D ERROR
|
---|
61 | Q
|
---|
62 | ERROR ;gathers errors to write
|
---|
63 | I '$D(ERR) Q
|
---|
64 | N CNT
|
---|
65 | I $D(ERR("PI")) D ERRORS("*** Package Interface is missing ***")
|
---|
66 | I $D(ERR("DQ")) D ERRORS("*** Data Qualifier is missing ***")
|
---|
67 | I $D(ERR("CODE")) D ERRORS("*** Invalid "_GROUP_" ***")
|
---|
68 | I $D(ERR("INACT")) D ERRORS("*** Inactive "_GROUP_" ***")
|
---|
69 | Q
|
---|
70 | ERRORS(ERR) ; -- writes out errors
|
---|
71 | I $G(CNT) W !
|
---|
72 | I '$G(CNT) W !?6,"ERRORS" S CNT=1
|
---|
73 | W ?22,ERR
|
---|
74 | Q
|
---|
75 | PAGE(PL) ; -- check page length
|
---|
76 | ; -- adds two lines to account for footer
|
---|
77 | K CK
|
---|
78 | I +PL S PL=PL+2
|
---|
79 | I '+PL S PL=5
|
---|
80 | Q:$Y+PL<IOSL
|
---|
81 | S PG=PG+1,CK=1
|
---|
82 | W !!,$$CJ^XLFSTR(PG,IOM)
|
---|
83 | I $E(IOST,1,2)["C-" S DIR(0)="E" D ^DIR K DIR,DIRUT,DUOUT,DTOUT I 'Y S IBDFOUT=1 Q
|
---|
84 | W @IOF
|
---|
85 | I +PL<100 D
|
---|
86 | .W !,$$CJ^XLFSTR("ENCOUNTER FORM VALIDATION",IOM)
|
---|
87 | .W !!,$P($T(TYPE+TYPE),";;",2)," ",NAME
|
---|
88 | .W !!,GROUP,!
|
---|
89 | Q
|
---|
90 | TYPE ; -- list of form types
|
---|
91 | ;;FORM:.........................................
|
---|
92 | ;;BASIC DEFAULT FORM: .........................
|
---|
93 | ;;SUPPLEMENTAL FORM - PATIENT WITH PRIOR VISITS:
|
---|
94 | ;;SUPPLEMENTAL FORM - FIRST TIME PATIENT: .....
|
---|
95 | ;;FORM WITH NO PRE-PRINTED PATIENT DATA: ......
|
---|
96 | ;;SUPPLEMENTAL FORM - ALL PATIENTS: ...........
|
---|
97 | ;;RESERVED FOR FUTURE USE: ....................
|
---|
98 | ;;SUPPLEMENTAL FORM - ALL PATIENTS:.............
|
---|
99 | ;;SUPPLEMENTAL FORM - ALL PATIENTS:.............
|
---|