| 1 | IBDFGRP ;ALB/MAF - GROUP COPY - 7/25/95 | 
|---|
| 2 | ;;3.0;AUTOMATED INFO COLLECTION SYS;;APR 24, 1997 | 
|---|
| 3 | N NEWLIST,NEWBLOCK | 
|---|
| 4 | S NEWLIST=IBLIST,NEWBLOCK=IBBLK | 
|---|
| 5 | N IBBLK,TOP,BOT,IBLIST,IBFORM | 
|---|
| 6 | S VALMBCK="R" | 
|---|
| 7 | S IBBLK=$$SELECT2() | 
|---|
| 8 | Q:'IBBLK | 
|---|
| 9 | ; | 
|---|
| 10 | S DIC("S")="I $P(^(0),U,11)=$P($G(^IBE(357.2,+NEWLIST,0)),U,11)" D SELECT^IBDF3 K DIC | 
|---|
| 11 | ; | 
|---|
| 12 | I '$G(IBLIST) W !!,"Block does not contain same type of selection list '"_$P($G(^IBE(357.6,+$P($G(^IBE(357.2,+NEWLIST,0)),U,11),0)),U)_"'.",! D PAUSE^IBDFU5 | 
|---|
| 13 | ; | 
|---|
| 14 | I IBLIST D EN^VALM("IBDF QUICK GRP COPY") | 
|---|
| 15 | Q | 
|---|
| 16 | ; | 
|---|
| 17 | INIT ; -- init variables and list array | 
|---|
| 18 | N IBDCNT,IBDCNT1 | 
|---|
| 19 | K ^TMP("GRP",$J),^TMP("GRPIDX",$J),IBDFHDR D KILL^VALM10() | 
|---|
| 20 | ; | 
|---|
| 21 | ;  -- Set up arrays for new and old selection list definitions in | 
|---|
| 22 | ;     in file 357.2.  Used to match data with the right subcolum # | 
|---|
| 23 | ;     when copying selection lists to a form. | 
|---|
| 24 | ; | 
|---|
| 25 | ;        - IBDFNEW(SUBCOLUM #) = TYPE OF DATA ..5th piece  (text or code) | 
|---|
| 26 | ;        - IBDFOLD(SUBCOLUM #) = TYPE OF DATA..5th piece  (text or code) | 
|---|
| 27 | D | 
|---|
| 28 | .N K,NODE | 
|---|
| 29 | .S (IBDFNEW,IBDFOLD)=0 | 
|---|
| 30 | .I $D(IBLIST) S K=0 D | 
|---|
| 31 | ..F  S K=$O(^IBE(357.2,IBLIST,2,K)) Q:'K  S NODE=$G(^IBE(357.2,IBLIST,2,K,0)),IBDFOLD(+NODE)=+$P(NODE,"^",5) | 
|---|
| 32 | ..Q | 
|---|
| 33 | .I $D(NEWLIST) S NODE="",K=0 D | 
|---|
| 34 | ..F  S K=$O(^IBE(357.2,NEWLIST,2,K)) Q:'K  S NODE=$G(^IBE(357.2,NEWLIST,2,K,0)),IBDFNEW(+NODE)=+$P(NODE,"^",5) | 
|---|
| 35 | ..Q | 
|---|
| 36 | S (IBDCNT,IBDCNT1,VALMCNT)=0 | 
|---|
| 37 | S IBDLSTNM=$P(^IBE(357.2,IBLIST,0),"^",1) D INTER D | 
|---|
| 38 | .S IBLSNODE=$G(^IBE(357.2,IBLIST,0)) | 
|---|
| 39 | .I $D(IBDFAR) F IBDFX=0:0 S IBDFX=$O(@(IBDFAR_"("_IBDFX_")")) Q:'IBDFX  S IBDFARR=$G(@(IBDFAR_"("_IBDFX_")")) D:$P(IBDFARR,"^",1)="" HEADER D:$P(IBDFARR,"^",1)]"" SETARR | 
|---|
| 40 | Q:$$LSTDESCR^IBDFU1(.IBLIST) 1 | 
|---|
| 41 | S IBRTN=IBLIST("RTN") | 
|---|
| 42 | D RTNDSCR^IBDFU1B(.IBRTN) | 
|---|
| 43 | Q | 
|---|
| 44 | ; | 
|---|
| 45 | SETARR ;  -- Set up Listman array | 
|---|
| 46 | N IBDFNODE | 
|---|
| 47 | S IBDFNODE=IBDFARR | 
|---|
| 48 | S IBDFSEL=$P(IBDFNODE,"^",4) | 
|---|
| 49 | S IBDCNT=IBDCNT+1,VALMCNT=VALMCNT+1 | 
|---|
| 50 | S X="" | 
|---|
| 51 | S IBDFVAL=$P(IBDFNODE,"^",1) | 
|---|
| 52 | S X=$$SETSTR^VALM1(IBDFVAL,X,7,7) | 
|---|
| 53 | S IBDFVAL=$P(IBDFNODE,"^",6) | 
|---|
| 54 | S X=$$SETSTR^VALM1(IBDFVAL,X,16,5) | 
|---|
| 55 | S IBDFVAL=$P(IBDFNODE,"^",2) | 
|---|
| 56 | S X=$$SETSTR^VALM1(IBDFVAL,X,23,40) | 
|---|
| 57 | S IBDFVAL=$P(^IBE(357.4,$P(IBDFNODE,"^",5),0),"^",1) | 
|---|
| 58 | S X=$$SETSTR^VALM1(IBDFVAL,X,64,15) | 
|---|
| 59 | TMP ; -- Set up TMP Array | 
|---|
| 60 | S ^TMP("GRP",$J,IBDCNT,0)=X,^TMP("GRP",$J,"IDX",VALMCNT,IBDCNT1)=IBDFSEL | 
|---|
| 61 | S ^TMP("GRPIDX",$J,IBDCNT1)=VALMCNT_"^"_$P(IBDFARR,"^",3)_"^"_$P(IBDFARR,"^",4)_"^"_$P(IBDFARR,"^",5) ;_"^"_IBDFX_"^"_$P(IBDFTMP,"^",4)_"^"_$P(IBDFTMP,"^",5)_"^"_$P(IBDFTMP,"^",1)_"^"_$P(IBDFTMP,"^",2) | 
|---|
| 62 | Q | 
|---|
| 63 | HEADER ;  -- Set up header line for the display | 
|---|
| 64 | S IBDCNT1=IBDCNT1+1 | 
|---|
| 65 | S IBDCNT=IBDCNT+1,VALMCNT=VALMCNT+1 | 
|---|
| 66 | S X="" | 
|---|
| 67 | S IBDVAL=$S($P(IBDFARR,"^",2)]"":$P(IBDFARR,"^",2),1:"BLANK") | 
|---|
| 68 | S IBDFHDR(IBDVAL)=IBDCNT1_"^"_$P(IBDFARR,"^",5) | 
|---|
| 69 | S IBDFSEL=$P(IBDFARR,"^",5) | 
|---|
| 70 | S X=$$SETSTR^VALM1(IBDCNT1_")",X,1,5) D TMP | 
|---|
| 71 | S X="",IBDCNT=IBDCNT+1,VALMCNT=VALMCNT+1 | 
|---|
| 72 | S IBDVAL=$P(IBDFARR,"^",6) | 
|---|
| 73 | S X=$$SETSTR^VALM1(IBDVAL,X,16,5) | 
|---|
| 74 | S IBDVAL=$P(IBDFARR,"^",2) | 
|---|
| 75 | S IBDVAL1=$L(IBDVAL) S IBDVAL1=(80-IBDVAL1)/2 S IBDVAL1=IBDVAL1\1 S X=$$SETSTR^VALM1(" ",X,22,IBDVAL1) | 
|---|
| 76 | S X=$$SETSTR^VALM1(IBDVAL,X,IBDVAL1,25) D TMP,CNTRL^VALM10(VALMCNT,1,80,IOINHI,IOINORM,0) | 
|---|
| 77 | S X="",IBDCNT=IBDCNT+1,VALMCNT=VALMCNT+1 | 
|---|
| 78 | S X=$$SETSTR^VALM1(" ",X,1,3) D TMP | 
|---|
| 79 | Q | 
|---|
| 80 | INTER ;  -- Find Package interface for selection list | 
|---|
| 81 | K IBARRY S IBDFAR="IBARRY",IBDFINT=$P($G(^IBE(357.2,IBLIST,0)),"^",11),IBDFINT(1)=$P(^IBE(357.6,IBDFINT,0),"^",1) D GETLST^IBDFQSL2(IBFORM,IBBLK,IBLIST,.IBDFINT,"IBARRY",1) | 
|---|
| 82 | Q | 
|---|
| 83 | HELP ; -- help code | 
|---|
| 84 | S X="?" D DISP^XQORM1 W !! | 
|---|
| 85 | Q | 
|---|
| 86 | ; | 
|---|
| 87 | EXIT ; -- exit code | 
|---|
| 88 | K IBARRY,IBDFAR,IBDFARR,IBDFHDR,IBDFINT,IBDFSEL,IBDFVAL,IBDFX,IBDLSTNM,IBDVAL,IBDVAL1,IBLIST,IBRTN,IEN,IBLSNODE,DIC,IBGRP,NODE,IBDFNEW,IBDFOLD | 
|---|
| 89 | K ^TMP("SEL",$J),^TMP("SELIDX",$J) | 
|---|
| 90 | Q | 
|---|
| 91 | ; | 
|---|
| 92 | EXPND ; -- expand code | 
|---|
| 93 | Q | 
|---|
| 94 | ; | 
|---|
| 95 | GRPCOPY ;  -- COPY GROUP | 
|---|
| 96 | N IBDVALM,GRP,VALMY,FROM,TO,IBDFCPYE | 
|---|
| 97 | S IBDFCPYF=1 | 
|---|
| 98 | S (FROM,TO)="357.4" | 
|---|
| 99 | S VALMBCK="" | 
|---|
| 100 | D EN^VALM2($G(XQORNOD(0))) | 
|---|
| 101 | I $O(VALMY(0)) D | 
|---|
| 102 | .S IBDVALM=0 | 
|---|
| 103 | .D FULL^VALM1 S VALMBCK="R" | 
|---|
| 104 | .F IBDVALM=0:0 S IBDVALM=$O(VALMY(IBDVALM)) Q:'IBDVALM  S (DA,GRP)=$P($G(^TMP("GRPIDX",$J,IBDVALM)),"^",4) D COPYGRP^IBDFU2A(GRP,IBLIST,NEWLIST,NEWBLOCK,FROM,TO) | 
|---|
| 105 | K IBDFCPYF | 
|---|
| 106 | Q | 
|---|
| 107 | SELECT2() ;allows the user to select a form, then a block from it | 
|---|
| 108 | S IBBLK="" | 
|---|
| 109 | S IBFORM=$$SLCTFORM^IBDFU4(0) | 
|---|
| 110 | I IBFORM D | 
|---|
| 111 | .W !!,"NOW CHOOSE THE BLOCK TO COPY!",! | 
|---|
| 112 | .S IBBLK=$$SLCTBLK^IBDFU8(IBFORM,IOSL) | 
|---|
| 113 | Q IBBLK | 
|---|