VistA-WorldVistAEHR/r/AUTOMATED_INFO_COLLECTION_S.../IBDFBKS.m

180 lines
7.3 KiB
Mathematica

IBDFBKS ;ALB/CJM/AAS - Create form spec file for scanning ; 6-JUN-95
;;3.0;AUTOMATED INFO COLLECTION SYS;**25**;APR 24, 1997
;
SCAN(IBFORMID) ;
;
Q:'$G(IBFORMID)
N IBLC,PERPAGE,PAGE,ROW,COL,PAGESIZE,SCAN,ARY,X,Y,ROWHT,ROWWIDTH,CONVERT,COUNT,LINE,TAG,NAME,XOFFSET,YOFFSET,NODE,FID,TYPE,XBUBOS,YBUBOS,COUNT,YHANDOS,FIELD,IEN,QLFR,PRIORPAG,END,LN,FIELDS,IBDFILL,IBDBKGND,XYSMALL
;XOFFSET,YOFFSET are the page margins (in decipoints)
;XBUBOS,YBUBOS are the offsets within the col,row of the bubbles
;YHANDOS is the offset for a handprint field within the row
;
I '$D(DT) D DT^DICRW
I $D(^IBD(359.2,IBFORMID,0)),$D(^IBD(357.95,IBFORMID,0)) S DIK="^IBD(359.2,",DA=IBFORMID D ^DIK
I '$D(DT) D DT^DICRW
S IBLC=0
D PARAM
S CONVERT=.352778 ;for converting PCL decipoints to .1mm
; This number is actually 254/720 ... 254 PK points (.1 mm) = 1 inch
; 720 PCL5 decipoints = 1 inch
; A PCL5 decipoint = .352778 PK points
S SCAN="^TMP(""IBDF"",$J,""SCAN"",IBFORMID)"
K @SCAN
;
S FIELDS="^TMP(""IBDF"",$J,""FIELDS"")"
K @FIELDS
;
;get form description
S NODE=$G(^IBD(357.95,IBFORMID,0))
Q:NODE=""
S PERPAGE=$P(NODE,"^",10)
;determine sizes and offsets - in terms of PCL decipoints
S XOFFSET=180 ; This is 1/4 inch ... .25*720 PCL decipoints
S YOFFSET=360 ; This is 1/2 inch ... .5*720 PCL decipoints
; rowht = # of PCL decipoints/line in height
; 80 lines (133 Col) = 720/8 lines per inch)
; 72 lines (96 Col) = 720/7.2 lines per inch)
; 60 lines (80 Col) = 720/6 lines per inch)
S ROWHT=$P(NODE,"^",10),ROWHT=$S(ROWHT>72:90,ROWHT>60:100.0005,1:120)
S COLWIDTH=$P(NODE,"^",9)
S XBUBOS=$S(COLWIDTH>96:.5,COLWIDTH>80:.75,1:1) ;leaves offset in terms of fraction of column width - must still convert to decipoints
S YBUBOS=$S(COLWIDTH>96:65,COLWIDTH>80:75,1:85)
; colwidth = # of PCL decipoints/character in width
; 133 Col = 720/16.67 char per inch
; 96 Col = 720/12 char per inch
; 80 Col = 720/10 char per inch
S COLWIDTH=$S(COLWIDTH>96:(720/16.67),COLWIDTH>80:60,1:72) ;converted to decipoints
S XBUBOS=XBUBOS*COLWIDTH ;converted to decipoints
S YHANDOS=$S(ROWHT=90:0,ROWHT=100.0005:15,1:30)
;
;get the list of scannable pages
S IEN=0 F S IEN=$O(^IBD(357.95,IBFORMID,3,IEN)) Q:'IEN S NODE=$G(^IBD(357.95,IBFORMID,3,IEN,0)) S:$P(NODE,"^",2) PAGE(+NODE)=""
;
;
S PAGE=0 F S PAGE=$O(PAGE(PAGE)) Q:'PAGE D
.;
.;list all the bubbles
.S ROW=((PAGE-1)*PERPAGE)-1
.S ARY="^IBD(357.95,""AC"","_IBFORMID_")"
.F S ROW=$O(@ARY@(ROW)) Q:ROW="" D
..Q:(ROW\PERPAGE)+1'=PAGE
..S COL="" F S COL=$O(@ARY@(ROW,COL)) Q:COL="" S IEN=0 F S IEN=$O(@ARY@(ROW,COL,IEN)) Q:'IEN D
...S NODE=$G(^IBD(357.95,IBFORMID,1,IEN,0))
...Q:($P(NODE,"^",6)="")!(($P(NODE,"^",4)="")&($P(NODE,"^",8)=""))!('$P(NODE,"^",3))
...S NAME=$E($P(NODE,"^",5),1,17),QLFR=$P(NODE,"^",10)
...S TYPE=$P(NODE,"^",7)
...I (TYPE=0)!(TYPE=3) S:QLFR QLFR=$P($G(^IBD(357.98,QLFR,0)),"^",3)
...I (TYPE=1)!(TYPE=2) S:QLFR QLFR=$E($P($G(^IBD(357.98,QLFR,0)),"^"),1,12)
...I QLFR'="" S NAME=NAME_"("_QLFR_")"
...I QLFR="" S NAME=NAME_"-"
...S @SCAN@(PAGE,$P(NODE,"^",6),+$P(NODE,"^",7),COL,(ROW-((PAGE-1)*PERPAGE)),IEN)=$P(NODE,"^",3,12)
...S @SCAN@(PAGE,$P(NODE,"^",6))=NAME
...;
.;
.;list all the handprint fields
.S ARY="^IBD(357.95,""AD"","_IBFORMID_")"
.S ROW=((PAGE-1)*PERPAGE)-1
.F S ROW=$O(@ARY@(ROW)) Q:ROW="" D
..Q:(ROW\PERPAGE)+1'=PAGE
..S COL="" F S COL=$O(@ARY@(ROW,COL)) Q:COL="" S IEN=0 F S IEN=$O(@ARY@(ROW,COL,IEN)) Q:'IEN D
...S NODE=$G(^IBD(357.95,IBFORMID,2,IEN,0))
...Q:($P(NODE,"^",8)="")!('$P(NODE,"^",4))!('$P(NODE,"^",15))
...S @SCAN@(PAGE,$P(NODE,"^",8),6,COL,(ROW-((PAGE-1)*PERPAGE)),IEN)=$P(NODE,"^",3,17),NAME=$E($P(NODE,"^",5),1,15)
...I $P(NODE,"^",17) S NAME=NAME_"("_$P($G(^IBE(359.1,$P(NODE,"^",17),0)),"^")_")"
...S @SCAN@(PAGE,$P(NODE,"^",8))=NAME
;
;make form description
F COUNT=1:1 S LINE=$T(FORM+COUNT^IBDFBKS1),TAG=$P(LINE,";;"),LINE=$P(LINE,";;",2) Q:TAG["QUIT" D
.N PG
.D BLDARY("")
.I TAG["NAME" S IBDFSA(IBLC)=IBDFSA(IBLC)_" NAME = ""ENCOUNTER FORM "_IBFORMID_""";" Q
.I TAG["SITE" S IBDFSA(IBLC)=IBDFSA(IBLC)_"'VA SITE = "_$P($$SITE^VASITE,"^",2),LINE=""
.I TAG["PGCK" S IBDFSA(IBLC)=IBDFSA(IBLC)_" else if (" D Q
..S PG=$O(PAGE(0))
..S IBDFSA(IBLC)=IBDFSA(IBLC)_"(page!="_PG_")"
..F S PG=$O(PAGE(PG)) Q:'PG S IBDFSA(IBLC)=IBDFSA(IBLC)_"&&(page!="_PG_")"
..S IBDFSA(IBLC)=IBDFSA(IBLC)_"){"
.S IBDFSA(IBLC)=IBDFSA(IBLC)_LINE
.;D BLDARY(LINE)
;
;make fields
S PAGE=0,FIELD=9,PRIORPG=$O(@SCAN@(0)),LN=0,BLN=0
F S PAGE=$O(@SCAN@(PAGE)) D:PRIORPG'=PAGE PRINTEND^IBDFBKS3 Q:'PAGE S FID="" F S FID=$O(@SCAN@(PAGE,FID)) Q:FID="" S TYPE=$O(@SCAN@(PAGE,FID,"")) Q:TYPE="" D
.S NAME=$G(@SCAN@(PAGE,FID))
.;
.; -- 1 = EXACTLY ONE, 2 = AT MOST ONE (0 or 1)
.I (TYPE=1)!(TYPE=2) S FIELD=FIELD+1,@FIELDS@(PAGE,FIELD)="" D
..I TYPE=1 S NAME=NAME_" (1 Required)"
..I TYPE=2 S NAME=NAME_" (1 Optional)"
..S NAME=$$NAME(NAME)
..D BUBBLE^IBDFBKS3 Q
.;
.I TYPE=6 D Q
..N OLDNAME S OLDNAME=NAME
..S COL="" F S COL=$O(@SCAN@(PAGE,FID,TYPE,COL)) Q:COL="" S ROW="" F S ROW=$O(@SCAN@(PAGE,FID,TYPE,COL,ROW)) Q:ROW="" S IEN=0 F S IEN=$O(@SCAN@(PAGE,FID,TYPE,COL,ROW,IEN)) Q:'IEN D
...S NAME=$$NAME(OLDNAME)
...;S IBDLAST=0 I $O(@SCAN@(PAGE,FID,TYPE,COL,ROW))="",$O(@SCAN@(PAGE,FID,TYPE,COL))="",$O(@SCAN@(PAGE,FID,TYPE))="" S IBDLAST=1
...S NODE=$G(@SCAN@(PAGE,FID,6,COL,ROW,IEN)) D HANDPRNT^IBDFBKS2(IEN,NAME,PAGE,ROW,COL,$P(NODE,"^",1),$P(NODE,"^",4),$P(NODE,"^",13),$P(NODE,"^",15),$P(NODE,"^",2))
.;
.;0 = ANY NUMBER
.;3 = AT LEAST ONE (1 or more)
.I (TYPE=0)!(TYPE=3) D
..N OLDNAME
..;I TYPE=3 N FIRST,LAST S LAST=FIELD+1,LAST=""
..I TYPE=3 N FIRST,LAST S FIRST=FIELD+1,LAST=""
..S COL="" F S COL=$O(@SCAN@(PAGE,FID,TYPE,COL)) Q:COL="" S ROW="" F S ROW=$O(@SCAN@(PAGE,FID,TYPE,COL,ROW)) Q:ROW="" S IEN=$O(@SCAN@(PAGE,FID,TYPE,COL,ROW,0)) D:IEN
...S FIELD=FIELD+1,@FIELDS@(PAGE,FIELD)="",NODE=$G(@SCAN@(PAGE,FID,TYPE,COL,ROW,IEN))
...S (NAME,OLDNAME)=$G(@SCAN@(PAGE,FID))
...S NAME=$$NAME(NAME)
...I TYPE=3,$O(@SCAN@(PAGE,FID,TYPE,COL,ROW))="",($O(@SCAN@(PAGE,FID,TYPE,COL))="") S LAST=FIELD
...D BUBBLE^IBDFBKS3
;
END ; -- end of routine
K @SCAN
K @FIELDS
K ^TMP("IBDF-NAME",$J)
S ^IBD(359.2,IBFORMID,10,IBLC,0)=IBDFSA(IBLC)
S ^IBD(359.2,IBFORMID,10,0)="^^"_IBLC_"^"_IBLC_"^"_DT_"^"
Q
;
NAME(NAME) ;
; -- make sure name is unique
N X
I (TYPE=0)!(TYPE=3) S NAME=NAME_" "_$P(NODE,"^",6) I TYPE=3
I TYPE=1,NAME'["Required" S NAME=NAME_" Required"
S X=$G(^TMP("IBDF-NAME",$J,NAME))+1
S ^TMP("IBDF-NAME",$J,NAME)=+X
I X>1 S NAME=NAME_" #"_X
Q NAME
;
BLDARY(TEXT) ;
; -- builds the export array IBDFS(linecount) = text
N DIC,DA,DINUM,X,Y,I,J,DLAYGO
I IBLC=1 D
.S DIC="^IBD(359.2,",DIC(0)="L",DLAYGO=359.2,(DINUM,X)=IBFORMID D FILE^DICN
.Q
;
I IBLC>0 D
.S ^IBD(359.2,IBFORMID,10,IBLC,0)=IBDFSA(IBLC)
.K IBDFSA(IBLC)
.Q
;
S IBLC=IBLC+1
S IBDFSA(IBLC)=$G(TEXT)
Q
;
WRITE(IBFORMID) ;
N LINE S LINE=0
S X=0 X ^%ZOSF("RM")
F S LINE=$O(^IBD(359.2,IBFORMID,10,LINE)) Q:'LINE W !,$G(^IBD(359.2,IBFORMID,10,LINE,0))
S X=80 X ^%ZOSF("RM")
Q
;
PARAM ; -- get values from parameter file
; ibdfill := % fill required
; ibdbkgnd := % background expected
S IBDFILL=$P($G(^IBD(357.09,1,0)),"^",8) I IBDFILL="" S IBDFILL=20
S IBDBKGND=$P($G(^IBD(357.09,1,0)),"^",9) I IBDBKGND="" S IBDBKGND=5
S XYSMALL=$P(^IBD(357.09,1,0),"^",12) I XYSMALL'=+XYSMALL S XYSMALL=4
Q