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

IBCEFG3.m

Go to the documentation of this file.
  1. IBCEFG3 ; ALB/TMP - OUTPUT FORMATTER MAINT - SCREEN BLD UTILITIES ; 22-JAN-96
  1. ;;2.0; INTEGRATED BILLING ;**52,88**; 21-MAR-94
  1. ;
  1. EN ; Main entry point LOCAL FORM maintenance
  1. D DT^DICRW
  1. K XQORS,VALMEVL,IBFASTXT
  1. D EN^VALM("IBCE LOCAL FORMS LIST")
  1. K IBFASTXT
  1. Q
  1. ;
  1. INIT ; -- set up inital variables local form list
  1. S U="^",VALMCNT=0,VALMBG=1
  1. K ^TMP("IBCEFORM",$J),^TMP("IBCEFORMDX",$J)
  1. D BLD
  1. Q
  1. ;
  1. BLD ; -- build list of local forms
  1. K ^TMP("IBCEFORM",$J),^TMP("IBCEFORMDX",$J)
  1. N IBCFORM,IBCNT,X,IB2
  1. S (IBCNT,VALMCNT)=0
  1. ;
  1. ; -- find all local forms
  1. S IBCFORM=0 F S IBCFORM=$O(^IBE(353,IBCFORM)) Q:'IBCFORM S IB2=$G(^(IBCFORM,2)) I $P(IB2,U,4)=0 D
  1. .; -- add to list
  1. .S IBCNT=IBCNT+1,X="" W "."
  1. .S X=$$SETFLD^VALM1(IBCNT,X,"NUMBER")
  1. .I $D(^IBE(353,IBCFORM,0)) S X=$$SETFLD^VALM1($P(^(0),"^"),X,"FNAME")
  1. .S X=$$SETFLD^VALM1($J(IBCFORM,6),X,"FENTRY")
  1. .S X=$$SETFLD^VALM1($J($P(IB2,U,2),3),X,"TYPE")
  1. .S X=$$SETFLD^VALM1($P(IB2,U,6),X,"DESCR")
  1. .D SET(X)
  1. I '$D(^TMP("IBCEFORM",$J)) S VALMCNT=2,IBCNT=2,^TMP("IBCEFORM",$J,1,0)=" ",^TMP("IBCEFORM",$J,2,0)=" No Local Forms Currently On File",^TMP("IBCEFORM",$J,"IDX",1,1)="",^TMP("IBCEFORM",$J,"IDX",2,2)=""
  1. Q
  1. ;
  1. FNL ; -- Clean up local form list
  1. K ^TMP("IBCEFORMDX",$J)
  1. D CLEAN^VALM10
  1. K IBFASTXT
  1. Q
  1. ;
  1. SET(X) ; -- set arrays for local form list
  1. S VALMCNT=VALMCNT+1,^TMP("IBCEFORM",$J,VALMCNT,0)=X
  1. S ^TMP("IBCEFORM",$J,"IDX",VALMCNT,IBCNT)=""
  1. S ^TMP("IBCEFORMDX",$J,IBCNT)=VALMCNT_"^"_IBCFORM
  1. Q
  1. ;
  1. BLDX ; -- build display of expanded local form
  1. N IB2,IBPAR,Z,Z0
  1. Q:'$G(IBCEXDA) ;Form ien in file 353
  1. S VALMBG=1,IB2=$G(^IBE(353,IBCEXDA,2)),IBPAR=+$P(IB2,U,5)
  1. K ^TMP("IBCEX",$J)
  1. D SET^VALM10(1,"Form Number: "_IBCEXDA),SET^VALM10(2,"Base File : "_$P($G(^DIC(+IB2,0)),U))
  1. D SET^VALM10(3,"Format Type: "_$$EXPAND^IBTRE(353,2.02,$P(IB2,U,2)))
  1. D SET^VALM10(4," ")
  1. D SET^VALM10(5,"Description: "_$P(IB2,U,6))
  1. S VALMCNT=5
  1. I $P(IB2,U,2)="P" D SET^VALM10(VALMCNT+1,"Form Length: "_$P(IB2,U,3)) S VALMCNT=VALMCNT+1
  1. I $P(IB2,U,2)="T" S Z=$S(IBPAR:$P($G(^IBE(353,IBPAR,2)),U,7),1:$P(IB2,U,7)) S:Z="" Z="^" D SET^VALM10(VALMCNT+1," Delimiter: "_Z) S VALMCNT=VALMCNT+1
  1. I IBPAR D SET^VALM10(VALMCNT+1," ") D SET^VALM10(VALMCNT+2,"Associated With National Form: "_$P($G(^IBE(353,IBPAR,0)),U)) S VALMCNT=VALMCNT+2
  1. S VALMCNT=VALMCNT+1 D SET^VALM10(VALMCNT," ")
  1. I $P(IB2,U,2)'="S" D
  1. . K Z
  1. . S VALMCNT=VALMCNT+1,Z0=$G(^IBE(353,IBPAR,"PRE")),Z=$G(^IBE(353,IBCEXDA,"PRE"))
  1. . I $L(Z)>57 D SPLITZ(.Z)
  1. . D SET^VALM10(VALMCNT,"Entry Pre-processor : "_$S(Z'="":Z,Z0="":"",1:Z0_" (defined for associated 'parent' form)"))
  1. . I $D(Z(0)) D
  1. .. N CT
  1. .. F CT=0:1:$O(Z(""),-1) S VALMCNT=VALMCNT+1 D SET^VALM10(VALMCNT,Z(CT))
  1. .. K Z
  1. . S VALMCNT=VALMCNT+1,Z0=$G(^IBE(353,IBPAR,"POST")),Z=$G(^IBE(353,IBCEXDA,"POST"))
  1. . I $L(Z)>57 D SPLITZ(.Z)
  1. . D SET^VALM10(VALMCNT,"Entry Post-processor: "_$S(Z'="":Z,Z0="":"",1:Z0_" (defined for associated 'parent' form)"))
  1. . I $D(Z(0)) D
  1. .. N CT
  1. .. F CT=0:1:$O(Z(""),-1) S VALMCNT=VALMCNT+1 D SET^VALM10(VALMCNT,Z(CT))
  1. .. K Z
  1. S VALMCNT=VALMCNT+1,Z0=$G(^IBE(353,IBPAR,"FPRE")),Z=$G(^IBE(353,IBCEXDA,"FPRE"))
  1. I $L(Z)>57 D SPLITZ(.Z)
  1. D SET^VALM10(VALMCNT,"Form Pre-processor : "_$S(Z'="":Z,Z0="":"",1:Z0_" (defined for associated 'parent' form)"))
  1. I $D(Z(0)) D
  1. . N CT
  1. . F CT=0:1:$O(Z(""),-1) S VALMCNT=VALMCNT+1 D SET^VALM10(VALMCNT,Z(CT))
  1. . K Z
  1. S VALMCNT=VALMCNT+1,Z0=$G(^IBE(353,IBPAR,"FPOST")),Z=$G(^IBE(353,IBCEXDA,"FPOST"))
  1. I $L(Z)>57 D SPLITZ(.Z)
  1. D SET^VALM10(VALMCNT,"Form Post-processor : "_$S(Z'="":Z,Z0="":"",1:Z0_" (defined for associated 'parent' form)"))
  1. I $D(Z(0)) D
  1. . N CT
  1. . F CT=0:1:$O(Z(""),-1) S VALMCNT=VALMCNT+1 D SET^VALM10(VALMCNT,Z(CT))
  1. . K Z
  1. I $P(IB2,U,2)'="S" D
  1. . S VALMCNT=VALMCNT+1,Z0=$G(^IBE(353,IBPAR,"OUT")),Z=$G(^IBE(353,IBCEXDA,"OUT"))
  1. . I $L(Z)>57 D SPLITZ(.Z)
  1. . D SET^VALM10(VALMCNT,"Output Logic : "_$S(Z'="":Z,Z0="":"(Use formatter default)",1:Z0_" (defined for associated 'parent' form)"))
  1. . I $D(Z(0)) D
  1. .. N CT
  1. .. F CT=0:1:$O(Z(""),-1) S VALMCNT=VALMCNT+1 D SET^VALM10(VALMCNT,Z(CT))
  1. .. K Z
  1. . S VALMCNT=VALMCNT+1,Z0=$G(^IBE(353,IBPAR,"EXT")),Z=$G(^IBE(353,IBCEXDA,"EXT"))
  1. . I $L(Z)>57 D SPLITZ(.Z)
  1. . D SET^VALM10(VALMCNT,"Extract Logic : "_$S(Z'="":Z,Z0="":"",1:Z0_" (defined for associated 'parent' form)"))
  1. . I $D(Z(0)) D
  1. .. N CT
  1. .. F CT=0:1:$O(Z(""),-1) S VALMCNT=VALMCNT+1 D SET^VALM10(VALMCNT,Z(CT))
  1. .. K Z
  1. Q
  1. ;
  1. SELX ; -- Select the form to process
  1. D EN^VALM2($G(XQORNOD(0)),"S")
  1. S IBCEXDA=$P($G(^TMP("IBCEFORMDX",$J,+$O(VALMY("")))),U,2)
  1. Q
  1. ;
  1. FNLX ; Clean up after form view/edit action
  1. K IBCEXDA
  1. D CLEAN^VALM10
  1. S VALMBCK="R"
  1. Q
  1. ;
  1. HDRX ; -- Hdr for form view/edit action
  1. S VALMHDR(1)=" "
  1. S VALMHDR(2)="LOCAL FORM: "_$P($G(^IBE(353,+$G(IBCEXDA),0)),U)
  1. Q
  1. ;
  1. SPLITZ(Z) ;Splits code into chunks the display can handle
  1. N A,CT,Q,ST
  1. S A=Z,CT=0,ST=57
  1. S Z=$E(A,1,ST)
  1. F CT=0:1 S Q=$E(A,ST+1,ST+57) Q:Q="" S Z(CT)=$J("",22)_Q,ST=ST+57
  1. Q
  1. ;