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

IBCEFG.m

Go to the documentation of this file.
IBCEFG ;ALB/TMP - OUTPUT FORMATTER EXTRACT ;17-JAN-96
 ;;2.0;INTEGRATED BILLING;**52,51**;21-MAR-94
 ;
EXTRACT(IBXFORM,IBXIEN,IBXREC,IBXPARM) ; Extract entry into global by rec #/pg/ln/col
 ; IBXFORM  (required) Form id pointer to file #353
 ; IBXIEN   (required) entry # in form's base file to output
 ; IBXREC   (optional) record # in extract file - if not defined - 1 used
 ; IBXPARM  (optional) array used to pass in specific search variables
 ;          that can be used to customize the determination
 ;          of the form field definition to use for each
 ;          form field to be extracted
 ;          IBXPARM(1) should contain a code to identify the
 ;          type of form being processed (see $$ELE^IBCEFG0 function)
 ; Returns total # of bytes of data extracted if extract successful
 ;  or 0 if extract not successful
 ;
 N IBXPG,IBXLN,IBXCOL,IBXERR,IBXF,IBXFILE,IBX2,IBXSIZE
 S IBXERR="" S:$G(IBXREC)="" IBXREC=1
 I $G(IBXFORM)=""!($G(IBXIEN)="") S IBXERR="Missing Parameters" G EXTQ
 K ^TMP("IBXDATA",$J,IBXREC),^TMP("DIERR",$J,1),^TMP("IBXEDIT",$J)
 ;
 S IBX2=$G(^IBE(353,IBXFORM,2)),IBXFILE=+IBX2
 I 'IBXFILE S IBXERR="No base file found for form "_IBXFORM G EXTQ
 S IBXF=$S($P(IBX2,U,5):$P(IBX2,U,5),1:IBXFORM)
 ;
 I $G(^IBE(353,IBXFORM,"PRE"))'="" X ^("PRE") ;Entry pre-proc
 I $G(^IBE(353,IBXFORM,"PRE"))="",$G(^IBE(353,IBXF,"PRE"))'="" X ^("PRE") ;Entry pre-proc - parent
 G:$G(IBXERR)'="" EXTQ
 ;
 S IBXPG=""
 F  S IBXPG=$O(^IBA(364.6,"ASEQ",IBXF,IBXPG)) Q:IBXPG=""  S IBXLN="" F  S IBXLN=$O(^IBA(364.6,"ASEQ",IBXF,IBXPG,IBXLN)) Q:IBXLN=""  S IBXCOL="" D  G:$G(IBXERR)'="" EXTQ
 .F  S IBXCOL=$O(^IBA(364.6,"ASEQ",IBXF,IBXPG,IBXLN,IBXCOL)) Q:IBXCOL=""  D  Q:$G(IBXERR)'=""
 ..S IBXDA=$O(^IBA(364.6,"ASEQ",IBXF,IBXPG,IBXLN,IBXCOL,""))
 ..Q:'IBXDA
 ..D DATA(IBXPG,IBXLN,IBXCOL,IBXIEN,IBXFORM,IBXDA,.IBXPARM,.IBXERR)
 .. I $G(IBXERR)'="" S IBXERR=IBXERR_"  Field: "_$P($G(^IBA(364.6,IBXDA,0)),U,10)
 ;
EXTQ ;
 I $G(^IBE(353,IBXFORM,"POST"))'="" X ^("POST") ;Entry post-proc - assoc form or parent if not associated
 I $G(^IBE(353,IBXFORM,"POST"))="",$G(^IBE(353,IBXF,"POST"))'="" X ^("POST") ;Entry post-proc - parent of associated form
 ;
 K IBXMAX,IBX0,IBX00,IBXARRAY,IBXDA,IBXDATA,IBXFF,IBZ,IBZ0,IBZ1
 S:$G(IBXERR)'="" IBXSIZE=0
 Q +$G(IBXSIZE)
 ;
