| 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:............. | 
|---|