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

IBDFBKS.m

Go to the documentation of this file.
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