DATA(IBXPG,IBXLN,IBXCOL,IBXIEN,IBXFORM,IBXDA,IBXPARM,IBXERR) ; Extract/Format Data Element 
 ;IBXPG,IBXLN,IBXCOL = page,line,column to extract
 ;IBXIEN = internal entry # of entity to extract
 ;IBXFORM = internal entry # of FORM (file 353) to use to extract data
 ;IBXDA = ien of IB FORM SKELETON file entry to use (file 364.6)
 ;        to use to extract the data
 ;IBXPARM = passed by reference. Array that optionally contains the
 ;        parameters to use to screen
 ;IBXERR = passed by reference.  Returned = error message if error
 ;        condition found
 ; 
 ; If associated form fld - get 'local' fld override
 S:'$D(IBXREC) IBXREC=1
 S:'$D(IBXFILE) IBXFILE=+$G(^IBE(353,IBXFORM,2))
 N IBXFF,IBX0,IBXELE,IBXARRAY,IBXZ,IBXMAX,IBXLEN,IBZ,IBZ0,IBZ1,IBX00,IBXDA0
 S IBXFF=$$ELE^IBCEFG0(IBXDA,.IBXPARM,IBXFORM) ;Form field entry to use
 Q:'IBXFF  ;no form field definition found
 S IBX0=$G(^IBA(364.7,IBXFF,0)) ;Form field 0-node
 ;
 S IBXELE=$P(IBX0,U,3) ;data element def entry to use
 Q:'$D(^IBA(364.5,+IBXELE,0))  S IBX00=$G(^(0))
 ;
 S IBXARRAY=$S($G(^IBA(364.5,IBXELE,2))="":"IBXDATA",1:^(2))
 K:IBXARRAY?1A.E!(IBXARRAY?1"^"1A.E) @IBXARRAY
 S @IBXARRAY=$$DATA^IBCEFG0(IBXELE,IBX00,IBXFILE,IBXIEN,IBXARRAY,.IBXERR)
 Q:$G(IBXERR)'=""
 ;
 I $G(^IBA(364.7,IBXFF,1))'="" S IBXZ=^(1) D  Q:$G(IBXERR)'=""
 . N IBXFF,IBXLOOP,Z
 . F Z="IBXDA","IBXPG","IBXLN","IBXCOL","IBX0" S IBXLOOP(Z)=@Z ;Protect loop variables
 . X IBXZ
 . F Z="IBXDA","IBXPG","IBXLN","IBXCOL","IBX0" K @Z S @Z=IBXLOOP(Z)
 S IBXDA0=$G(^IBA(364.6,IBXDA,0))
 ; Check for required field
 I $P(IBXDA0,U,13),'$G(IBXNOREQ) D  Q:$G(IBXERR)'=""
 . I $G(@IBXARRAY)="" N Z S Z=0 F  S Z=$O(@IBXARRAY@(Z)) S:'Z IBXERR="No data found for required field " Q:$S('Z:1,1:$G(@IBXARRAY@(Z))'="")
 D:'$G(IBXNOREQ) NULLCHEK
 K IBXNOREQ
 Q:$P(IBXDA0,U,11)!($P(IBXDA0,U,8)[".")!('$D(@IBXARRAY))  ;data no longer exists or fld not an output fld
 ;
 S IBXMAX=$O(@IBXARRAY@(""),-1),IBXLEN=$P(IBXDA0,U,9)
 I IBXMAX,$P(IBXDA0,U,6),IBXMAX>$P(IBXDA0,U,6) S IBXERR="Max # lines or occurrences exceeded ("_IBXMAX_" > "_$P(IBXDA0,U,6)_") - "_$P(IBXDA0,U,10) Q:$G(IBXERR)'=""
 I 'IBXMAX D  Q
 . D SETGBL(IBXPG,IBXLN,IBXCOL,$$FORMAT($G(@IBXARRAY),IBXLEN,$P(^IBA(364.7,IBXFF,0),U,7),IBX0),.IBXSIZE)
 . D:$P($G(^IBE(353,IBXFORM,2)),U,2)="S" SETEDIT(IBXFORM,IBX0)
 ;
 S IBZ=IBXARRAY,IBZ0=$E(IBZ,1,$L(IBZ)-$S($E(IBZ,$L(IBZ))=")":1,1:0))
 S:IBZ0["("&($P(IBZ0,"(",2)'="") IBZ0=IBZ0_"," S:IBZ0'["(" IBZ0=IBZ0_"("
 F  S IBZ=$Q(@IBZ) Q:IBZ'[IBZ0  I $QS(IBZ,$QL(IBZ)) D
 . S IBZ1=IBXLN+$P(IBZ,IBZ0,2)-1
 . D SETGBL(IBXPG,IBZ1,IBXCOL,$$FORMAT(@IBZ,IBXLEN,$P(^IBA(364.7,IBXFF,0),U,7),IBX0,+$P(IBZ,"(",2)),.IBXSIZE)
 . D:$P($G(^IBE(353,IBXFORM,2)),U,2)="S" SETEDIT(IBXFORM,IBX0)
 Q
 ;
FORMAT(DATA,IBXLEN,IBXPAD,IBX0,MULTI) ; Adjust length on data for field def,add prompt
 ; DATA = the data to be output
 ; IBXLEN = the max length of the data
 ; IBXPAD = code for pad character
 ; IBX0 = the 0-node of the entry in file 364.7 being formatted
 ; MULTI = (optional)
 ;    0 or null if a single occurrence of the data
 ;    > 0 if multiple ocurrences of the data being processed (group data)
 ; 
 N Z
 S Z="",$P(Z,$S($E(IBXPAD)="Z":"0",1:" "),IBXLEN+1)=""
 S Z=$S($E(IBXPAD)="N":$E(DATA,1,IBXLEN),$E(IBXPAD,2)="L":$E(Z,1,IBXLEN-$L(DATA))_DATA,1:$E(DATA_Z,1,IBXLEN))
 I $P(IBX0,U,4)'="" D
 .I $S('$G(MULTI):1,1:MULTI=1) S Z=$P(IBX0,U,4)_Z Q  ;Add prompt to data
 .S Z=$J("",$L($P(IBX0,U,4)))_Z
 I $P(IBX0,U,10),$P(IBX0,U,9)="E" S Z="["_$P(IBX0,U,10)_"] "_Z
 Q Z
 ;
SETGBL(IBXPG,IBXLN,IBXCOL,VAL,IBXSIZE) ; Sets the output global
 ;IBXPG = Form page     IBXLN = Form line    IBXCOL = form column
 ;VAL = value to place at PG/LINE/COL   IBXSIZE = size counter (optional)
 ;
 S ^TMP("IBXDATA",$J,IBXREC,IBXPG,IBXLN,IBXCOL)=VAL,IBXSIZE=$G(IBXSIZE)+$L(VAL)
 Q
 ;
SETEDIT(IBFORM,IBX0) ;
 N Z,Z0
 Q:$P(IBX0,U,9)="D"!'$P(IBX0,U,10)
 S Z0=$P($G(^IBA(364.5,+$P(IBX0,U,3),0)),U,6)
 Q:Z0=""  S Z0=$O(^DD(+$G(^IBE(353,IBXFORM,2)),"B",Z0,""))
 Q:Z0=""
 S Z=$O(^TMP("IBXEDIT",$J,$P(IBX0,U,10),""),-1)+1
 S ^TMP("IBXEDIT",$J,$P(IBX0,U,10),Z)=Z0
 Q
 ;
NULLCHEK ; Checks for no output if null, deletes variable if appropriate
 ; Check for no output if transmit and null
 I $P($G(^IBA(364.6,+IBXDA,0)),U,12),$P($G(^IBE(353,IBXFORM,2)),U,2)="T" D
 . I $D(@IBXARRAY)=1 K:$G(@IBXARRAY)="" @IBXARRAY Q
 . I $D(@IBXARRAY)>9 D
 .. N Z
 .. S Z=0 F  S Z=$O(@IBXARRAY@(Z)) Q:'Z  I $G(@IBXARRAY@(Z))="" K @IBXARRAY@(Z)
 Q
 ;